@openpalm/ui 0.11.2-rc.1 → 0.11.2-rc.2
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/build/.openpalm-ui-version +1 -1
- package/build/client/_app/immutable/chunks/{BbsmUDEz.js → B9kBGpAJ.js} +1 -1
- package/build/client/_app/immutable/chunks/B9kBGpAJ.js.br +0 -0
- package/build/client/_app/immutable/chunks/B9kBGpAJ.js.gz +0 -0
- package/build/client/_app/immutable/chunks/{7Y-z2Cs4.js → BTqXEXC4.js} +2 -2
- package/build/client/_app/immutable/chunks/BTqXEXC4.js.br +0 -0
- package/build/client/_app/immutable/chunks/BTqXEXC4.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Bx59jv_h.js +1 -0
- package/build/client/_app/immutable/chunks/Bx59jv_h.js.br +1 -0
- package/build/client/_app/immutable/chunks/Bx59jv_h.js.gz +0 -0
- package/build/client/_app/immutable/chunks/{BBdT9Cjm.js → CBsYTB66.js} +1 -1
- package/build/client/_app/immutable/chunks/CBsYTB66.js.br +0 -0
- package/build/client/_app/immutable/chunks/CBsYTB66.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DQhBfV9e.js +1 -0
- package/build/client/_app/immutable/chunks/DQhBfV9e.js.br +2 -0
- package/build/client/_app/immutable/chunks/DQhBfV9e.js.gz +0 -0
- package/build/client/_app/immutable/chunks/{BxIEEPV3.js → DyJ19VZu.js} +1 -1
- package/build/client/_app/immutable/chunks/DyJ19VZu.js.br +0 -0
- package/build/client/_app/immutable/chunks/DyJ19VZu.js.gz +0 -0
- package/build/client/_app/immutable/chunks/{BQ0vnNWj.js → adhfkYFR.js} +1 -1
- package/build/client/_app/immutable/chunks/adhfkYFR.js.br +0 -0
- package/build/client/_app/immutable/chunks/adhfkYFR.js.gz +0 -0
- package/build/client/_app/immutable/chunks/bVbUAUAn.js +3 -0
- package/build/client/_app/immutable/chunks/bVbUAUAn.js.br +0 -0
- package/build/client/_app/immutable/chunks/bVbUAUAn.js.gz +0 -0
- package/build/client/_app/immutable/chunks/{jhtvkF_A.js → c0HpR2WI.js} +1 -1
- package/build/client/_app/immutable/chunks/c0HpR2WI.js.br +0 -0
- package/build/client/_app/immutable/chunks/c0HpR2WI.js.gz +0 -0
- package/build/client/_app/immutable/entry/{app.DamaMvOo.js → app.DPmsGUJp.js} +2 -2
- package/build/client/_app/immutable/entry/app.DPmsGUJp.js.br +0 -0
- package/build/client/_app/immutable/entry/app.DPmsGUJp.js.gz +0 -0
- package/build/client/_app/immutable/entry/start.Cco8Jp7y.js +1 -0
- package/build/client/_app/immutable/entry/start.Cco8Jp7y.js.br +0 -0
- package/build/client/_app/immutable/entry/start.Cco8Jp7y.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{0.0pi4RS6G.js → 0.Dtu4G17f.js} +1 -1
- package/build/client/_app/immutable/nodes/0.Dtu4G17f.js.br +0 -0
- package/build/client/_app/immutable/nodes/0.Dtu4G17f.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{1.D_t9eVLg.js → 1.tXMubY47.js} +1 -1
- package/build/client/_app/immutable/nodes/1.tXMubY47.js.br +0 -0
- package/build/client/_app/immutable/nodes/1.tXMubY47.js.gz +0 -0
- package/build/client/_app/immutable/nodes/2.BAZ2QRxd.js +1 -0
- package/build/client/_app/immutable/nodes/2.BAZ2QRxd.js.br +0 -0
- package/build/client/_app/immutable/nodes/2.BAZ2QRxd.js.gz +0 -0
- package/build/client/_app/immutable/nodes/3.CU_MVBDy.js +1 -0
- package/build/client/_app/immutable/nodes/3.CU_MVBDy.js.br +0 -0
- package/build/client/_app/immutable/nodes/3.CU_MVBDy.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{4.rszAmyBN.js → 4.CEDfN_Gi.js} +1 -1
- package/build/client/_app/immutable/nodes/4.CEDfN_Gi.js.br +0 -0
- package/build/client/_app/immutable/nodes/4.CEDfN_Gi.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{5.B5KOuICr.js → 5.CTedszia.js} +1 -1
- package/build/client/_app/immutable/nodes/5.CTedszia.js.br +0 -0
- package/build/client/_app/immutable/nodes/5.CTedszia.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{6.Bw69iLts.js → 6.Dj2G5q_Y.js} +1 -1
- package/build/client/_app/immutable/nodes/6.Dj2G5q_Y.js.br +0 -0
- package/build/client/_app/immutable/nodes/6.Dj2G5q_Y.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{7.ockxnYPK.js → 7.D6Nw-pl1.js} +1 -1
- package/build/client/_app/immutable/nodes/7.D6Nw-pl1.js.br +0 -0
- package/build/client/_app/immutable/nodes/7.D6Nw-pl1.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{8.Bt2Nswbt.js → 8.DzpdIlcK.js} +1 -1
- package/build/client/_app/immutable/nodes/8.DzpdIlcK.js.br +0 -0
- package/build/client/_app/immutable/nodes/8.DzpdIlcK.js.gz +0 -0
- package/build/client/_app/immutable/nodes/9.q6VxiDYg.js +45 -0
- package/build/client/_app/immutable/nodes/9.q6VxiDYg.js.br +0 -0
- package/build/client/_app/immutable/nodes/9.q6VxiDYg.js.gz +0 -0
- package/build/client/_app/version.json +1 -1
- package/build/client/_app/version.json.br +1 -1
- package/build/client/_app/version.json.gz +0 -0
- package/build/server/chunks/{0-BK7D9z9V.js → 0-CohBWzrb.js} +2 -2
- package/build/server/chunks/{0-BK7D9z9V.js.map → 0-CohBWzrb.js.map} +1 -1
- package/build/server/chunks/1-9GlsaHWX.js +9 -0
- package/build/server/chunks/{1-BTD70sT7.js.map → 1-9GlsaHWX.js.map} +1 -1
- package/build/server/chunks/{2-DQWoUtW1.js → 2-vy1PpAbA.js} +2 -2
- package/build/server/chunks/{2-DQWoUtW1.js.map → 2-vy1PpAbA.js.map} +1 -1
- package/build/server/chunks/{3-COIGgysA.js → 3-BU0uFnIR.js} +2 -2
- package/build/server/chunks/{3-COIGgysA.js.map → 3-BU0uFnIR.js.map} +1 -1
- package/build/server/chunks/4-ldHpTpq0.js +9 -0
- package/build/server/chunks/{4-CubOOlWA.js.map → 4-ldHpTpq0.js.map} +1 -1
- package/build/server/chunks/5-B6iGAka8.js +9 -0
- package/build/server/chunks/{5-C5D5O8w1.js.map → 5-B6iGAka8.js.map} +1 -1
- package/build/server/chunks/6-BSZX2-mS.js +9 -0
- package/build/server/chunks/{6-DCNMSRHJ.js.map → 6-BSZX2-mS.js.map} +1 -1
- package/build/server/chunks/7-C1xYJqTn.js +9 -0
- package/build/server/chunks/{7-jdfP4oIc.js.map → 7-C1xYJqTn.js.map} +1 -1
- package/build/server/chunks/{8-Dd434AgX.js → 8-CkxlZEhw.js} +3 -3
- package/build/server/chunks/{8-Dd434AgX.js.map → 8-CkxlZEhw.js.map} +1 -1
- package/build/server/chunks/{9-Dj1CAYUs.js → 9-CReuqtkZ.js} +3 -3
- package/build/server/chunks/{9-Dj1CAYUs.js.map → 9-CReuqtkZ.js.map} +1 -1
- package/build/server/chunks/{Navbar-Bbr28xK9.js → Navbar-CvtXS8Br.js} +3 -3
- package/build/server/chunks/{Navbar-Bbr28xK9.js.map → Navbar-CvtXS8Br.js.map} +1 -1
- package/build/server/chunks/{_page.svelte-D7VlbGXj.js → _page.svelte-DLOnDP4u.js} +5 -5
- package/build/server/chunks/{_page.svelte-D7VlbGXj.js.map → _page.svelte-DLOnDP4u.js.map} +1 -1
- package/build/server/chunks/{_page.svelte-Dfe5FJdv.js → _page.svelte-DPRrE2o7.js} +5 -5
- package/build/server/chunks/{_page.svelte-Dfe5FJdv.js.map → _page.svelte-DPRrE2o7.js.map} +1 -1
- package/build/server/chunks/{_page.svelte-B0M8mXzs.js → _page.svelte-Dil5xfYa.js} +20 -1
- package/build/server/chunks/_page.svelte-Dil5xfYa.js.map +1 -0
- package/build/server/chunks/{_page.svelte-fkfNgz2M.js → _page.svelte-DqmfyUaG.js} +3 -3
- package/build/server/chunks/{_page.svelte-fkfNgz2M.js.map → _page.svelte-DqmfyUaG.js.map} +1 -1
- package/build/server/chunks/{_page.svelte-4qKAK6Tb.js → _page.svelte-PbgUQ4cZ.js} +5 -5
- package/build/server/chunks/{_page.svelte-4qKAK6Tb.js.map → _page.svelte-PbgUQ4cZ.js.map} +1 -1
- package/build/server/chunks/{_page.svelte-D-uhfsj5.js → _page.svelte-YTnL96oH.js} +6 -6
- package/build/server/chunks/{_page.svelte-D-uhfsj5.js.map → _page.svelte-YTnL96oH.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DrZeLUaT.js → _server.ts-0-ApvfUF.js} +4 -4
- package/build/server/chunks/{_server.ts-DrZeLUaT.js.map → _server.ts-0-ApvfUF.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BXQH4Qlt.js → _server.ts-3N-jIKPt.js} +4 -4
- package/build/server/chunks/{_server.ts-BXQH4Qlt.js.map → _server.ts-3N-jIKPt.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DFBCN73l.js → _server.ts-B0-0yZap.js} +5 -5
- package/build/server/chunks/{_server.ts-DFBCN73l.js.map → _server.ts-B0-0yZap.js.map} +1 -1
- package/build/server/chunks/{_server.ts-CAycEHO4.js → _server.ts-B2wk42hT.js} +9 -7
- package/build/server/chunks/_server.ts-B2wk42hT.js.map +1 -0
- package/build/server/chunks/{_server.ts-fRYbSpUy.js → _server.ts-B4V9SeNf.js} +4 -4
- package/build/server/chunks/{_server.ts-fRYbSpUy.js.map → _server.ts-B4V9SeNf.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BAmfRgDu.js → _server.ts-BACShnCW.js} +4 -4
- package/build/server/chunks/{_server.ts-BAmfRgDu.js.map → _server.ts-BACShnCW.js.map} +1 -1
- package/build/server/chunks/{_server.ts-B4p_jHqU.js → _server.ts-BEHfO4TD.js} +24 -8
- package/build/server/chunks/_server.ts-BEHfO4TD.js.map +1 -0
- package/build/server/chunks/{_server.ts-B3uS0ABl.js → _server.ts-BGwZSYn-.js} +4 -4
- package/build/server/chunks/{_server.ts-B3uS0ABl.js.map → _server.ts-BGwZSYn-.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BimilJxw.js → _server.ts-BMpP5PNG.js} +4 -4
- package/build/server/chunks/{_server.ts-BimilJxw.js.map → _server.ts-BMpP5PNG.js.map} +1 -1
- package/build/server/chunks/{_server.ts--N8krQnw.js → _server.ts-BNcRsaYO.js} +4 -4
- package/build/server/chunks/{_server.ts--N8krQnw.js.map → _server.ts-BNcRsaYO.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DVdrht9C.js → _server.ts-BP8lFvxH.js} +4 -4
- package/build/server/chunks/{_server.ts-DVdrht9C.js.map → _server.ts-BP8lFvxH.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DZyh2rB9.js → _server.ts-BR4XEibW.js} +5 -5
- package/build/server/chunks/{_server.ts-DZyh2rB9.js.map → _server.ts-BR4XEibW.js.map} +1 -1
- package/build/server/chunks/{_server.ts-CpO4xFnt.js → _server.ts-BS1_TD9E.js} +4 -4
- package/build/server/chunks/{_server.ts-CpO4xFnt.js.map → _server.ts-BS1_TD9E.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DSUpiCQo.js → _server.ts-BTyvF6Nf.js} +4 -4
- package/build/server/chunks/{_server.ts-DSUpiCQo.js.map → _server.ts-BTyvF6Nf.js.map} +1 -1
- package/build/server/chunks/{_server.ts-CaIBfM3d.js → _server.ts-BVc71p7g.js} +4 -4
- package/build/server/chunks/{_server.ts-CaIBfM3d.js.map → _server.ts-BVc71p7g.js.map} +1 -1
- package/build/server/chunks/{_server.ts-CVnGEGgz.js → _server.ts-Bb3Cujgm.js} +4 -4
- package/build/server/chunks/{_server.ts-CVnGEGgz.js.map → _server.ts-Bb3Cujgm.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BZV8kPh-.js → _server.ts-Bg7ik1iz.js} +4 -4
- package/build/server/chunks/{_server.ts-BZV8kPh-.js.map → _server.ts-Bg7ik1iz.js.map} +1 -1
- package/build/server/chunks/{_server.ts-oLxKZF14.js → _server.ts-BkAHRjAx.js} +6 -6
- package/build/server/chunks/{_server.ts-oLxKZF14.js.map → _server.ts-BkAHRjAx.js.map} +1 -1
- package/build/server/chunks/{_server.ts-D3isWFzo.js → _server.ts-BkOGrDZ4.js} +5 -5
- package/build/server/chunks/{_server.ts-D3isWFzo.js.map → _server.ts-BkOGrDZ4.js.map} +1 -1
- package/build/server/chunks/{_server.ts-CRgQ6JvE.js → _server.ts-BpQxnQ2O.js} +4 -4
- package/build/server/chunks/{_server.ts-CRgQ6JvE.js.map → _server.ts-BpQxnQ2O.js.map} +1 -1
- package/build/server/chunks/{_server.ts-kVbBWaDD.js → _server.ts-Bs4cf3Bg.js} +27 -5
- package/build/server/chunks/_server.ts-Bs4cf3Bg.js.map +1 -0
- package/build/server/chunks/{_server.ts-B1J6gmcu.js → _server.ts-Btgzl9Ds.js} +4 -4
- package/build/server/chunks/{_server.ts-B1J6gmcu.js.map → _server.ts-Btgzl9Ds.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DXBrPiAj.js → _server.ts-C0hfYyE8.js} +4 -4
- package/build/server/chunks/{_server.ts-DXBrPiAj.js.map → _server.ts-C0hfYyE8.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BtIfXnk8.js → _server.ts-C7p2LyhO.js} +4 -4
- package/build/server/chunks/{_server.ts-BtIfXnk8.js.map → _server.ts-C7p2LyhO.js.map} +1 -1
- package/build/server/chunks/{_server.ts-rGaZfdIc.js → _server.ts-CE5OGGjJ.js} +4 -4
- package/build/server/chunks/{_server.ts-rGaZfdIc.js.map → _server.ts-CE5OGGjJ.js.map} +1 -1
- package/build/server/chunks/{_server.ts-vr1wDdjl.js → _server.ts-CFVu94d-.js} +4 -4
- package/build/server/chunks/{_server.ts-vr1wDdjl.js.map → _server.ts-CFVu94d-.js.map} +1 -1
- package/build/server/chunks/{_server.ts-Bb62UkjI.js → _server.ts-CHzGnp76.js} +4 -4
- package/build/server/chunks/{_server.ts-Bb62UkjI.js.map → _server.ts-CHzGnp76.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BAlnprxv.js → _server.ts-CJN0XAKJ.js} +4 -4
- package/build/server/chunks/{_server.ts-BAlnprxv.js.map → _server.ts-CJN0XAKJ.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BDGqI5pR.js → _server.ts-CK8Xw6ia.js} +4 -4
- package/build/server/chunks/{_server.ts-BDGqI5pR.js.map → _server.ts-CK8Xw6ia.js.map} +1 -1
- package/build/server/chunks/{_server.ts-CBYvFEVS.js → _server.ts-CMiIat2x.js} +6 -6
- package/build/server/chunks/{_server.ts-CBYvFEVS.js.map → _server.ts-CMiIat2x.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BjsoTMxt.js → _server.ts-CP_BI6Nx.js} +4 -4
- package/build/server/chunks/{_server.ts-BjsoTMxt.js.map → _server.ts-CP_BI6Nx.js.map} +1 -1
- package/build/server/chunks/{_server.ts-CcLqY7mC.js → _server.ts-CU0jn2LO.js} +4 -4
- package/build/server/chunks/{_server.ts-CcLqY7mC.js.map → _server.ts-CU0jn2LO.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DteVoyg4.js → _server.ts-CbLsJZuR.js} +4 -4
- package/build/server/chunks/{_server.ts-DteVoyg4.js.map → _server.ts-CbLsJZuR.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BC7_zqMR.js → _server.ts-CcH-dqDe.js} +4 -4
- package/build/server/chunks/{_server.ts-BC7_zqMR.js.map → _server.ts-CcH-dqDe.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DCg7u0gt.js → _server.ts-CgsiXNhO.js} +4 -4
- package/build/server/chunks/{_server.ts-DCg7u0gt.js.map → _server.ts-CgsiXNhO.js.map} +1 -1
- package/build/server/chunks/{_server.ts-cFNIAAvs.js → _server.ts-CnV-B9wI.js} +3 -3
- package/build/server/chunks/{_server.ts-cFNIAAvs.js.map → _server.ts-CnV-B9wI.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DYuZIg9l.js → _server.ts-CnYeFzrQ.js} +4 -4
- package/build/server/chunks/{_server.ts-DYuZIg9l.js.map → _server.ts-CnYeFzrQ.js.map} +1 -1
- package/build/server/chunks/{_server.ts-CRUfNiEL.js → _server.ts-CoJCMQ9O.js} +4 -4
- package/build/server/chunks/{_server.ts-CRUfNiEL.js.map → _server.ts-CoJCMQ9O.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BTwVVUpt.js → _server.ts-Cr894o8T.js} +4 -4
- package/build/server/chunks/{_server.ts-BTwVVUpt.js.map → _server.ts-Cr894o8T.js.map} +1 -1
- package/build/server/chunks/{_server.ts-SFkX7VFb.js → _server.ts-Csr--yoU.js} +6 -6
- package/build/server/chunks/{_server.ts-SFkX7VFb.js.map → _server.ts-Csr--yoU.js.map} +1 -1
- package/build/server/chunks/{_server.ts-swRf_u3E.js → _server.ts-CvNKkRf_.js} +5 -5
- package/build/server/chunks/{_server.ts-swRf_u3E.js.map → _server.ts-CvNKkRf_.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DDNv0MDu.js → _server.ts-Cz4rqGcO.js} +4 -4
- package/build/server/chunks/{_server.ts-DDNv0MDu.js.map → _server.ts-Cz4rqGcO.js.map} +1 -1
- package/build/server/chunks/{_server.ts-Bkz7Vyl7.js → _server.ts-D2tYhgkS.js} +5 -5
- package/build/server/chunks/{_server.ts-Bkz7Vyl7.js.map → _server.ts-D2tYhgkS.js.map} +1 -1
- package/build/server/chunks/{_server.ts-CKkuDSSM.js → _server.ts-D335o7vg.js} +4 -4
- package/build/server/chunks/{_server.ts-CKkuDSSM.js.map → _server.ts-D335o7vg.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DniIPBxO.js → _server.ts-D3eL8ghY.js} +2 -2
- package/build/server/chunks/{_server.ts-DniIPBxO.js.map → _server.ts-D3eL8ghY.js.map} +1 -1
- package/build/server/chunks/{_server.ts-C3UA92-P.js → _server.ts-D4GCS8S-.js} +4 -4
- package/build/server/chunks/{_server.ts-C3UA92-P.js.map → _server.ts-D4GCS8S-.js.map} +1 -1
- package/build/server/chunks/{_server.ts-D39hF3fC.js → _server.ts-D4ZJODQ1.js} +2 -2
- package/build/server/chunks/{_server.ts-D39hF3fC.js.map → _server.ts-D4ZJODQ1.js.map} +1 -1
- package/build/server/chunks/{_server.ts-B7ST2I1g.js → _server.ts-D60NzF0a.js} +2 -2
- package/build/server/chunks/{_server.ts-B7ST2I1g.js.map → _server.ts-D60NzF0a.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DS6wkfxg.js → _server.ts-D6J-vSqv.js} +4 -4
- package/build/server/chunks/{_server.ts-DS6wkfxg.js.map → _server.ts-D6J-vSqv.js.map} +1 -1
- package/build/server/chunks/{_server.ts-C_o9u8JZ.js → _server.ts-D7hNhjI7.js} +4 -4
- package/build/server/chunks/{_server.ts-C_o9u8JZ.js.map → _server.ts-D7hNhjI7.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DhXmrQhc.js → _server.ts-DMKACnON.js} +4 -4
- package/build/server/chunks/{_server.ts-DhXmrQhc.js.map → _server.ts-DMKACnON.js.map} +1 -1
- package/build/server/chunks/{_server.ts-C2jZDeoI.js → _server.ts-DOEG8mIs.js} +4 -4
- package/build/server/chunks/{_server.ts-C2jZDeoI.js.map → _server.ts-DOEG8mIs.js.map} +1 -1
- package/build/server/chunks/{_server.ts-67vw7faX.js → _server.ts-DQVANT_s.js} +4 -4
- package/build/server/chunks/{_server.ts-67vw7faX.js.map → _server.ts-DQVANT_s.js.map} +1 -1
- package/build/server/chunks/{_server.ts-Dbqne9eY.js → _server.ts-DSaRaRsv.js} +6 -6
- package/build/server/chunks/{_server.ts-Dbqne9eY.js.map → _server.ts-DSaRaRsv.js.map} +1 -1
- package/build/server/chunks/{_server.ts-CgkGvTF0.js → _server.ts-DceQDSDd.js} +5 -5
- package/build/server/chunks/{_server.ts-CgkGvTF0.js.map → _server.ts-DceQDSDd.js.map} +1 -1
- package/build/server/chunks/{_server.ts-D9xZdloN.js → _server.ts-DdhxzkWp.js} +2 -2
- package/build/server/chunks/{_server.ts-D9xZdloN.js.map → _server.ts-DdhxzkWp.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BJYAW2v_.js → _server.ts-DfhoSzqh.js} +4 -4
- package/build/server/chunks/{_server.ts-BJYAW2v_.js.map → _server.ts-DfhoSzqh.js.map} +1 -1
- package/build/server/chunks/{_server.ts-upBZRwnP.js → _server.ts-DgjEs7Bk.js} +5 -5
- package/build/server/chunks/{_server.ts-upBZRwnP.js.map → _server.ts-DgjEs7Bk.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BGBkyRka.js → _server.ts-DjSCtZBm.js} +4 -4
- package/build/server/chunks/{_server.ts-BGBkyRka.js.map → _server.ts-DjSCtZBm.js.map} +1 -1
- package/build/server/chunks/{_server.ts-Co5auLt6.js → _server.ts-Dkw3m0id.js} +4 -4
- package/build/server/chunks/{_server.ts-Co5auLt6.js.map → _server.ts-Dkw3m0id.js.map} +1 -1
- package/build/server/chunks/{_server.ts-MJxff6j1.js → _server.ts-DoIdll9B.js} +4 -4
- package/build/server/chunks/{_server.ts-MJxff6j1.js.map → _server.ts-DoIdll9B.js.map} +1 -1
- package/build/server/chunks/{_server.ts-Dw9IUnbc.js → _server.ts-Dxjt3AcD.js} +4 -4
- package/build/server/chunks/{_server.ts-Dw9IUnbc.js.map → _server.ts-Dxjt3AcD.js.map} +1 -1
- package/build/server/chunks/{_server.ts-KOGE5rzJ.js → _server.ts-IAz5Y8QW.js} +2 -2
- package/build/server/chunks/{_server.ts-KOGE5rzJ.js.map → _server.ts-IAz5Y8QW.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DguLVMDx.js → _server.ts-R-otxCJs.js} +5 -5
- package/build/server/chunks/{_server.ts-DguLVMDx.js.map → _server.ts-R-otxCJs.js.map} +1 -1
- package/build/server/chunks/{_server.ts-rP8pYqeQ.js → _server.ts-SJVbfTY-.js} +4 -4
- package/build/server/chunks/{_server.ts-rP8pYqeQ.js.map → _server.ts-SJVbfTY-.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DUa6bwDM.js → _server.ts-WxIT9W2N.js} +4 -4
- package/build/server/chunks/{_server.ts-DUa6bwDM.js.map → _server.ts-WxIT9W2N.js.map} +1 -1
- package/build/server/chunks/{_server.ts-Dw7_J4x-.js → _server.ts-dsQ0_ecn.js} +4 -4
- package/build/server/chunks/{_server.ts-Dw7_J4x-.js.map → _server.ts-dsQ0_ecn.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BLWYsGx3.js → _server.ts-hwnVsgqm.js} +4 -4
- package/build/server/chunks/{_server.ts-BLWYsGx3.js.map → _server.ts-hwnVsgqm.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DEB9v5s4.js → _server.ts-iPAMgkQE.js} +4 -4
- package/build/server/chunks/{_server.ts-DEB9v5s4.js.map → _server.ts-iPAMgkQE.js.map} +1 -1
- package/build/server/chunks/{_server.ts-Cw-3n_ep.js → _server.ts-wKuNNV0n.js} +4 -4
- package/build/server/chunks/{_server.ts-Cw-3n_ep.js.map → _server.ts-wKuNNV0n.js.map} +1 -1
- package/build/server/chunks/{_server.ts-D20tceEK.js → _server.ts-zFBp1NmR.js} +6 -6
- package/build/server/chunks/{_server.ts-D20tceEK.js.map → _server.ts-zFBp1NmR.js.map} +1 -1
- package/build/server/chunks/{addon-helpers-DU7K-Jl-.js → addon-helpers-CJtE_Dk0.js} +2 -2
- package/build/server/chunks/{addon-helpers-DU7K-Jl-.js.map → addon-helpers-CJtE_Dk0.js.map} +1 -1
- package/build/server/chunks/{client-DlIaBp3l.js → client-B0Os1NyZ.js} +2 -2
- package/build/server/chunks/{client-DlIaBp3l.js.map → client-B0Os1NyZ.js.map} +1 -1
- package/build/server/chunks/{config-DuMmS4Kk.js → config-DjPB0tcv.js} +2 -2
- package/build/server/chunks/{config-DuMmS4Kk.js.map → config-DjPB0tcv.js.map} +1 -1
- package/build/server/chunks/{docker-YA68OZn5.js → docker-D7xUhSN0.js} +2 -2
- package/build/server/chunks/{docker-YA68OZn5.js.map → docker-D7xUhSN0.js.map} +1 -1
- package/build/server/chunks/{endpoints-CGm4oVfk.js → endpoints-CRYjnmeW.js} +2 -2
- package/build/server/chunks/{endpoints-CGm4oVfk.js.map → endpoints-CRYjnmeW.js.map} +1 -1
- package/build/server/chunks/{environment-WrKoCzje.js → environment-vrt2A8E3.js} +2 -2
- package/build/server/chunks/{environment-WrKoCzje.js.map → environment-vrt2A8E3.js.map} +1 -1
- package/build/server/chunks/{error.svelte-D4IIBHJA.js → error.svelte-GrDfifPA.js} +4 -4
- package/build/server/chunks/{error.svelte-D4IIBHJA.js.map → error.svelte-GrDfifPA.js.map} +1 -1
- package/build/server/chunks/{helpers-h_Fq1SBb.js → helpers-C9xlDb4M.js} +3 -3
- package/build/server/chunks/{helpers-h_Fq1SBb.js.map → helpers-C9xlDb4M.js.map} +1 -1
- package/build/server/chunks/{hooks.server-SbPoC8s4.js → hooks.server-CWVrlPsn.js} +5 -5
- package/build/server/chunks/{hooks.server-SbPoC8s4.js.map → hooks.server-CWVrlPsn.js.map} +1 -1
- package/build/server/chunks/{http-DbpsBgUe.js → http-CKxMa9DL.js} +2 -2
- package/build/server/chunks/{http-DbpsBgUe.js.map → http-CKxMa9DL.js.map} +1 -1
- package/build/server/chunks/{internal-DtdC4O8s.js → internal-Dmwjn9fG.js} +3 -3
- package/build/server/chunks/{internal-DtdC4O8s.js.map → internal-Dmwjn9fG.js.map} +1 -1
- package/build/server/chunks/{session-cookie-C61HbJV5.js → session-cookie-Cp0GJgRc.js} +2 -2
- package/build/server/chunks/{session-cookie-C61HbJV5.js.map → session-cookie-Cp0GJgRc.js.map} +1 -1
- package/build/server/chunks/{setup-deploy-D0Om28m3.js → setup-deploy-BrOYMz2M.js} +4 -3
- package/build/server/chunks/setup-deploy-BrOYMz2M.js.map +1 -0
- package/build/server/chunks/{src-DJv-Q_k2.js → src-Bs1lSXiF.js} +191 -68
- package/build/server/chunks/src-Bs1lSXiF.js.map +1 -0
- package/build/server/chunks/{state-DGpfeO6d.js → state-Dh7rqC1X.js} +2 -2
- package/build/server/chunks/{state-DGpfeO6d.js.map → state-Dh7rqC1X.js.map} +1 -1
- package/build/server/index.js +2 -2
- package/build/server/manifest.js +82 -82
- package/build/server/manifest.js.map +1 -1
- package/package.json +2 -2
- package/build/client/_app/immutable/chunks/0swOyi-5.js +0 -3
- package/build/client/_app/immutable/chunks/0swOyi-5.js.br +0 -0
- package/build/client/_app/immutable/chunks/0swOyi-5.js.gz +0 -0
- package/build/client/_app/immutable/chunks/7Y-z2Cs4.js.br +0 -0
- package/build/client/_app/immutable/chunks/7Y-z2Cs4.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BBdT9Cjm.js.br +0 -0
- package/build/client/_app/immutable/chunks/BBdT9Cjm.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BQ0vnNWj.js.br +0 -1
- package/build/client/_app/immutable/chunks/BQ0vnNWj.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BbsmUDEz.js.br +0 -0
- package/build/client/_app/immutable/chunks/BbsmUDEz.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Bmfn2m9N.js +0 -1
- package/build/client/_app/immutable/chunks/Bmfn2m9N.js.br +0 -1
- package/build/client/_app/immutable/chunks/Bmfn2m9N.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BxIEEPV3.js.br +0 -0
- package/build/client/_app/immutable/chunks/BxIEEPV3.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DBtofX2R.js +0 -1
- package/build/client/_app/immutable/chunks/DBtofX2R.js.br +0 -2
- package/build/client/_app/immutable/chunks/DBtofX2R.js.gz +0 -0
- package/build/client/_app/immutable/chunks/jhtvkF_A.js.br +0 -0
- package/build/client/_app/immutable/chunks/jhtvkF_A.js.gz +0 -0
- package/build/client/_app/immutable/entry/app.DamaMvOo.js.br +0 -0
- package/build/client/_app/immutable/entry/app.DamaMvOo.js.gz +0 -0
- package/build/client/_app/immutable/entry/start.CiFTF0Id.js +0 -1
- package/build/client/_app/immutable/entry/start.CiFTF0Id.js.br +0 -0
- package/build/client/_app/immutable/entry/start.CiFTF0Id.js.gz +0 -0
- package/build/client/_app/immutable/nodes/0.0pi4RS6G.js.br +0 -0
- package/build/client/_app/immutable/nodes/0.0pi4RS6G.js.gz +0 -0
- package/build/client/_app/immutable/nodes/1.D_t9eVLg.js.br +0 -1
- package/build/client/_app/immutable/nodes/1.D_t9eVLg.js.gz +0 -0
- package/build/client/_app/immutable/nodes/2.B-8ehRO1.js +0 -1
- package/build/client/_app/immutable/nodes/2.B-8ehRO1.js.br +0 -0
- package/build/client/_app/immutable/nodes/2.B-8ehRO1.js.gz +0 -0
- package/build/client/_app/immutable/nodes/3.B_FXzjZB.js +0 -1
- package/build/client/_app/immutable/nodes/3.B_FXzjZB.js.br +0 -0
- package/build/client/_app/immutable/nodes/3.B_FXzjZB.js.gz +0 -0
- package/build/client/_app/immutable/nodes/4.rszAmyBN.js.br +0 -0
- package/build/client/_app/immutable/nodes/4.rszAmyBN.js.gz +0 -0
- package/build/client/_app/immutable/nodes/5.B5KOuICr.js.br +0 -0
- package/build/client/_app/immutable/nodes/5.B5KOuICr.js.gz +0 -0
- package/build/client/_app/immutable/nodes/6.Bw69iLts.js.br +0 -0
- package/build/client/_app/immutable/nodes/6.Bw69iLts.js.gz +0 -0
- package/build/client/_app/immutable/nodes/7.ockxnYPK.js.br +0 -0
- package/build/client/_app/immutable/nodes/7.ockxnYPK.js.gz +0 -0
- package/build/client/_app/immutable/nodes/8.Bt2Nswbt.js.br +0 -0
- package/build/client/_app/immutable/nodes/8.Bt2Nswbt.js.gz +0 -0
- package/build/client/_app/immutable/nodes/9.pk1c6xm-.js +0 -4
- package/build/client/_app/immutable/nodes/9.pk1c6xm-.js.br +0 -0
- package/build/client/_app/immutable/nodes/9.pk1c6xm-.js.gz +0 -0
- package/build/server/chunks/1-BTD70sT7.js +0 -9
- package/build/server/chunks/4-CubOOlWA.js +0 -9
- package/build/server/chunks/5-C5D5O8w1.js +0 -9
- package/build/server/chunks/6-DCNMSRHJ.js +0 -9
- package/build/server/chunks/7-jdfP4oIc.js +0 -9
- package/build/server/chunks/_page.svelte-B0M8mXzs.js.map +0 -1
- package/build/server/chunks/_server.ts-B4p_jHqU.js.map +0 -1
- package/build/server/chunks/_server.ts-CAycEHO4.js.map +0 -1
- package/build/server/chunks/_server.ts-kVbBWaDD.js.map +0 -1
- package/build/server/chunks/setup-deploy-D0Om28m3.js.map +0 -1
- package/build/server/chunks/src-DJv-Q_k2.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"_page.svelte-B0M8mXzs.js","sources":["../../../.svelte-kit/adapter-node/entries/pages/setup/_page.svelte.js"],"sourcesContent":["import { H as escape_html, V as attr, a as derived, n as attr_class, o as ensure_array_like, r as attr_style, s as head, u as stringify } from \"../../../chunks/dev.js\";\nimport \"../../../chunks/index-server.js\";\nimport { t as Spinner } from \"../../../chunks/Spinner.js\";\nimport { c as STEP_LABELS, d as FormField, i as KNOWN_EMB_DIMS, l as STT_OPTIONS, n as VoiceEngineSelector, o as PROVIDERS, r as CHANNELS, s as PROVIDER_GROUPS, t as VoiceProfileSelector, u as TTS_OPTIONS } from \"../../../chunks/VoiceProfileSelector.js\";\n//#region src/lib/wizard/error-messages.ts\nvar DOCKER_LINK = {\n\tlabel: \"Docker setup\",\n\thref: \"https://docs.docker.com/get-docker/\"\n};\nfunction rawText(raw) {\n\tif (!raw) return \"\";\n\tif (raw instanceof Error) return raw.message;\n\tif (typeof raw === \"string\") return raw;\n\ttry {\n\t\treturn JSON.stringify(raw);\n\t} catch {\n\t\treturn String(raw);\n\t}\n}\nfunction friendlyError(raw, context = \"generic\", opts = {}) {\n\tconst text = rawText(raw);\n\tconst lower = text.toLowerCase();\n\tconst providerLabel = opts.providerName ? `${opts.providerName} didn't accept that key` : \"API key rejected\";\n\tif (/\\b(401|403|unauthorized|forbidden|invalid.?api.?key)\\b/i.test(text)) return {\n\t\ttitle: providerLabel,\n\t\tbody: \"The provider rejected the API key.\",\n\t\thint: \"Common causes: extra spaces, wrong account, or the key was revoked. Double-check the key and that it has access to the model you selected. Most providers show the key in their dashboard.\",\n\t\traw: text\n\t};\n\tif (/\\b(ENOTFOUND|ECONNREFUSED|getaddrinfo|EAI_AGAIN|EHOSTUNREACH)\\b/i.test(text)) return {\n\t\ttitle: \"Couldn't reach the host\",\n\t\tbody: text,\n\t\thint: \"Confirm the URL is correct and the service is online. For local providers (Ollama, LM Studio) make sure the server is running on this machine.\",\n\t\traw: text\n\t};\n\tif (/(timeout|timed out|AbortError|ETIMEDOUT)/i.test(text)) return {\n\t\ttitle: \"Request timed out\",\n\t\tbody: \"The provider didn't respond in time.\",\n\t\thint: \"It may be slow or temporarily down. Try again in a moment.\",\n\t\traw: text\n\t};\n\tif (lower.includes(\"docker\") || lower.includes(\"compose\") || lower.includes(\"daemon\")) return {\n\t\ttitle: \"Docker isn't available\",\n\t\tbody: \"OpenPalm needs Docker (with Compose v2) installed and running.\",\n\t\thint: \"Start Docker Desktop (macOS/Windows) or the docker daemon (Linux), then retry.\",\n\t\tlinks: [DOCKER_LINK],\n\t\traw: text\n\t};\n\tif (/EADDRINUSE/i.test(text) || /port.*in.?use/i.test(lower)) return {\n\t\ttitle: \"A required port is already in use\",\n\t\tbody: text,\n\t\thint: \"Another program is using one of OpenPalm's default ports. Quit the conflicting app, or change OpenPalm's port from the Admin Dashboard after setup.\",\n\t\traw: text\n\t};\n\tif (/EACCES|EPERM|permission denied/i.test(text)) return {\n\t\ttitle: \"Permission denied\",\n\t\tbody: text,\n\t\thint: \"OpenPalm couldn't write to its data directory. Check that ~/.openpalm/ is writable by your user.\",\n\t\traw: text\n\t};\n\tswitch (context) {\n\t\tcase \"provider-verify\":\n\t\tcase \"model-fetch\": return {\n\t\t\ttitle: \"Couldn't connect to the provider\",\n\t\t\tbody: text || \"Verification failed.\",\n\t\t\thint: \"Check the API key and base URL, then click Verify again.\",\n\t\t\traw: text\n\t\t};\n\t\tcase \"setup-complete\": return {\n\t\t\ttitle: \"Setup couldn't finish\",\n\t\t\tbody: text || \"Writing configuration failed.\",\n\t\t\thint: \"Check the technical details below, then retry. If the issue persists, the admin dashboard logs may help.\",\n\t\t\traw: text\n\t\t};\n\t\tcase \"deploy\":\n\t\tcase \"deploy-poll\": return {\n\t\t\ttitle: \"Deployment ran into a problem\",\n\t\t\tbody: text || \"One or more services failed to start.\",\n\t\t\thint: \"Image pulls can take several minutes on first install. Retry to attempt again; check Docker logs if it keeps failing.\",\n\t\t\traw: text\n\t\t};\n\t\tcase \"system-check\": return {\n\t\t\ttitle: \"System check failed\",\n\t\t\tbody: text || \"A required dependency is missing.\",\n\t\t\thint: \"Resolve the failing check above, then click Retry.\",\n\t\t\traw: text\n\t\t};\n\t\tcase \"channel\": return {\n\t\t\ttitle: \"Channel credential issue\",\n\t\t\tbody: text || \"A required field is missing or invalid.\",\n\t\t\thint: \"Confirm the bot token and other required fields are correct.\",\n\t\t\traw: text\n\t\t};\n\t\tcase \"port-conflict\": return {\n\t\t\ttitle: \"A required port is already in use\",\n\t\t\tbody: text || \"Another process is using one of OpenPalm's ports.\",\n\t\t\thint: \"Another program is using one of OpenPalm's default ports. Quit the conflicting app, or change OpenPalm's port from the Admin Dashboard after setup.\",\n\t\t\traw: text\n\t\t};\n\t\tdefault: return {\n\t\t\ttitle: \"Something went wrong\",\n\t\t\tbody: text || \"An unexpected error occurred.\",\n\t\t\thint: \"Try again. If the problem persists, check the admin dashboard logs.\",\n\t\t\traw: text\n\t\t};\n\t}\n}\n//#endregion\n//#region src/routes/setup/ProgressBar.svelte\nfunction ProgressBar($$renderer, $$props) {\n\t$$renderer.component(($$renderer) => {\n\t\tlet { currentStep, maxVisitedStep, onnavigate, canNavigateTo } = $$props;\n\t\t$$renderer.push(`<nav class=\"prog-bar\" aria-label=\"Wizard steps\"><div class=\"prog-segments\"><!--[-->`);\n\t\tconst each_array = ensure_array_like(STEP_LABELS);\n\t\tfor (let i = 0, $$length = each_array.length; i < $$length; i++) {\n\t\t\teach_array[i];\n\t\t\t$$renderer.push(`<div${attr_class(`prog-seg ${i <= currentStep ? \"on\" : \"\"}`)}></div>`);\n\t\t}\n\t\t$$renderer.push(`<!--]--></div> <div class=\"prog-labels\"><!--[-->`);\n\t\tconst each_array_1 = ensure_array_like(STEP_LABELS);\n\t\tfor (let i = 0, $$length = each_array_1.length; i < $$length; i++) {\n\t\t\tlet label = each_array_1[i];\n\t\t\t$$renderer.push(`<span${attr_class(`prog-lbl ${i <= currentStep ? \"on\" : \"\"} ${i === currentStep ? \"active\" : \"\"}`)} role=\"button\"${attr(\"tabindex\", i <= maxVisitedStep && canNavigateTo(i) ? 0 : -1)}${attr(\"aria-current\", i === currentStep ? \"step\" : void 0)}${attr(\"aria-disabled\", i <= maxVisitedStep && canNavigateTo(i) ? void 0 : \"true\")}${attr(\"aria-label\", `Go to step ${stringify(label)}`)}><span class=\"prog-lbl-text\">${escape_html(label)}</span><span class=\"prog-lbl-num\" aria-hidden=\"true\">${escape_html(i + 1)}</span></span>`);\n\t\t}\n\t\t$$renderer.push(`<!--]--></div></nav>`);\n\t});\n}\n//#endregion\n//#region src/lib/components/common/FriendlyError.svelte\nfunction FriendlyError($$renderer, $$props) {\n\t$$renderer.component(($$renderer) => {\n\t\t/** Render compactly without the technical-details disclosure (inline forms). */\n\t\tlet { error, role = \"alert\", compact = false } = $$props;\n\t\tif (error) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"friendly-error svelte-iqsgzf\"${attr(\"role\", role)}><div class=\"friendly-error-header svelte-iqsgzf\"><svg aria-hidden=\"true\" width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M10.29 3.86 1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z\"></path><line x1=\"12\" y1=\"9\" x2=\"12\" y2=\"13\"></line><line x1=\"12\" y1=\"17\" x2=\"12.01\" y2=\"17\"></line></svg> <strong class=\"friendly-error-title svelte-iqsgzf\">${escape_html(error.title)}</strong></div> `);\n\t\t\tif (error.body) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t$$renderer.push(`<p class=\"friendly-error-body svelte-iqsgzf\">${escape_html(error.body)}</p>`);\n\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`<!--]--> `);\n\t\t\tif (error.hint) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t$$renderer.push(`<p class=\"friendly-error-hint svelte-iqsgzf\">${escape_html(error.hint)}</p>`);\n\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`<!--]--> `);\n\t\t\tif (error.links && error.links.length > 0) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t$$renderer.push(`<div class=\"friendly-error-links svelte-iqsgzf\"><!--[-->`);\n\t\t\t\tconst each_array = ensure_array_like(error.links);\n\t\t\t\tfor (let $$index = 0, $$length = each_array.length; $$index < $$length; $$index++) {\n\t\t\t\t\tlet link = each_array[$$index];\n\t\t\t\t\t$$renderer.push(`<a${attr(\"href\", link.href)} target=\"_blank\" rel=\"noopener noreferrer\" class=\"friendly-error-link svelte-iqsgzf\">${escape_html(link.label)} →</a>`);\n\t\t\t\t}\n\t\t\t\t$$renderer.push(`<!--]--></div>`);\n\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`<!--]--> `);\n\t\t\tif (!compact && error.raw && error.raw !== error.body) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t$$renderer.push(`<details class=\"friendly-error-details svelte-iqsgzf\"><summary class=\"svelte-iqsgzf\">Technical details</summary> <pre class=\"svelte-iqsgzf\">${escape_html(error.raw)}</pre></details>`);\n\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`<!--]--></div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]-->`);\n\t});\n}\n//#endregion\n//#region src/routes/setup/steps/SystemCheckStep.svelte\nfunction SystemCheckStep($$renderer, $$props) {\n\t$$renderer.component(($$renderer) => {\n\t\t/** True when re-running an existing install; suppresses misleading\n\t\t* port-conflict warnings that just reflect the running stack itself. */\n\t\tlet { onnext, onpass, ongpudetected, isRerun = false } = $$props;\n\t\tlet loading = true;\n\t\tlet result = null;\n\t\tconst portConflicts = derived(() => isRerun ? [] : []);\n\t\tconst blockingPortConflicts = derived(() => portConflicts().filter((p) => p.blocking));\n\t\tderived(() => blockingPortConflicts().length > 0);\n\t\tderived(() => false);\n\t\t$$renderer.push(`<h2>System Check</h2> <p class=\"step-description\">Let's make sure your machine has everything OpenPalm needs.</p> `);\n\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> <div class=\"syscheck-list svelte-1txhq2p\" aria-live=\"polite\"><div${attr_class(\"syscheck-row svelte-1txhq2p\", void 0, {\n\t\t\t\"syscheck-row--ok\": void 0,\n\t\t\t\"syscheck-row--fail\": result\n\t\t})}><div class=\"syscheck-icon svelte-1txhq2p\">`);\n\t\t$$renderer.push(\"<!--[0-->\");\n\t\tSpinner($$renderer, { size: 16 });\n\t\t$$renderer.push(`<!--]--></div> <div class=\"syscheck-body svelte-1txhq2p\"><div class=\"syscheck-title svelte-1txhq2p\">Docker is installed and running</div> `);\n\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--></div></div> <div${attr_class(\"syscheck-row svelte-1txhq2p\", void 0, {\n\t\t\t\"syscheck-row--ok\": void 0,\n\t\t\t\"syscheck-row--fail\": result\n\t\t})}><div class=\"syscheck-icon svelte-1txhq2p\">`);\n\t\t$$renderer.push(\"<!--[0-->\");\n\t\tSpinner($$renderer, { size: 16 });\n\t\t$$renderer.push(`<!--]--></div> <div class=\"syscheck-body svelte-1txhq2p\"><div class=\"syscheck-title svelte-1txhq2p\">Docker can run multi-container apps</div> `);\n\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--></div></div> `);\n\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> `);\n\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> `);\n\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--></div> <div class=\"step-actions\"><button class=\"btn btn-secondary\" id=\"btn-syscheck-retry\"${attr(\"disabled\", loading, true)}>${escape_html(\"Checking…\")}</button> <button class=\"btn btn-primary\" id=\"btn-syscheck-next\"${attr(\"disabled\", loading, true)}>Continue</button></div>`);\n\t});\n}\n//#endregion\n//#region src/routes/setup/steps/WelcomeStep.svelte\nfunction WelcomeStep($$renderer, $$props) {\n\t$$renderer.component(($$renderer) => {\n\t\tlet { errorMessage, detectionReady, autoModeImporting, recommendation, recommendationFetched, onnext, onusedefaults } = $$props;\n\t\tfunction summarizeProviders(names, verb, state) {\n\t\t\tconst n = names.length;\n\t\t\tif (n === 0) return `${verb} a ${state} provider`;\n\t\t\tif (n === 1) return `${verb} ${names[0]} ${state}`;\n\t\t\tif (n === 2) return `${verb} ${names[0]} and ${names[1]} ${state}`;\n\t\t\tif (n === 3) return `${verb} ${n} ${state} providers (${names[0]}, ${names[1]} +1 more)`;\n\t\t\treturn `${verb} ${n} ${state} providers (${names[0]}, ${names[1]} +${n - 2} more)`;\n\t\t}\n\t\tconst summary = derived(() => {\n\t\t\tconst rec = recommendation;\n\t\t\tif (!rec) return null;\n\t\t\tswitch (rec.action) {\n\t\t\t\tcase \"enable-ollama\": return {\n\t\t\t\t\theadline: `Detected ${rec.gpu.name} — recommended setup will run models locally with Ollama.`,\n\t\t\t\t\tdetail: \"No external account or API key needed.\"\n\t\t\t\t};\n\t\t\t\tcase \"use-host-providers\": {\n\t\t\t\t\tconst names = rec.hostProviders.map((p) => p.provider);\n\t\t\t\t\treturn {\n\t\t\t\t\t\theadline: `${summarizeProviders(names, \"Found\", \"running on your computer\")} — recommended setup will use ${names.length === 1 ? \"it\" : \"them\"}.`,\n\t\t\t\t\t\tdetail: \"You can pick which models to use on the next step.\"\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\tcase \"use-cloud\": {\n\t\t\t\t\tconst names = rec.cloudProviders;\n\t\t\t\t\treturn {\n\t\t\t\t\t\theadline: names.length ? `${summarizeProviders(names, \"Detected\", \"connected\")} — recommended setup will use ${names.length === 1 ? \"it\" : \"them\"}.` : \"Detected a connected provider — recommended setup will use it.\",\n\t\t\t\t\t\tdetail: \"You can pick which models to use on the next step.\"\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\tcase \"connect-manually\": return {\n\t\t\t\t\theadline: \"No AI provider or capable GPU detected.\",\n\t\t\t\t\tdetail: \"You'll connect a provider on the next step.\"\n\t\t\t\t};\n\t\t\t}\n\t\t});\n\t\tconst useDefaultsLabel = derived(() => recommendation?.action === \"connect-manually\" ? \"Connect a provider\" : \"Use recommended setup\");\n\t\t$$renderer.push(`<div class=\"welcome-hero\" id=\"welcome-hero\"><div class=\"welcome-icon\">👋</div> <h2>Welcome to OpenPalm</h2> <p class=\"welcome-subtitle\">Your self-hosted AI assistant. Pick your providers, choose models, and you're up and running.</p> `);\n\t\tif (!recommendationFetched && !recommendation) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"feedback feedback--info welcome-detection svelte-1d9o2de\" data-testid=\"recommendation-alert\">`);\n\t\t\tSpinner($$renderer, {});\n\t\t\t$$renderer.push(`<!----> <span>Checking your system…</span></div>`);\n\t\t} else if (summary()) {\n\t\t\t$$renderer.push(\"<!--[1-->\");\n\t\t\t$$renderer.push(`<div class=\"feedback feedback--info welcome-detection svelte-1d9o2de\" role=\"status\" data-testid=\"recommendation-alert\"><span class=\"welcome-detection-headline svelte-1d9o2de\">${escape_html(summary().headline)}</span> <span class=\"welcome-detection-detail svelte-1d9o2de\">${escape_html(summary().detail)}</span></div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> `);\n\t\tif (errorMessage) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"feedback feedback--error\" id=\"step0-error\" role=\"alert\"><span>${escape_html(errorMessage)}</span></div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> <div class=\"welcome-actions svelte-1d9o2de\"><button class=\"btn btn-primary btn-lg svelte-1d9o2de\" id=\"btn-use-defaults\"${attr(\"disabled\", !detectionReady || autoModeImporting, true)}>`);\n\t\tif (autoModeImporting) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\tSpinner($$renderer, {});\n\t\t\t$$renderer.push(`<!----> Importing providers…`);\n\t\t} else if (!detectionReady) {\n\t\t\t$$renderer.push(\"<!--[1-->\");\n\t\t\tSpinner($$renderer, {});\n\t\t\t$$renderer.push(`<!----> Detecting your system…`);\n\t\t} else {\n\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`${escape_html(useDefaultsLabel())}`);\n\t\t}\n\t\t$$renderer.push(`<!--]--></button> <button class=\"btn btn-secondary svelte-1d9o2de\" id=\"btn-step0-next\">Continue</button></div></div>`);\n\t});\n}\n//#endregion\n//#region src/routes/setup/steps/ProvidersStep.svelte\nfunction ProvidersStep($$renderer, $$props) {\n\t$$renderer.component(($$renderer) => {\n\t\tfunction friendlyProviderError(raw, providerName) {\n\t\t\tif (!raw) return \"Connection failed\";\n\t\t\tconst view = friendlyError(raw, \"provider-verify\", providerName ? { providerName } : {});\n\t\t\treturn view.hint ? `${view.title}. ${view.hint}` : view.title;\n\t\t}\n\t\t/** True while the parent is importing providers from host OpenCode — shows a loading view in place of the step */\n\t\t/** Number of providers detected on this host's OpenCode install (0 = none) */\n\t\t/** Called when user chooses Import and clicks Continue — parent calls import-host then advances */\n\t\t/** Optional warning to display (e.g. partial host import failures) */\n\t\t/** Whether the user has explicitly opted to install with no provider */\n\t\t/** Called when the \"install without provider\" checkbox flips */\n\t\t/**\n\t\t* Single source of truth (from the parent) for whether the user may leave\n\t\t* this step: a provider is verified OR they opted into an empty install.\n\t\t* Drives the Next button + the copy so the two never contradict.\n\t\t*/\n\t\tlet { hostImporting = false, opencodeAvailable, opencodeProviders, opencodeAuth, providerState, expandedProvider, detectedProviders, detecting, ocFilterQuery, verifiedCount, onback, onnext, ontogglefallback, ontoggleopencode, onverify, onapikey, onbaseurl, onollamamode, onoauthstart, onoauthcancel, onmarkready, ondeselect, onfilterchange, hostProviderCount = 0, onhostimport, hostStatusWarning = null, allowEmptyInstall = false, onallowemptyinstallchange, canProceed = false } = $$props;\n\t\tconst importMode = derived(() => hostProviderCount > 0 ? \"import\" : \"manual\");\n\t\tlet filteredOcProviders = derived(() => {\n\t\t\tconst query = ocFilterQuery.toLowerCase().trim();\n\t\t\tlet list = opencodeProviders;\n\t\t\tif (query) list = list.filter((p) => p.name.toLowerCase().includes(query) || p.id.toLowerCase().includes(query));\n\t\t\treturn [...list].sort((a, b) => {\n\t\t\t\tconst aConn = providerState[a.id]?.verified ? 1 : 0;\n\t\t\t\tconst bConn = providerState[b.id]?.verified ? 1 : 0;\n\t\t\t\tif (aConn !== bConn) return bConn - aConn;\n\t\t\t\treturn (a.name ?? a.id).localeCompare(b.name ?? b.id);\n\t\t\t});\n\t\t});\n\t\tconst RECOMMENDED_IDS = new Set([\n\t\t\t\"ollama\",\n\t\t\t\"huggingface\",\n\t\t\t\"openai\",\n\t\t\t\"google\",\n\t\t\t\"model-runner\",\n\t\t\t\"lmstudio\"\n\t\t]);\n\t\tlet ocRecommended = derived(() => filteredOcProviders().filter((p) => providerState[p.id]?.verified || RECOMMENDED_IDS.has(p.id)));\n\t\tlet ocRest = derived(() => filteredOcProviders().filter((p) => !providerState[p.id]?.verified && !RECOMMENDED_IDS.has(p.id)));\n\t\tlet ocDisplayList = derived(() => ocFilterQuery ? filteredOcProviders() : ocRecommended());\n\t\tlet ocRestCount = derived(() => ocFilterQuery ? 0 : ocRest().length);\n\t\tif (hostImporting) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"host-importing-state svelte-1iuc968\"><div class=\"loading-state\">`);\n\t\t\tSpinner($$renderer, {});\n\t\t\t$$renderer.push(`<!----> Importing providers from host OpenCode…</div></div>`);\n\t\t} else {\n\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`<h2>Where should your models run?</h2> <p class=\"step-description\">Select one or more providers. Click a card to configure it.</p> `);\n\t\t\tif (hostStatusWarning) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t$$renderer.push(`<div class=\"host-status-warning svelte-1iuc968\" role=\"alert\">⚠ ${escape_html(hostStatusWarning)}</div>`);\n\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`<!--]--> `);\n\t\t\tif (hostProviderCount > 0) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t$$renderer.push(`<div class=\"host-import-choice svelte-1iuc968\"><p class=\"host-import-desc svelte-1iuc968\">We found OpenCode on this host with <strong>${escape_html(hostProviderCount)}</strong> provider${escape_html(hostProviderCount !== 1 ? \"s\" : \"\")} configured.</p> <label class=\"host-radio svelte-1iuc968\"><input type=\"radio\" name=\"provider-source\" value=\"import\"${attr(\"checked\", importMode() === \"import\", true)} class=\"svelte-1iuc968\"/> <span><strong>Import from host OpenCode</strong> <em>(recommended)</em></span></label> <label class=\"host-radio svelte-1iuc968\"><input type=\"radio\" name=\"provider-source\" value=\"manual\"${attr(\"checked\", importMode() === \"manual\", true)} class=\"svelte-1iuc968\"/> <span>Configure providers manually</span></label></div>`);\n\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`<!--]--> `);\n\t\t\tif (!hostProviderCount || importMode() === \"manual\") {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\tif (detecting) {\n\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t$$renderer.push(`<div class=\"loading-state\" id=\"conn-detecting\">`);\n\t\t\t\t\tSpinner($$renderer, {});\n\t\t\t\t\t$$renderer.push(`<!----> Detecting local providers...</div>`);\n\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t$$renderer.push(`<!--]--> <div class=\"provider-grid\" id=\"provider-grid\">`);\n\t\t\t\tif (opencodeAvailable) {\n\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t$$renderer.push(`<div class=\"model-filter-row\" style=\"margin-bottom:12px\"><input type=\"text\" class=\"model-filter-input\" id=\"oc-provider-filter\"${attr(\"placeholder\", `Search ${stringify(opencodeProviders.length)} providers…`)}${attr(\"value\", ocFilterQuery)} autocomplete=\"off\"/></div> <!--[-->`);\n\t\t\t\t\tconst each_array = ensure_array_like(ocDisplayList());\n\t\t\t\t\tfor (let $$index_1 = 0, $$length = each_array.length; $$index_1 < $$length; $$index_1++) {\n\t\t\t\t\t\tlet ocp = each_array[$$index_1];\n\t\t\t\t\t\tconst st = providerState[ocp.id] ?? {\n\t\t\t\t\t\t\tselected: false,\n\t\t\t\t\t\t\tverified: false,\n\t\t\t\t\t\t\tverifying: false,\n\t\t\t\t\t\t\terror: false,\n\t\t\t\t\t\t\tapiKey: \"\",\n\t\t\t\t\t\t\tbaseUrl: \"\",\n\t\t\t\t\t\t\tmodels: [],\n\t\t\t\t\t\t\tollamaMode: null\n\t\t\t\t\t\t};\n\t\t\t\t\t\tconst modelCount = st.models && st.models.length > 0 ? st.models.length : Object.keys(ocp.models ?? {}).length;\n\t\t\t\t\t\tconst authMethods = opencodeAuth[ocp.id] ?? [];\n\t\t\t\t\t\tconst isExpanded = expandedProvider === ocp.id;\n\t\t\t\t\t\t$$renderer.push(`<div${attr_class(`pcard ${st.verified ? \"selected verified\" : isExpanded ? \"selected\" : \"\"} ${isExpanded ? \"wide\" : \"\"}`)}${attr(\"data-provider\", ocp.id)}><div class=\"pcard-header\" role=\"button\" tabindex=\"0\"><div class=\"pcard-info\"><div class=\"pcard-name\">${escape_html(ocp.name)} `);\n\t\t\t\t\t\tif (st.verified) {\n\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t$$renderer.push(`<span class=\"vs vs-ok\">✓</span>`);\n\t\t\t\t\t\t} else if (st.verifying) {\n\t\t\t\t\t\t\t$$renderer.push(\"<!--[1-->\");\n\t\t\t\t\t\t\t$$renderer.push(`<span class=\"vs vs-wait\">⟳</span>`);\n\t\t\t\t\t\t} else if (st.error) {\n\t\t\t\t\t\t\t$$renderer.push(\"<!--[2-->\");\n\t\t\t\t\t\t\t$$renderer.push(`<span class=\"vs vs-err\">✗</span>`);\n\t\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t$$renderer.push(`<!--]--></div> <div class=\"pcard-desc\">${escape_html(modelCount)} model${escape_html(modelCount !== 1 ? \"s\" : \"\")} `);\n\t\t\t\t\t\tif (authMethods.length > 0) {\n\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t$$renderer.push(`· ${escape_html(authMethods.length)} auth method${escape_html(authMethods.length !== 1 ? \"s\" : \"\")}`);\n\t\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t$$renderer.push(`<!--]--></div></div> <div class=\"pcard-check\" aria-hidden=\"true\">${escape_html(st.verified ? \"✓\" : \"\")}</div></div> `);\n\t\t\t\t\t\tif (isExpanded) {\n\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t$$renderer.push(`<div class=\"pcard-auth\">`);\n\t\t\t\t\t\t\tif (st.verified) {\n\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t\t$$renderer.push(`<div class=\"feedback feedback--success\"><span>Connected</span> <button class=\"auth-disconnect\" type=\"button\">Disconnect</button></div>`);\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t\t\tif (st.error) {\n\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t\t\t$$renderer.push(`<div class=\"feedback feedback--error\"><span>${escape_html(friendlyProviderError(st.errorMessage, ocp.name))}</span></div>`);\n\t\t\t\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t\t\t$$renderer.push(`<!--]--> `);\n\t\t\t\t\t\t\t\tif (authMethods.length > 0) {\n\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t\t\t$$renderer.push(`<!--[-->`);\n\t\t\t\t\t\t\t\t\tconst each_array_1 = ensure_array_like(authMethods);\n\t\t\t\t\t\t\t\t\tfor (let idx = 0, $$length = each_array_1.length; idx < $$length; idx++) {\n\t\t\t\t\t\t\t\t\t\tlet method = each_array_1[idx];\n\t\t\t\t\t\t\t\t\t\tif (method.type === \"api\") {\n\t\t\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t\t\t\t\t$$renderer.push(`<div class=\"auth-row\" style=\"margin-bottom:6px\"><input type=\"password\" placeholder=\"API key\"${attr(\"value\", st.apiKey ?? \"\")}/> <button class=\"auth-btn auth-btn-verify\"${attr(\"disabled\", st.verifying, true)}>${escape_html(st.verifying ? \"Connecting...\" : method.label)}</button></div>`);\n\t\t\t\t\t\t\t\t\t\t} else if (method.type === \"oauth\") {\n\t\t\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[1-->\");\n\t\t\t\t\t\t\t\t\t\t\t$$renderer.push(`<div class=\"auth-row\" style=\"margin-bottom:6px\"><button class=\"auth-btn auth-btn-detect\" style=\"width:100%\"${attr(\"disabled\", st.verifying, true)}>${escape_html(st.verifying ? \"Waiting...\" : method.label)}</button></div>`);\n\t\t\t\t\t\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t\t\t\t\t$$renderer.push(`<!--]-->`);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t$$renderer.push(`<!--]-->`);\n\t\t\t\t\t\t\t\t} else if ((ocp.env ?? []).length > 0) {\n\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[1-->\");\n\t\t\t\t\t\t\t\t\t$$renderer.push(`<div class=\"auth-row\"><input type=\"password\"${attr(\"placeholder\", (ocp.env ?? [])[0])}${attr(\"value\", st.apiKey ?? \"\")}/> <button class=\"auth-btn auth-btn-verify\"${attr(\"disabled\", st.verifying, true)}>${escape_html(st.verifying ? \"Connecting...\" : \"Connect\")}</button></div>`);\n\t\t\t\t\t\t\t\t} else if (ocp.id === \"openai-compatible\") {\n\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[2-->\");\n\t\t\t\t\t\t\t\t\t$$renderer.push(`<div class=\"auth-row\" style=\"margin-bottom:6px\"><input type=\"url\" placeholder=\"https://your-server.example/v1\"${attr(\"value\", st.baseUrl ?? \"\")}/></div> <div class=\"auth-row\" style=\"margin-bottom:6px\"><input type=\"password\" placeholder=\"API key (optional)\"${attr(\"value\", st.apiKey ?? \"\")}/></div> <div class=\"auth-row\"><button class=\"auth-btn auth-btn-verify\"${attr(\"disabled\", st.verifying, true)}>${escape_html(st.verifying ? \"Checking...\" : \"Connect\")}</button></div>`);\n\t\t\t\t\t\t\t\t} else if (ocp.localUrl) {\n\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[3-->\");\n\t\t\t\t\t\t\t\t\t$$renderer.push(`<div class=\"auth-row\"><input type=\"url\"${attr(\"placeholder\", ocp.localUrl)}${attr(\"value\", st.baseUrl || ocp.localUrl)}/> <button${attr_class(`auth-btn ${st.verified ? \"auth-btn-detected\" : \"auth-btn-detect\"}`)}${attr(\"disabled\", st.verifying, true)}>${escape_html(st.verifying ? \"Detecting...\" : st.verified ? \"Connected ✓\" : \"Detect\")}</button></div>`);\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t\t\t\t$$renderer.push(`<div style=\"padding:4px 0;color:var(--color-text-secondary);font-size:var(--text-xs)\">No authentication required</div> <button class=\"auth-btn auth-btn-detect\">Mark as ready</button>`);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t$$renderer.push(`<!--]--> `);\n\t\t\t\t\t\t\t\tif (st.oauthPolling) {\n\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t\t\t$$renderer.push(`<div style=\"text-align:center;padding:8px\">`);\n\t\t\t\t\t\t\t\t\tif (st.oauthUrl) {\n\t\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t\t\t\t$$renderer.push(`<p style=\"margin-bottom:6px\"><a${attr(\"href\", st.oauthUrl)} target=\"_blank\" rel=\"noopener\" style=\"color:var(--color-accent)\">Open authorization page →</a></p>`);\n\t\t\t\t\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t\t\t\t$$renderer.push(`<!--]--> `);\n\t\t\t\t\t\t\t\t\tif (st.oauthInstructions) {\n\t\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t\t\t\t$$renderer.push(`<p style=\"margin-bottom:6px;white-space:pre-wrap;font-size:var(--text-xs)\">${escape_html(st.oauthInstructions)}</p>`);\n\t\t\t\t\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t\t\t\t$$renderer.push(`<!--]--> <p>`);\n\t\t\t\t\t\t\t\t\tSpinner($$renderer, {});\n\t\t\t\t\t\t\t\t\t$$renderer.push(`<!----> Waiting for authorization...</p> <button class=\"auth-btn\" style=\"margin-top:6px\">Cancel</button></div>`);\n\t\t\t\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t\t\t$$renderer.push(`<!--]-->`);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t$$renderer.push(`<!--]--></div>`);\n\t\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t$$renderer.push(`<!--]--></div>`);\n\t\t\t\t\t}\n\t\t\t\t\t$$renderer.push(`<!--]--> `);\n\t\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t$$renderer.push(`<!--]--> `);\n\t\t\t\t\tif (ocRestCount() > 0 && !ocFilterQuery) {\n\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t$$renderer.push(`<button class=\"btn-show-all-providers svelte-1iuc968\" id=\"btn-show-all-providers\">${escape_html(`Show all providers (${ocRestCount()} more)`)}</button>`);\n\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t$$renderer.push(`<!--]--> `);\n\t\t\t\t\tif (filteredOcProviders().length === 0 && ocFilterQuery) {\n\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t$$renderer.push(`<div style=\"text-align:center;padding:24px;color:var(--color-text-secondary)\">No providers match \"${escape_html(ocFilterQuery)}\"</div>`);\n\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t$$renderer.push(`<!--]-->`);\n\t\t\t\t} else {\n\t\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t$$renderer.push(`<!--[-->`);\n\t\t\t\t\tconst each_array_4 = ensure_array_like(PROVIDER_GROUPS);\n\t\t\t\t\tfor (let $$index_5 = 0, $$length = each_array_4.length; $$index_5 < $$length; $$index_5++) {\n\t\t\t\t\t\tlet group = each_array_4[$$index_5];\n\t\t\t\t\t\tconst members = PROVIDERS.filter((p) => p.group === group.id).sort((a, b) => a.order - b.order);\n\t\t\t\t\t\tif (members.length > 0) {\n\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t$$renderer.push(`<div class=\"provider-group\"><div class=\"provider-group-header\"><h3 class=\"provider-group-label\">${escape_html(group.label)}</h3> <span class=\"provider-group-desc\">${escape_html(group.desc)}</span></div> <div class=\"provider-group-cards\"><!--[-->`);\n\t\t\t\t\t\t\tconst each_array_5 = ensure_array_like(members);\n\t\t\t\t\t\t\tfor (let $$index_4 = 0, $$length = each_array_5.length; $$index_4 < $$length; $$index_4++) {\n\t\t\t\t\t\t\t\tlet p = each_array_5[$$index_4];\n\t\t\t\t\t\t\t\tconst st = providerState[p.id] ?? {\n\t\t\t\t\t\t\t\t\tselected: false,\n\t\t\t\t\t\t\t\t\tverified: false,\n\t\t\t\t\t\t\t\t\tverifying: false,\n\t\t\t\t\t\t\t\t\terror: false,\n\t\t\t\t\t\t\t\t\tapiKey: \"\",\n\t\t\t\t\t\t\t\t\tbaseUrl: \"\",\n\t\t\t\t\t\t\t\t\tmodels: [],\n\t\t\t\t\t\t\t\t\tollamaMode: null\n\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\tconst isExpanded = expandedProvider === p.id && st.selected;\n\t\t\t\t\t\t\t\tconst badgeCls = p.kind === \"cloud\" ? \"badge-neutral\" : p.kind === \"local\" ? \"badge-success\" : \"badge-recommended\";\n\t\t\t\t\t\t\t\t$$renderer.push(`<div${attr_class(`pcard ${st.selected ? \"selected\" : \"\"} ${st.verified ? \"verified\" : \"\"} ${isExpanded ? \"wide\" : \"\"}`)}${attr(\"data-provider\", p.id)}><div class=\"pcard-header\" role=\"button\" tabindex=\"0\"${attr(\"data-toggle-provider\", p.id)}><div class=\"pcard-icon\">${escape_html(p.icon)}</div> <div class=\"pcard-info\"><div class=\"pcard-name\">${escape_html(p.name)} <span${attr_class(`badge ${badgeCls}`, \"svelte-1iuc968\")}>${escape_html(p.kind)}</span> `);\n\t\t\t\t\t\t\t\tif (st.verified) {\n\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t\t\t$$renderer.push(`<span class=\"vs vs-ok\">✓</span>`);\n\t\t\t\t\t\t\t\t} else if (st.verifying) {\n\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[1-->\");\n\t\t\t\t\t\t\t\t\t$$renderer.push(`<span class=\"vs vs-wait\">⟳</span>`);\n\t\t\t\t\t\t\t\t} else if (st.error) {\n\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[2-->\");\n\t\t\t\t\t\t\t\t\t$$renderer.push(`<span class=\"vs vs-err\">✗</span>`);\n\t\t\t\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t\t\t$$renderer.push(`<!--]--></div> <div class=\"pcard-desc\">${escape_html(p.desc)}</div></div> <div class=\"pcard-check\" aria-hidden=\"true\">${escape_html(st.selected ? \"✓\" : \"\")}</div></div> `);\n\t\t\t\t\t\t\t\tif (isExpanded) {\n\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t\t\t$$renderer.push(`<div class=\"pcard-auth\">`);\n\t\t\t\t\t\t\t\t\tif (p.id === \"ollama\") {\n\t\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t\t\t\tif (!st.ollamaMode) {\n\t\t\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t\t\t\t\t$$renderer.push(`<div class=\"ollama-mode-prompt\"><p>Is Ollama already running on this machine?</p> <div class=\"ollama-mode-buttons\"><button class=\"ollama-mode-btn ollama-mode-btn-detect\">Yes, detect it</button> <button class=\"ollama-mode-btn ollama-mode-btn-stack\">No, add to stack</button></div></div>`);\n\t\t\t\t\t\t\t\t\t\t} else if (st.ollamaMode === \"running\") {\n\t\t\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[1-->\");\n\t\t\t\t\t\t\t\t\t\t\t$$renderer.push(`<div class=\"auth-row\"><input type=\"url\"${attr(\"placeholder\", p.baseUrl)}${attr(\"value\", st.baseUrl || p.baseUrl)}/> <button${attr_class(`auth-btn ${st.verified ? \"auth-btn-detected\" : \"auth-btn-detect\"}`)}${attr(\"disabled\", st.verifying, true)}>${escape_html(st.verifying ? \"Detecting...\" : st.verified ? \"Connected ✓\" : \"Detect\")}</button></div>`);\n\t\t\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t\t\t\t\t\tif (st.verified) {\n\t\t\t\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t\t\t\t\t\t$$renderer.push(`<div class=\"feedback feedback--success\"><span>Ollama will be added to your Docker stack with default models.</span> <button class=\"auth-disconnect\" type=\"button\">Disconnect</button></div>`);\n\t\t\t\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t\t\t\t\t\t\t$$renderer.push(`<div class=\"ollama-mode-prompt\"><p>Ollama runs as a container in your stack with recommended models pre-configured.</p> <button class=\"auth-btn auth-btn-detect\" style=\"margin-top:4px\">Enable Ollama</button></div>`);\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t$$renderer.push(`<!--]-->`);\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t$$renderer.push(`<!--]-->`);\n\t\t\t\t\t\t\t\t\t} else if (p.needsUrl) {\n\t\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[1-->\");\n\t\t\t\t\t\t\t\t\t\t$$renderer.push(`<div class=\"auth-row\"><input type=\"url\" placeholder=\"https://your-server.example/v1\"${attr(\"value\", st.baseUrl || \"\")}/></div> `);\n\t\t\t\t\t\t\t\t\t\tif (p.optionalKey) {\n\t\t\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t\t\t\t\t$$renderer.push(`<div class=\"auth-row\" style=\"margin-top:6px\"><input type=\"password\"${attr(\"placeholder\", p.placeholder || \"API key (optional)\")}${attr(\"value\", st.apiKey)}/></div>`);\n\t\t\t\t\t\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t\t\t\t\t$$renderer.push(`<!--]--> <div class=\"auth-row\" style=\"margin-top:6px\"><button${attr_class(`auth-btn ${st.verified ? \"auth-btn-verified\" : \"auth-btn-verify\"}`)}${attr(\"disabled\", st.verifying, true)}>${escape_html(st.verifying ? \"Checking...\" : st.verified ? \"Connected ✓\" : \"Connect\")}</button></div>`);\n\t\t\t\t\t\t\t\t\t} else if (p.needsKey) {\n\t\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[2-->\");\n\t\t\t\t\t\t\t\t\t\t$$renderer.push(`<div class=\"auth-row\"><input type=\"password\"${attr(\"placeholder\", p.placeholder || \"API key\")}${attr(\"value\", st.apiKey)}/> <button${attr_class(`auth-btn ${st.verified ? \"auth-btn-verified\" : \"auth-btn-verify\"}`)}${attr(\"disabled\", st.verifying, true)}>${escape_html(st.verifying ? \"Checking...\" : st.verified ? \"Verified ✓\" : \"Verify\")}</button></div>`);\n\t\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t\t\t\t\t$$renderer.push(`<div class=\"auth-row\"><input type=\"url\"${attr(\"placeholder\", p.baseUrl || \"http://localhost:8080\")}${attr(\"value\", st.baseUrl || p.baseUrl || \"\")}/> <button${attr_class(`auth-btn ${st.verified ? \"auth-btn-detected\" : \"auth-btn-detect\"}`)}${attr(\"disabled\", st.verifying, true)}>${escape_html(st.verifying ? \"Detecting...\" : st.verified ? \"Connected ✓\" : \"Detect\")}</button></div>`);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t$$renderer.push(`<!--]--> `);\n\t\t\t\t\t\t\t\t\tif (st.verified && p.id !== \"ollama\") {\n\t\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t\t\t\t$$renderer.push(`<div class=\"feedback feedback--success\"><span>Credentials verified</span> <button class=\"auth-disconnect\" type=\"button\">Disconnect</button></div>`);\n\t\t\t\t\t\t\t\t\t} else if (st.error) {\n\t\t\t\t\t\t\t\t\t\t$$renderer.push(\"<!--[1-->\");\n\t\t\t\t\t\t\t\t\t\t$$renderer.push(`<div class=\"feedback feedback--error\"><span>${escape_html(friendlyProviderError(st.errorMessage, p.name) || \"Verification failed — check your \" + (p.needsKey ? \"credentials\" : \"endpoint\"))}</span></div>`);\n\t\t\t\t\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t\t\t\t$$renderer.push(`<!--]--></div>`);\n\t\t\t\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t\t\t$$renderer.push(`<!--]--></div>`);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t$$renderer.push(`<!--]--></div></div>`);\n\t\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t$$renderer.push(`<!--]-->`);\n\t\t\t\t\t}\n\t\t\t\t\t$$renderer.push(`<!--]-->`);\n\t\t\t\t}\n\t\t\t\t$$renderer.push(`<!--]--></div>`);\n\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`<!--]--> `);\n\t\t\tif (verifiedCount === 0 && (!hostProviderCount || importMode() === \"manual\")) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t$$renderer.push(`<label class=\"allow-empty-row svelte-1iuc968\"><input type=\"checkbox\" id=\"allow-empty-install\"${attr(\"checked\", allowEmptyInstall, true)} class=\"svelte-1iuc968\"/> <span>Install without an AI provider (assistant won't be able to chat until I add one from the dashboard)</span></label>`);\n\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`<!--]--> <div class=\"step-actions\" id=\"step1-actions\"><button class=\"btn btn-secondary\" id=\"btn-step1-back\">Back</button> `);\n\t\t\tif (importMode() === \"import\" && hostProviderCount > 0) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t$$renderer.push(`<span class=\"nav-info\">Import ${escape_html(hostProviderCount)} provider${escape_html(hostProviderCount !== 1 ? \"s\" : \"\")} from host</span> <button class=\"btn btn-primary\" id=\"btn-step1-next\">Continue</button>`);\n\t\t\t} else {\n\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t$$renderer.push(`<span class=\"nav-info\" id=\"provider-count-info\">`);\n\t\t\t\tif (verifiedCount > 0) {\n\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t$$renderer.push(`<b>${escape_html(verifiedCount)}</b> provider${escape_html(verifiedCount > 1 ? \"s\" : \"\")} ready`);\n\t\t\t\t} else if (allowEmptyInstall) {\n\t\t\t\t\t$$renderer.push(\"<!--[1-->\");\n\t\t\t\t\t$$renderer.push(`Installing without an AI provider`);\n\t\t\t\t} else {\n\t\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t$$renderer.push(`Connect a provider to continue`);\n\t\t\t\t}\n\t\t\t\t$$renderer.push(`<!--]--></span> <button class=\"btn btn-primary\" id=\"btn-step1-next\"${attr(\"disabled\", !canProceed, true)}>`);\n\t\t\t\tif (verifiedCount > 0) {\n\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t$$renderer.push(`Choose Models`);\n\t\t\t\t} else if (allowEmptyInstall) {\n\t\t\t\t\t$$renderer.push(\"<!--[1-->\");\n\t\t\t\t\t$$renderer.push(`Install without AI`);\n\t\t\t\t} else {\n\t\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t$$renderer.push(`Choose Models`);\n\t\t\t\t}\n\t\t\t\t$$renderer.push(`<!--]--></button>`);\n\t\t\t}\n\t\t\t$$renderer.push(`<!--]--></div>`);\n\t\t}\n\t\t$$renderer.push(`<!--]-->`);\n\t});\n}\n//#endregion\n//#region src/routes/setup/steps/ModelsStep.svelte\nfunction ModelsStep($$renderer, $$props) {\n\t$$renderer.component(($$renderer) => {\n\t\t/** True only when the user explicitly opted into a no-AI install. */\n\t\t/** Single source of truth: a verified provider + chat model, OR empty-install. */\n\t\tlet { verifiedProviders, providerState, modelSelection, allowEmptyInstall = false, canComplete = false, errorMessage, onback, onnext, onselect, onselectnone } = $$props;\n\t\tconst roles = [\n\t\t\t{\n\t\t\t\tid: \"llm\",\n\t\t\t\tlabel: \"Chat Model\",\n\t\t\t\ttag: \"required\",\n\t\t\t\tdesc: \"Conversations, reasoning, and code\"\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"embedding\",\n\t\t\t\tlabel: \"Memory Model\",\n\t\t\t\ttag: \"optional\",\n\t\t\t\tdesc: \"Helps the assistant remember past conversations. Optional.\"\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"small\",\n\t\t\t\tlabel: \"Small Model\",\n\t\t\t\ttag: \"optional\",\n\t\t\t\tdesc: \"Lightweight tasks like summarization\"\n\t\t\t}\n\t\t];\n\t\tlet filterQueries = {};\n\t\tlet collapsedRoles = /* @__PURE__ */ new Set();\n\t\tfunction getOptionsForRole(role) {\n\t\t\tconst options = [];\n\t\t\tfor (const p of verifiedProviders) {\n\t\t\t\tconst st = providerState[p.id];\n\t\t\t\tconst defaultModel = role.id === \"embedding\" ? p.embModel : p.llmModel;\n\t\t\t\tconst models = st.models.length > 0 ? st.models : [];\n\t\t\t\tif (defaultModel && models.includes(defaultModel)) options.push({\n\t\t\t\t\tid: defaultModel,\n\t\t\t\t\tconnId: p.id,\n\t\t\t\t\tproviderName: p.name,\n\t\t\t\t\tbaseUrl: st.baseUrl || p.baseUrl,\n\t\t\t\t\tisDefault: true,\n\t\t\t\t\tdims: role.id === \"embedding\" ? KNOWN_EMB_DIMS[defaultModel] ?? KNOWN_EMB_DIMS[defaultModel.replace(/:.*$/, \"\")] ?? p.embDims ?? 0 : 0\n\t\t\t\t});\n\t\t\t\tfor (const m of models) {\n\t\t\t\t\tif (m === defaultModel) continue;\n\t\t\t\t\tconst dims = role.id === \"embedding\" ? KNOWN_EMB_DIMS[m] ?? KNOWN_EMB_DIMS[m.replace(/:.*$/, \"\")] ?? 0 : 0;\n\t\t\t\t\toptions.push({\n\t\t\t\t\t\tid: m,\n\t\t\t\t\t\tconnId: p.id,\n\t\t\t\t\t\tproviderName: p.name,\n\t\t\t\t\t\tbaseUrl: st.baseUrl || p.baseUrl,\n\t\t\t\t\t\tisDefault: false,\n\t\t\t\t\t\tdims\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (role.id === \"embedding\") return options.filter((o) => o.isDefault || o.dims > 0);\n\t\t\tif (role.id === \"small\" && options.length === 0) {\n\t\t\t\tconst llmProvider = verifiedProviders[0];\n\t\t\t\tif (llmProvider) for (const m of providerState[llmProvider.id].models) options.push({\n\t\t\t\t\tid: m,\n\t\t\t\t\tconnId: llmProvider.id,\n\t\t\t\t\tproviderName: llmProvider.name,\n\t\t\t\t\tbaseUrl: providerState[llmProvider.id].baseUrl || llmProvider.baseUrl,\n\t\t\t\t\tisDefault: false,\n\t\t\t\t\tdims: 0\n\t\t\t\t});\n\t\t\t}\n\t\t\treturn options;\n\t\t}\n\t\tfunction filteredOptions(role, options) {\n\t\t\tconst query = (filterQueries[role.id] ?? \"\").toLowerCase().trim();\n\t\t\tif (!query) return options;\n\t\t\treturn options.filter((o) => o.id.toLowerCase().includes(query) || o.providerName.toLowerCase().includes(query));\n\t\t}\n\t\t$$renderer.push(`<h2>Choose Your Models</h2> <p class=\"step-description\">Pre-selected from your providers. Adjust if needed.</p> `);\n\t\tif (verifiedProviders.length === 0) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\tif (allowEmptyInstall) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t$$renderer.push(`<div class=\"feedback feedback--warning\" style=\"margin-bottom:16px\" role=\"status\"><span>Installing without an AI provider — the assistant won't be able to chat until you add one from the dashboard. No model selection is needed.</span></div>`);\n\t\t\t} else {\n\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t$$renderer.push(`<div class=\"feedback feedback--error\" style=\"margin-bottom:16px\" role=\"alert\"><span>Connect a provider on the previous step to choose a chat model.</span></div>`);\n\t\t\t}\n\t\t\t$$renderer.push(`<!--]-->`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> <div id=\"model-groups\"><!--[-->`);\n\t\tconst each_array = ensure_array_like(roles);\n\t\tfor (let $$index_1 = 0, $$length = each_array.length; $$index_1 < $$length; $$index_1++) {\n\t\t\tlet role = each_array[$$index_1];\n\t\t\tconst options = getOptionsForRole(role);\n\t\t\tconst isEmptyEmbedding = role.id === \"embedding\" && options.length === 0;\n\t\t\tif (options.length > 0 || role.id === \"small\" || isEmptyEmbedding) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\tconst hasOverflow = options.length > 6;\n\t\t\t\tconst query = filterQueries[role.id] ?? \"\";\n\t\t\t\tconst visible = filteredOptions(role, options);\n\t\t\t\t$$renderer.push(`<div class=\"model-group\"><div class=\"model-group-header\" role=\"button\" tabindex=\"0\" style=\"cursor:pointer;user-select:none\"><span class=\"model-group-title\">${escape_html(role.label)}</span> <span${attr_class(`model-group-tag ${role.tag === \"required\" ? \"model-group-tag-required\" : \"model-group-tag-optional\"}`)}>${escape_html(role.tag)}</span> `);\n\t\t\t\tif (collapsedRoles.has(role.id)) {\n\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\tconst sel = modelSelection[role.id];\n\t\t\t\t\t$$renderer.push(`<span style=\"flex:1;font-size:var(--text-xs);color:var(--color-text-secondary);margin-left:8px\">${escape_html(isEmptyEmbedding && !sel?.model ? \"Automatic\" : sel?.model ?? \"(none)\")}</span> <span style=\"font-size:var(--text-xs);color:var(--color-text-secondary)\">▶</span>`);\n\t\t\t\t} else {\n\t\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t$$renderer.push(`<span style=\"margin-left:auto;font-size:var(--text-xs);color:var(--color-text-secondary)\">▼</span>`);\n\t\t\t\t}\n\t\t\t\t$$renderer.push(`<!--]--></div> `);\n\t\t\t\tif (!collapsedRoles.has(role.id)) {\n\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t$$renderer.push(`<div class=\"model-group-desc\">${escape_html(role.desc)}</div> `);\n\t\t\t\t\tif (isEmptyEmbedding) {\n\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t$$renderer.push(`<div class=\"model-auto-note\">Handled automatically — uses built-in local embeddings. No model needed.</div>`);\n\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t$$renderer.push(`<!--]--> `);\n\t\t\t\t\tif (role.id === \"small\") {\n\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\tconst noneOn = !modelSelection.small?.model;\n\t\t\t\t\t\t$$renderer.push(`<div${attr_class(`model-opt ${noneOn ? \"on\" : \"\"}`)} role=\"button\" tabindex=\"0\"><div class=\"model-opt-dot\"><div class=\"model-opt-dot-inner\"></div></div> <div style=\"flex:1\"><div class=\"model-opt-name\">(same as chat model)</div> <div class=\"model-opt-meta\">No separate small model</div></div> <span class=\"model-opt-badge model-opt-badge-auto\">Default</span></div>`);\n\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t$$renderer.push(`<!--]--> `);\n\t\t\t\t\tif (options.length > 3) {\n\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t$$renderer.push(`<div class=\"model-filter-row\"><input type=\"text\" class=\"model-filter-input\"${attr(\"placeholder\", `Search ${stringify(options.length)} models…`)}${attr(\"value\", query)} autocomplete=\"off\"/></div>`);\n\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t$$renderer.push(`<!--]--> <!--[-->`);\n\t\t\t\t\tconst each_array_1 = ensure_array_like(query ? visible : options);\n\t\t\t\t\tfor (let idx = 0, $$length = each_array_1.length; idx < $$length; idx++) {\n\t\t\t\t\t\tlet opt = each_array_1[idx];\n\t\t\t\t\t\tconst firstDefaultIdx = options.findIndex((o) => o.isDefault);\n\t\t\t\t\t\tconst sel = modelSelection[role.id];\n\t\t\t\t\t\tconst isOn = !!sel && sel.model === opt.id && sel.connId === opt.connId;\n\t\t\t\t\t\tconst isHidden = !query && hasOverflow && idx >= 6 && !isOn;\n\t\t\t\t\t\tconst meta = \"via \" + opt.providerName + (opt.dims > 0 ? \" · \" + opt.dims + \"d\" : \"\");\n\t\t\t\t\t\t$$renderer.push(`<div${attr_class(`model-opt ${isOn ? \"on\" : \"\"} ${isHidden ? \"model-opt-filtered\" : \"\"}`)} role=\"button\" tabindex=\"0\"${attr(\"data-model-select\", `${stringify(role.id)}:${stringify(opt.connId)}:${stringify(opt.id)}:${stringify(opt.dims)}`)}${attr(\"data-model-name\", opt.id.toLowerCase())}><div class=\"model-opt-dot\"><div class=\"model-opt-dot-inner\"></div></div> <div style=\"flex:1;min-width:0\"><div class=\"model-opt-name\">${escape_html(opt.id)}</div> <div class=\"model-opt-meta\">${escape_html(meta)}</div></div> `);\n\t\t\t\t\t\tif (idx === firstDefaultIdx && opt.isDefault) {\n\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t$$renderer.push(`<span class=\"model-opt-badge model-opt-badge-top\">Top Pick</span>`);\n\t\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t$$renderer.push(`<!--]--></div>`);\n\t\t\t\t\t}\n\t\t\t\t\t$$renderer.push(`<!--]-->`);\n\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t$$renderer.push(`<!--]--></div>`);\n\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`<!--]-->`);\n\t\t}\n\t\t$$renderer.push(`<!--]--></div> <input type=\"hidden\" id=\"llm-connection\"${attr(\"value\", modelSelection.llm?.connId ?? \"\")}/> <input type=\"hidden\" id=\"llm-model\"${attr(\"value\", modelSelection.llm?.model ?? \"\")}/> <input type=\"hidden\" id=\"llm-small-model\"${attr(\"value\", modelSelection.small?.model ?? \"\")}/> <input type=\"hidden\" id=\"emb-connection\"${attr(\"value\", modelSelection.embedding?.connId ?? \"\")}/> <input type=\"hidden\" id=\"emb-model\"${attr(\"value\", modelSelection.embedding?.model ?? \"\")}/> <input type=\"hidden\" id=\"emb-dims\"${attr(\"value\", String(modelSelection.embedding?.dims ?? 1536))}/> `);\n\t\tif (errorMessage) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"feedback feedback--error\" id=\"step2-error\" role=\"alert\"><span>${escape_html(errorMessage)}</span></div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> <div class=\"step-actions\"><button class=\"btn btn-secondary\" id=\"btn-step2-back\">Back</button> <button class=\"btn btn-primary\" id=\"btn-step2-next\"${attr(\"disabled\", !canComplete, true)}>`);\n\t\tif (verifiedProviders.length === 0 && allowEmptyInstall) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`Skip for now`);\n\t\t} else {\n\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`Voice Setup`);\n\t\t}\n\t\t$$renderer.push(`<!--]--></button></div>`);\n\t});\n}\n//#endregion\n//#region src/routes/setup/steps/VoiceStep.svelte\nfunction VoiceStep($$renderer, $$props) {\n\t$$renderer.component(($$renderer) => {\n\t\tlet { tts, stt, hasOpenAI, unknownTts = false, unknownStt = false, profiles = [], selectedVoiceProfile = \"\", onback, onnext, onchangetts, onchangestt, onprofilechange } = $$props;\n\t\tlet configureOpen = false;\n\t\tconst ttsLabel = derived(() => TTS_OPTIONS.find((o) => o.id === tts.engine)?.name ?? \"Browser Built-in\");\n\t\tconst sttLabel = derived(() => STT_OPTIONS.find((o) => o.id === stt.engine)?.name ?? \"Browser Built-in\");\n\t\tconst usesBundledVoice = derived(() => tts.engine === \"openpalm-voice\" || stt.engine === \"openpalm-voice\");\n\t\tconst selectedProfileLabel = derived(() => {\n\t\t\tif (!selectedVoiceProfile) return \"\";\n\t\t\tconst profile = profiles.find((p) => p.id === selectedVoiceProfile);\n\t\t\treturn profile?.label ?? profile?.id ?? selectedVoiceProfile;\n\t\t});\n\t\t$$renderer.push(`<h2>Voice Capabilities</h2> <p class=\"step-description\">Browser voice is ready out of the box — no setup needed.</p> `);\n\t\tif (unknownTts || unknownStt) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"voice-unknown svelte-jxtfqg\" role=\"alert\">Your previous voice settings couldn't be loaded. Please pick an engine.</div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> `);\n\t\tif (usesBundledVoice()) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"voice-download-notice svelte-jxtfqg\" role=\"note\"><strong class=\"svelte-jxtfqg\">First install will download the OpenPalm Voice image.</strong> <ul class=\"svelte-jxtfqg\"><li>CPU build: ~2.4 GB (5–15 min on a typical home connection)</li> <li>CUDA build: ~7.6 GB (15–45 min — chosen later from the admin tab)</li></ul> The wizard's final Install step will show a progress indicator and\n wait for the download to finish before completing.</div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> <div id=\"voice-summary\" class=\"voice-summary svelte-jxtfqg\"><div class=\"voice-summary-row svelte-jxtfqg\"><span class=\"voice-summary-label svelte-jxtfqg\">Text-to-Speech</span> <span class=\"voice-summary-value svelte-jxtfqg\">${escape_html(ttsLabel())}</span></div> <div class=\"voice-summary-row svelte-jxtfqg\"><span class=\"voice-summary-label svelte-jxtfqg\">Speech-to-Text</span> <span class=\"voice-summary-value svelte-jxtfqg\">${escape_html(sttLabel())}</span></div> `);\n\t\tif (usesBundledVoice() && selectedProfileLabel()) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"voice-summary-row svelte-jxtfqg\"><span class=\"voice-summary-label svelte-jxtfqg\">Voice Container</span> <span class=\"voice-summary-value svelte-jxtfqg\">${escape_html(selectedProfileLabel())}</span></div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--></div> `);\n\t\tif (usesBundledVoice()) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"voice-profile-inline svelte-jxtfqg\"><div class=\"voice-profile-inline-title svelte-jxtfqg\">Voice container profile</div> `);\n\t\t\tif (profiles.length > 0 && onprofilechange) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\tVoiceProfileSelector($$renderer, {\n\t\t\t\t\tprofiles,\n\t\t\t\t\tselectedProfile: selectedVoiceProfile,\n\t\t\t\t\tonchange: onprofilechange,\n\t\t\t\t\tshowDescription: false\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t$$renderer.push(`<p class=\"voice-profile-inline-loading svelte-jxtfqg\">Checking available hardware profiles…</p>`);\n\t\t\t}\n\t\t\t$$renderer.push(`<!--]--></div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> <details${attr(\"open\", configureOpen, true)} id=\"voice-configure-details\" class=\"svelte-jxtfqg\"><summary class=\"voice-configure-summary svelte-jxtfqg\" id=\"voice-configure-toggle\">Configure voice…</summary> <div id=\"voice-groups\" style=\"margin-top:12px\">`);\n\t\tif (hasOpenAI) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<p class=\"voice-hint svelte-jxtfqg\">OpenAI is available. You can use OpenAI TTS/STT or keep browser voice.</p>`);\n\t\t} else {\n\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`<p class=\"voice-hint svelte-jxtfqg\">Kokoro and Whisper give higher quality. Browser voice works without extra setup.</p>`);\n\t\t}\n\t\t$$renderer.push(`<!--]--> <div class=\"model-group\"><div class=\"model-group-header\"><span class=\"model-group-title\">Text-to-Speech</span> <span class=\"model-group-tag model-group-tag-optional\">Optional</span></div> <div class=\"model-group-desc\">How your assistant speaks</div> `);\n\t\tVoiceEngineSelector($$renderer, {\n\t\t\tkind: \"tts\",\n\t\t\tvalue: tts,\n\t\t\tonchange: onchangetts\n\t\t});\n\t\t$$renderer.push(`<!----></div> <div class=\"model-group\"><div class=\"model-group-header\"><span class=\"model-group-title\">Speech-to-Text</span> <span class=\"model-group-tag model-group-tag-optional\">Optional</span></div> <div class=\"model-group-desc\">How your assistant hears you</div> `);\n\t\tVoiceEngineSelector($$renderer, {\n\t\t\tkind: \"stt\",\n\t\t\tvalue: stt,\n\t\t\tonchange: onchangestt\n\t\t});\n\t\t$$renderer.push(`<!----></div></div></details> <div class=\"step-actions\"><button class=\"btn btn-secondary\" id=\"btn-step3-back\">Back</button> <button class=\"btn btn-primary\" id=\"btn-step3-next\">Continue</button></div>`);\n\t});\n}\n//#endregion\n//#region src/lib/wizard/helpers.ts\nfunction isChannelEnabled(channelSelection, chId, locked) {\n\tif (locked) return true;\n\tconst sel = channelSelection[chId];\n\tif (typeof sel === \"object\" && sel !== null) return sel.enabled;\n\treturn !!sel;\n}\nfunction getCredValue(channelSelection, chId, key) {\n\tconst sel = channelSelection[chId];\n\tif (typeof sel === \"object\" && sel !== null) return String(sel[key] ?? \"\");\n\treturn \"\";\n}\n//#endregion\n//#region src/routes/setup/steps/OptionsStep.svelte\nfunction OptionsStep($$renderer, $$props) {\n\t$$renderer.component(($$renderer) => {\n\t\t/** True when Ollama/LM Studio is already running on the host — the in-stack\n\t\t* Ollama addon is redundant, so its toggle is disabled with a note. */\n\t\tlet { channelSelection, imageTag, hostAkmEnabled, hostAkmAvailable, enableVoice, voiceProfiles, selectedVoiceProfile, ollamaEnabled, ollamaProfiles, selectedOllamaProfile, hostLocalRunning = false, errorMessage, onback, onnext, onchanneltoggle, oncredentialchange, onimagtagchange, onhostakmchange, onenablevoicechange, onvoiceprofilechange, onollamachange, onollamaprofilechange } = $$props;\n\t\tfunction isChannelEnabled$2(chId, locked) {\n\t\t\treturn isChannelEnabled(channelSelection, chId, locked);\n\t\t}\n\t\tfunction getCredValue$2(chId, key) {\n\t\t\treturn getCredValue(channelSelection, chId, key);\n\t\t}\n\t\t$$renderer.push(`<h2>Options</h2> <p class=\"step-description\">Configure channels and deployment options.</p> <div class=\"options-section\"><h3 class=\"options-section-title\">Channels</h3> <p class=\"options-section-desc\">Additional ways to reach your assistant.</p> <div class=\"toggle-grid\" id=\"channels-grid\"><!--[-->`);\n\t\tconst each_array = ensure_array_like(CHANNELS);\n\t\tfor (let $$index_1 = 0, $$length = each_array.length; $$index_1 < $$length; $$index_1++) {\n\t\t\tlet ch = each_array[$$index_1];\n\t\t\tconst isOn = isChannelEnabled$2(ch.id, ch.locked);\n\t\t\t$$renderer.push(`<div${attr_class(`toggle-card ${isOn ? \"on\" : \"\"} ${ch.locked ? \"locked\" : \"\"} ${ch.credentials && isOn ? \"wide\" : \"\"}`)}${attr(\"data-channel\", ch.id)}><div class=\"toggle-card-header\" role=\"button\"${attr(\"tabindex\", ch.locked ? -1 : 0)}><div class=\"toggle-card-icon\">${escape_html(ch.icon)}</div> <div class=\"toggle-card-info\"><div class=\"toggle-card-name\">${escape_html(ch.name)} `);\n\t\t\tif (ch.locked) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t$$renderer.push(`<span class=\"badge badge-success\">Always on</span>`);\n\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`<!--]--></div> <div class=\"toggle-card-desc\">${escape_html(ch.desc)}</div></div> <div class=\"toggle-card-switch\">`);\n\t\t\tif (ch.locked) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t$$renderer.push(`<div class=\"toggle-track on locked\"><div class=\"toggle-thumb\"></div></div>`);\n\t\t\t} else {\n\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t$$renderer.push(`<div${attr_class(`toggle-track ${isOn ? \"on\" : \"\"}`)}><div class=\"toggle-thumb\"></div></div>`);\n\t\t\t}\n\t\t\t$$renderer.push(`<!--]--></div></div> `);\n\t\t\tif (ch.credentials && isOn) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t$$renderer.push(`<div class=\"pcard-auth\"><!--[-->`);\n\t\t\t\tconst each_array_1 = ensure_array_like(ch.credentials);\n\t\t\t\tfor (let $$index = 0, $$length = each_array_1.length; $$index < $$length; $$index++) {\n\t\t\t\t\tlet cred = each_array_1[$$index];\n\t\t\t\t\tconst inputType = cred.secret === false ? \"text\" : \"password\";\n\t\t\t\t\t$$renderer.push(`<div class=\"auth-row\"><label class=\"channel-cred-label\"${attr(\"for\", `cred-${stringify(ch.id)}-${stringify(cred.key)}`)}>${escape_html(cred.label)} `);\n\t\t\t\t\tif (cred.required) {\n\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t$$renderer.push(`<span class=\"channel-cred-required\">*</span>`);\n\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t$$renderer.push(`<!--]--></label> <input${attr(\"id\", `cred-${stringify(ch.id)}-${stringify(cred.key)}`)}${attr(\"type\", inputType)}${attr(\"placeholder\", cred.placeholder ?? \"\")}${attr(\"value\", getCredValue$2(ch.id, cred.key))}/></div>`);\n\t\t\t\t}\n\t\t\t\t$$renderer.push(`<!--]--></div>`);\n\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`<!--]--></div>`);\n\t\t}\n\t\t$$renderer.push(`<!--]--></div></div> <div class=\"options-section\"><h3 class=\"options-section-title\">Add-ons</h3> <p class=\"options-section-desc\">Optional features to extend your assistant.</p> <div class=\"toggle-grid\" id=\"addons-grid\"><div${attr_class(`toggle-card ${enableVoice ? \"on\" : \"\"} ${enableVoice && voiceProfiles.length > 0 ? \"wide\" : \"\"}`)}><div class=\"toggle-card-header\" role=\"button\" tabindex=\"0\"><div class=\"toggle-card-icon\">🎙️</div> <div class=\"toggle-card-info\"><div class=\"toggle-card-name\">Voice</div> <div class=\"toggle-card-desc\">Bundled text-to-speech and speech-to-text. Requires a one-time local model download.</div></div> <div class=\"toggle-card-switch\"><div${attr_class(`toggle-track ${enableVoice ? \"on\" : \"\"}`)}><div class=\"toggle-thumb\"></div></div></div></div> `);\n\t\tif (enableVoice && voiceProfiles.length > 0) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"pcard-auth\">`);\n\t\t\tVoiceProfileSelector($$renderer, {\n\t\t\t\tprofiles: voiceProfiles,\n\t\t\t\tselectedProfile: selectedVoiceProfile,\n\t\t\t\tonchange: onvoiceprofilechange,\n\t\t\t\tshowDescription: false\n\t\t\t});\n\t\t\t$$renderer.push(`<!----></div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--></div> <div${attr_class(`toggle-card ${ollamaEnabled && !hostLocalRunning ? \"on\" : \"\"} ${hostLocalRunning ? \"addon-disabled\" : \"\"} ${ollamaEnabled && !hostLocalRunning && ollamaProfiles.length > 0 ? \"wide\" : \"\"}`, \"svelte-1q1mmx4\")}><div class=\"toggle-card-header svelte-1q1mmx4\" role=\"button\"${attr(\"tabindex\", hostLocalRunning ? -1 : 0)}${attr(\"aria-disabled\", hostLocalRunning ? \"true\" : void 0)}><div class=\"toggle-card-icon\">🦙</div> <div class=\"toggle-card-info\"><div class=\"toggle-card-name\">Ollama</div> <div class=\"toggle-card-desc\">`);\n\t\tif (hostLocalRunning) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`Ollama or LM Studio is already running on your computer — the bundled Ollama isn't needed.`);\n\t\t} else {\n\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`Run local AI models inside the stack. Downloads and serves models via Docker.`);\n\t\t}\n\t\t$$renderer.push(`<!--]--></div></div> <div class=\"toggle-card-switch\"><div${attr_class(`toggle-track ${ollamaEnabled && !hostLocalRunning ? \"on\" : \"\"}`)}><div class=\"toggle-thumb\"></div></div></div></div> `);\n\t\tif (ollamaEnabled && !hostLocalRunning && ollamaProfiles.length > 0) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"pcard-auth\">`);\n\t\t\tVoiceProfileSelector($$renderer, {\n\t\t\t\tprofiles: ollamaProfiles,\n\t\t\t\tselectedProfile: selectedOllamaProfile,\n\t\t\t\tonchange: onollamaprofilechange,\n\t\t\t\tshowDescription: false\n\t\t\t});\n\t\t\t$$renderer.push(`<!----></div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--></div></div></div> <details id=\"options-advanced-details\" class=\"svelte-1q1mmx4\"><summary class=\"options-advanced-summary svelte-1q1mmx4\" id=\"options-advanced-toggle\">Advanced settings</summary> <div class=\"options-section\"><h3 class=\"options-section-title\">Container Image</h3> <p class=\"options-section-desc\">Tag or version of the OpenPalm images to deploy.</p> `);\n\t\tFormField($$renderer, {\n\t\t\tlabel: \"Image tag\",\n\t\t\tfor: \"image-tag\",\n\t\t\thint: \"Advanced — leave blank to use the default.\",\n\t\t\tchildren: ($$renderer) => {\n\t\t\t\t$$renderer.push(`<input id=\"image-tag\" class=\"form-input\" type=\"text\" placeholder=\"dev\"${attr(\"value\", imageTag)}/>`);\n\t\t\t},\n\t\t\t$$slots: { default: true }\n\t\t});\n\t\t$$renderer.push(`<!----></div> `);\n\t\tif (hostAkmAvailable) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"options-section\"><h3 class=\"options-section-title\">Share knowledge with my host AKM</h3> <p class=\"options-section-desc\">Adds a source entry to your personal <code>~/.config/akm/config.json</code> and mounts <code>~/akm</code> into the assistant as a secondary source. Your files' ownership is not changed and your primary stash is unchanged — your <code>~/akm</code> data and cache stay yours.</p> <div class=\"toggle-grid\"><div${attr_class(`toggle-card ${hostAkmEnabled ? \"on\" : \"\"}`)}><div class=\"toggle-card-header\" role=\"button\" tabindex=\"0\"><div class=\"toggle-card-icon\">🧠</div> <div class=\"toggle-card-info\"><div class=\"toggle-card-name\">Share knowledge with my host AKM (read + contribute)</div> <div class=\"toggle-card-desc\">The assistant reads your personal knowledge and can contribute back. Each side keeps its own primary stash, database, and cache — only the knowledge files are shared.</div></div> <div class=\"toggle-card-switch\"><div${attr_class(`toggle-track ${hostAkmEnabled ? \"on\" : \"\"}`)}><div class=\"toggle-thumb\"></div></div></div></div></div></div></div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--></details> `);\n\t\tif (errorMessage) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"feedback feedback--error\" role=\"alert\"><span>${escape_html(errorMessage)}</span></div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> <div class=\"step-actions\"><button class=\"btn btn-secondary\" id=\"btn-step4-back\">Back</button> <button class=\"btn btn-primary\" id=\"btn-step4-next\">Review</button></div>`);\n\t});\n}\n//#endregion\n//#region src/routes/setup/steps/ReviewStep.svelte\nfunction ReviewStep($$renderer, $$props) {\n\t$$renderer.component(($$renderer) => {\n\t\tlet { uiLoginPassword, verifiedProviders, modelSelection, activeTts, activeStt, voiceProfileLabel = \"\", ollamaProfileLabel = \"\", channelSelection, ollamaEnabled, payload, installError, installing, isRerun = false, onback, oninstall, ongostepedit } = $$props;\n\t\tfunction maskSecret(value) {\n\t\t\tif (!value || value.length < 8) return \"(not set)\";\n\t\t\treturn value.slice(0, 4) + \"...\" + value.slice(-4);\n\t\t}\n\t\tfunction isChannelEnabled$1(chId, locked) {\n\t\t\treturn isChannelEnabled(channelSelection, chId, locked);\n\t\t}\n\t\tfunction getCredValue$1(chId, key) {\n\t\t\treturn getCredValue(channelSelection, chId, key);\n\t\t}\n\t\tconst ttsOpt = derived(() => TTS_OPTIONS.find((o) => o.id === activeTts));\n\t\tconst sttOpt = derived(() => STT_OPTIONS.find((o) => o.id === activeStt));\n\t\tconst activeChannels = derived(() => CHANNELS.filter((ch) => isChannelEnabled$1(ch.id, ch.locked)));\n\t\tfunction findProvider(connId) {\n\t\t\treturn PROVIDERS.find((p) => p.id === connId);\n\t\t}\n\t\t$$renderer.push(`<h2>Review & Install</h2> <p class=\"step-description\">Confirm your settings, then install.</p> `);\n\t\tif (verifiedProviders.length === 0) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"review-warning svelte-1q74f52\" role=\"alert\">⚠ No AI provider connected — your assistant won't be able to chat until you add one from the dashboard.</div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> <div id=\"review-summary\"><div class=\"review-card\"><div class=\"review-card-title\"><span>Account</span> <button class=\"review-edit-btn\" type=\"button\">Edit</button></div> `);\n\t\tif (!isRerun) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"review-row review-row--alert svelte-1q74f52\"><span class=\"review-row-label\">UI Login Password</span> <span class=\"review-row-value\">`);\n\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`<span class=\"token-save-box svelte-1q74f52\">${escape_html(uiLoginPassword.substring(0, 2))}*********</span>`);\n\t\t\t$$renderer.push(`<!--]--></span></div> <div class=\"review-row review-row--alert svelte-1q74f52\"><span class=\"review-row-label\"><span class=\"token-save-hint svelte-1q74f52\">You'll need this to sign in. Also saved in <code class=\"svelte-1q74f52\">stack.env</code>.</span></span> <span class=\"review-row-value\"><button type=\"button\" class=\"btn btn-secondary btn-sm\">${escape_html(\"Copy password\")}</button></span></div>`);\n\t\t} else {\n\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`<div class=\"review-row\"><span class=\"review-row-label\">UI Login Password</span> <span class=\"review-row-value\">${escape_html(maskSecret(uiLoginPassword))}</span></div>`);\n\t\t}\n\t\t$$renderer.push(`<!--]--></div> <div class=\"review-card\"><div class=\"review-card-title\"><span>Models</span> <button class=\"review-edit-btn\" type=\"button\">Edit</button></div> `);\n\t\tif (modelSelection.llm) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\tconst llmProv = findProvider(modelSelection.llm.connId);\n\t\t\t$$renderer.push(`<div class=\"review-row\"><span class=\"review-row-label\">Chat Model</span> <span class=\"review-row-value\">${escape_html(modelSelection.llm.model)}${escape_html(llmProv ? \" (\" + llmProv.name + \")\" : \"\")}</span></div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> `);\n\t\tif (modelSelection.small?.model) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\tconst smallProv = findProvider(modelSelection.small.connId);\n\t\t\t$$renderer.push(`<div class=\"review-row\"><span class=\"review-row-label\">Small Model</span> <span class=\"review-row-value\">${escape_html(modelSelection.small.model)}${escape_html(smallProv ? \" (\" + smallProv.name + \")\" : \"\")}</span></div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> `);\n\t\tif (modelSelection.embedding) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\tconst embProv = findProvider(modelSelection.embedding.connId);\n\t\t\t$$renderer.push(`<div class=\"review-row\"><span class=\"review-row-label\">Memory Model</span> <span class=\"review-row-value\">${escape_html(modelSelection.embedding.model)}${escape_html(embProv ? \" (\" + embProv.name + \")\" : \"\")}</span></div> <div class=\"review-row\" style=\"padding:4px 0\"><span class=\"review-row-label\">Embedding Dims</span> <span class=\"review-row-value\">${escape_html(modelSelection.embedding.dims ?? 1536)}</span></div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--></div> <div class=\"review-card\"><div class=\"review-card-title\"><span>Channels</span> <button class=\"review-edit-btn\" type=\"button\">Edit</button></div> <!--[-->`);\n\t\tconst each_array = ensure_array_like(activeChannels());\n\t\tfor (let $$index_1 = 0, $$length = each_array.length; $$index_1 < $$length; $$index_1++) {\n\t\t\tlet ch = each_array[$$index_1];\n\t\t\t$$renderer.push(`<div class=\"review-row\"><span class=\"review-row-label\">${escape_html(ch.icon)} ${escape_html(ch.name)}</span> <span class=\"review-row-value review-row-value-ok\">Enabled ✓</span></div> `);\n\t\t\tif (ch.credentials) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\tconst sel = channelSelection[ch.id];\n\t\t\t\tif (typeof sel === \"object\" && sel !== null && sel.enabled) {\n\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t$$renderer.push(`<!--[-->`);\n\t\t\t\t\tconst each_array_1 = ensure_array_like(ch.credentials);\n\t\t\t\t\tfor (let $$index = 0, $$length = each_array_1.length; $$index < $$length; $$index++) {\n\t\t\t\t\t\tlet cred = each_array_1[$$index];\n\t\t\t\t\t\tconst val = getCredValue$1(ch.id, cred.key);\n\t\t\t\t\t\tif (val) {\n\t\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\t\t$$renderer.push(`<div class=\"review-row\"><span class=\"review-row-label\" style=\"padding-left:24px\">${escape_html(cred.label)}</span> <span class=\"review-row-value\">${escape_html(maskSecret(val))}</span></div>`);\n\t\t\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t$$renderer.push(`<!--]-->`);\n\t\t\t\t\t}\n\t\t\t\t\t$$renderer.push(`<!--]-->`);\n\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t$$renderer.push(`<!--]-->`);\n\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`<!--]-->`);\n\t\t}\n\t\t$$renderer.push(`<!--]--></div> <div class=\"review-card\"><div class=\"review-card-title\"><span>Voice</span> <button class=\"review-edit-btn\" type=\"button\">Edit</button></div> <div class=\"review-row\"><span class=\"review-row-label\">Text-to-Speech</span> <span class=\"review-row-value\">${escape_html(ttsOpt() ? ttsOpt().name : \"Disabled\")}</span></div> <div class=\"review-row\"><span class=\"review-row-label\">Speech-to-Text</span> <span class=\"review-row-value\">${escape_html(sttOpt() ? sttOpt().name : \"Disabled\")}</span></div> `);\n\t\tif (voiceProfileLabel && (activeTts === \"openpalm-voice\" || activeStt === \"openpalm-voice\")) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"review-row\"><span class=\"review-row-label\">Voice Container</span> <span class=\"review-row-value\">${escape_html(voiceProfileLabel)}</span></div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--></div> <div class=\"review-card\"><div class=\"review-card-title\"><span>Options</span> <button class=\"review-edit-btn\" type=\"button\">Edit</button></div> `);\n\t\tif (ollamaEnabled) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"review-row\"><span class=\"review-row-label\">Ollama In-Stack</span> <span class=\"review-row-value\">Enabled</span></div> `);\n\t\t\tif (ollamaProfileLabel) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t$$renderer.push(`<div class=\"review-row\"><span class=\"review-row-label\">Ollama Profile</span> <span class=\"review-row-value\">${escape_html(ollamaProfileLabel)}</span></div>`);\n\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`<!--]-->`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--></div> <div class=\"review-card\"><div class=\"review-card-title\"><span>Providers</span> <button class=\"review-edit-btn\" type=\"button\">Edit</button></div> <!--[-->`);\n\t\tconst each_array_2 = ensure_array_like(verifiedProviders);\n\t\tfor (let $$index_2 = 0, $$length = each_array_2.length; $$index_2 < $$length; $$index_2++) {\n\t\t\tlet p = each_array_2[$$index_2];\n\t\t\t$$renderer.push(`<div class=\"review-row\"><span class=\"review-row-label\">${escape_html(p.icon)} ${escape_html(p.name)}</span> <span class=\"review-row-value review-row-value-ok\">Connected ✓</span></div>`);\n\t\t}\n\t\t$$renderer.push(`<!--]--></div></div> `);\n\t\tif (installError) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\tFriendlyError($$renderer, { error: friendlyError(installError, \"setup-complete\") });\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> <div class=\"step-actions\" id=\"review-actions\"><button type=\"button\" class=\"btn btn-info\">Save configuration</button> <button class=\"btn btn-secondary\">Back</button> <button class=\"btn btn-primary\" id=\"btn-install\"${attr(\"disabled\", installing, true)}>`);\n\t\tif (installing) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\tSpinner($$renderer, {});\n\t\t\t$$renderer.push(`<!----> Installing...`);\n\t\t} else {\n\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`Install`);\n\t\t}\n\t\t$$renderer.push(`<!--]--></button></div>`);\n\t});\n}\n//#endregion\n//#region src/routes/setup/steps/DeployStep.svelte\nfunction DeployStep($$renderer, $$props) {\n\t$$renderer.component(($$renderer) => {\n\t\t/** Terminal state reached with non-running rows that are all warnings. */\n\t\tlet { deployData, deployDone, deployHasWarnings = false, deployError, onback, onretry } = $$props;\n\t\tconst warningRows = derived(() => (deployData.deployStatus ?? []).filter((s) => s.status === \"warning\"));\n\t\tconst isElectron = typeof window !== \"undefined\" && !!window.openpalm;\n\t\tconst windowPort = typeof window !== \"undefined\" ? Number(window.location.port) || 3880 : 3880;\n\t\tconst adminPort = derived(() => deployData.ports?.admin ?? windowPort);\n\t\tconst assistantPort = derived(() => deployData.ports?.assistant ?? 3800);\n\t\tconst serviceLinks = derived(() => ({\n\t\t\tassistant: {\n\t\t\t\tport: assistantPort(),\n\t\t\t\tlabel: \"Assistant (OpenCode)\",\n\t\t\t\tpath: \"\"\n\t\t\t},\n\t\t\tadmin: {\n\t\t\t\tport: adminPort(),\n\t\t\t\tlabel: \"Admin Dashboard\",\n\t\t\t\tpath: \"\"\n\t\t\t}\n\t\t}));\n\t\tconst services = derived(() => deployData.deployStatus ?? []);\n\t\tconst total = derived(() => services().length);\n\t\tconst running = derived(() => services().filter((s) => s.status === \"running\").length);\n\t\tconst pct = derived(() => total() > 0 ? Math.round(running() / total() * 100) : 0);\n\t\tconst phase = derived(() => deployData.phase ?? \"writing-config\");\n\t\tconst voiceEnabled = derived(() => services().some((s) => /^voice(-cuda|-rocm)?$/.test(s.service ?? \"\")));\n\t\tconst deployTitle = derived(() => {\n\t\t\tif (deployDone) return deployHasWarnings ? \"Setup Complete (with warnings)\" : \"Setup Complete\";\n\t\t\tif (deployError) return \"Deployment Issue\";\n\t\t\tswitch (phase()) {\n\t\t\t\tcase \"writing-config\": return \"Preparing Configuration…\";\n\t\t\t\tcase \"pulling-images\": return voiceEnabled() ? \"Downloading Images (incl. Voice ~2.4 GB)…\" : \"Downloading Images…\";\n\t\t\t\tcase \"starting\": return \"Starting Services…\";\n\t\t\t\tcase \"starting-voice\": return \"Starting Voice Addon…\";\n\t\t\t\tcase \"ready\": return \"Setup Complete\";\n\t\t\t}\n\t\t\treturn \"Deploying…\";\n\t\t});\n\t\tconst deploySubtitle = derived(() => {\n\t\t\tif (deployDone) return deployHasWarnings ? \"Setup is complete. Some services are still warming up in the background — they will be ready shortly.\" : \"Your OpenPalm stack is up and running.\";\n\t\t\tif (deployError) return \"Setup could not finish starting the stack.\";\n\t\t\tswitch (phase()) {\n\t\t\t\tcase \"writing-config\": return \"Writing config files and validating settings.\";\n\t\t\t\tcase \"pulling-images\": return voiceEnabled() ? \"Downloading container images. The voice model (~2.4 GB) is the largest — on a typical home connection this step can take 10–30 minutes. The wizard will wait — keep this tab open.\" : \"Downloading container images — first install can take 3–8 minutes depending on connection.\";\n\t\t\t\tcase \"starting\": return `${running()} of ${total()} services running.`;\n\t\t\t\tcase \"starting-voice\": return \"Pulling the voice image (~2.4 GB) and warming up Kokoro + Whisper models. First launch can take 5–30 minutes on slow connections — the wizard will wait.\";\n\t\t\t\tcase \"ready\": return \"All services are up.\";\n\t\t\t}\n\t\t\treturn \"Writing configuration and starting services.\";\n\t\t});\n\t\tconst noStartMode = derived(() => deployDone && services().length === 0);\n\t\t$$renderer.push(`<div class=\"deploy-header\"><h2 id=\"deploy-title\">${escape_html(deployTitle())}</h2> <p class=\"step-description\" id=\"deploy-subtitle\">${escape_html(deploySubtitle())}</p></div> <div class=\"deploy-progress-summary\"><div class=\"deploy-progress-meta\"><span class=\"deploy-progress-label\">Progress</span> <span${attr_class(`deploy-progress-value ${deployError ? \"deploy-progress-value--error\" : \"\"}`)} id=\"deploy-progress-value\">`);\n\t\tif (deployError) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`Error`);\n\t\t} else if (deployDone) {\n\t\t\t$$renderer.push(\"<!--[1-->\");\n\t\t\t$$renderer.push(`${escape_html(services().length > 0 ? \"100%\" : \"\")}`);\n\t\t} else {\n\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`${escape_html(pct())}%`);\n\t\t}\n\t\t$$renderer.push(`<!--]--></span></div> <div class=\"deploy-progress-bar\"><div class=\"deploy-progress-fill\" id=\"deploy-progress-fill\"${attr_style(`width:${stringify(deployDone && services().length > 0 ? 100 : deployDone ? 0 : pct())}%`)}></div></div></div> <div class=\"deploy-services\" id=\"deploy-services\"><!--[-->`);\n\t\tconst each_array = ensure_array_like(services());\n\t\tfor (let $$index = 0, $$length = each_array.length; $$index < $$length; $$index++) {\n\t\t\tlet svc = each_array[$$index];\n\t\t\t$$renderer.push(`<div class=\"deploy-service-row\"><div class=\"deploy-service-indicator\">`);\n\t\t\tif (svc.status === \"running\") {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t$$renderer.push(`<span class=\"deploy-check\"><svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"var(--color-success)\" stroke-width=\"2.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><polyline points=\"20 6 9 17 4 12\"></polyline></svg></span>`);\n\t\t\t} else if (svc.status === \"error\" || svc.status === \"warning\") {\n\t\t\t\t$$renderer.push(\"<!--[1-->\");\n\t\t\t\t$$renderer.push(`<span class=\"deploy-warning\"><svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"var(--color-warning)\" stroke-width=\"2.3\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M12 9v4\"></path><path d=\"M12 17h.01\"></path><path d=\"M10.29 3.86 1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z\"></path></svg></span>`);\n\t\t\t} else {\n\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t$$renderer.push(`<span class=\"deploy-spinner\">`);\n\t\t\t\tSpinner($$renderer, {});\n\t\t\t\t$$renderer.push(`<!----></span>`);\n\t\t\t}\n\t\t\t$$renderer.push(`<!--]--></div> <div class=\"deploy-service-info\"><span class=\"deploy-service-name\">${escape_html(svc.service || svc.label || \"\")}</span> <span class=\"deploy-service-status\">${escape_html(svc.label || svc.status)}</span></div> <div class=\"deploy-service-bar\"><div${attr_class(`deploy-bar-fill ${svc.status === \"running\" ? \"complete\" : svc.status === \"ready\" ? \"ready\" : svc.status === \"warning\" ? \"warning\" : svc.status === \"error\" ? \"stopped\" : \"indeterminate\"}`, \"svelte-1orw49v\")}></div></div></div>`);\n\t\t}\n\t\t$$renderer.push(`<!--]--></div> `);\n\t\tif (deployError) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div id=\"deploy-failure\">`);\n\t\t\tFriendlyError($$renderer, { error: friendlyError(deployError, \"deploy\") });\n\t\t\t$$renderer.push(`<!----></div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> `);\n\t\tif (!deployDone && !deployError) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<aside class=\"deploy-tips\" id=\"deploy-tips\"><div class=\"deploy-tips-header\"><span class=\"deploy-tips-kicker\">Tips</span> <h3>${escape_html(voiceEnabled() ? \"First install may take 10–30 minutes\" : \"First startup takes a few minutes\")}</h3></div> <ul>`);\n\t\t\tif (voiceEnabled()) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t$$renderer.push(`<li>The OpenPalm Voice image is ~2.4 GB — the largest piece by far. Download speed depends on your internet connection.</li> <li>The wizard waits as long as the download takes. Progress bars below show each service's state.</li>`);\n\t\t\t} else {\n\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t$$renderer.push(`<li>Container images are being downloaded for the first time.</li>`);\n\t\t\t}\n\t\t\t$$renderer.push(`<!--]--> <li>The admin console will be available once all services are healthy.</li> `);\n\t\t\tif (isElectron) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t$$renderer.push(`<li>You can leave this window — we'll let you know when it's ready.</li>`);\n\t\t\t} else {\n\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t$$renderer.push(`<li><strong>Keep this tab open while installation runs.</strong></li>`);\n\t\t\t}\n\t\t\t$$renderer.push(`<!--]--></ul></aside>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> `);\n\t\tif (deployDone) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"done-state\" id=\"deploy-done\"><div class=\"done-icon\"><svg width=\"48\" height=\"48\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"var(--color-success)\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M22 11.08V12a10 10 0 1 1-5.93-9.14\"></path><polyline points=\"22 4 12 14.01 9 11.01\"></polyline></svg></div> <h2>${escape_html(deployHasWarnings ? \"Setup Complete (with warnings)\" : \"Setup Complete\")}</h2> `);\n\t\t\tif (noStartMode()) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t$$renderer.push(`<p class=\"done-subtitle\">Configuration saved. Run 'openpalm start' to start services.</p>`);\n\t\t\t} else {\n\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t$$renderer.push(`<p class=\"done-subtitle\">${escape_html(deployHasWarnings ? \"Setup is complete. Some services are still warming up in the background.\" : \"Your OpenPalm stack is up and running.\")}</p> `);\n\t\t\t\tif (deployHasWarnings && warningRows().length > 0) {\n\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t$$renderer.push(`<div class=\"deploy-warnings-note svelte-1orw49v\" role=\"status\" id=\"deploy-warnings-note\">Still warming up: ${escape_html(warningRows().map((s) => s.label || s.service).join(\", \"))}. You can finish setup now — these will be ready shortly.</div>`);\n\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t$$renderer.push(`<!--]--> `);\n\t\t\t\tif (!isElectron) {\n\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t$$renderer.push(`<p class=\"done-close-hint svelte-1orw49v\">Setup is complete. You can safely close this tab now.</p>`);\n\t\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t\t$$renderer.push(`<!--]--> <ul class=\"service-list\" id=\"deploy-service-list\"><!--[-->`);\n\t\t\t\tconst each_array_1 = ensure_array_like(services());\n\t\t\t\tfor (let $$index_1 = 0, $$length = each_array_1.length; $$index_1 < $$length; $$index_1++) {\n\t\t\t\t\tlet svc = each_array_1[$$index_1];\n\t\t\t\t\tconst name = svc.service || svc.label || \"\";\n\t\t\t\t\tconst linkInfo = serviceLinks()[name];\n\t\t\t\t\tconst isWarming = svc.status === \"warning\";\n\t\t\t\t\t$$renderer.push(`<li>`);\n\t\t\t\t\tif (linkInfo) {\n\t\t\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t\t\tconst url = \"http://127.0.0.1:\" + linkInfo.port + linkInfo.path;\n\t\t\t\t\t\t$$renderer.push(`<span class=\"deploy-svc-name\">${escape_html(linkInfo.label)}</span> <a${attr(\"href\", url)} target=\"_blank\" rel=\"noopener\" class=\"deploy-svc-link\">${escape_html(url)}</a> <span class=\"deploy-svc-status\">${escape_html(isWarming ? svc.label || \"⚠ Warming up\" : \"✓ Running\")}</span>`);\n\t\t\t\t\t} else {\n\t\t\t\t\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t\t\t\t\t$$renderer.push(`<span class=\"deploy-svc-name\">${escape_html(name)}</span> <span class=\"deploy-svc-status\">${escape_html(isWarming ? svc.label || \"⚠ Warming up\" : \"✓ Running\")}</span>`);\n\t\t\t\t\t}\n\t\t\t\t\t$$renderer.push(`<!--]--></li>`);\n\t\t\t\t}\n\t\t\t\t$$renderer.push(`<!--]--></ul> <div class=\"done-links\"><a href=\"/chat\" class=\"btn btn-primary\">Open Chat</a> <a${attr(\"href\", `http://127.0.0.1:${stringify(assistantPort())}`)} target=\"_blank\" rel=\"noopener\" class=\"btn btn-secondary\">OpenCode UI</a> <a href=\"/\" class=\"btn btn-secondary\">Admin Dashboard</a></div>`);\n\t\t\t}\n\t\t\t$$renderer.push(`<!--]--></div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> `);\n\t\tif (deployError) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"step-actions\" id=\"deploy-error-actions\"><button class=\"btn btn-secondary\" id=\"btn-deploy-back\">Back to Review</button> <button class=\"btn btn-primary\" id=\"btn-deploy-retry\">Retry</button></div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]-->`);\n\t});\n}\n//#endregion\n//#region src/routes/setup/+page.svelte\nfunction _page($$renderer, $$props) {\n\t$$renderer.component(($$renderer) => {\n\t\tlet currentStep = 0;\n\t\tlet maxVisitedStep = 0;\n\t\tlet showDeploy = false;\n\t\tlet systemCheckPassed = false;\n\t\tlet uiLoginPassword = \"\";\n\t\tlet step0Error = \"\";\n\t\tlet detectionReady = false;\n\t\tlet autoModeImporting = false;\n\t\tlet enableVoice = false;\n\t\tlet gpuDetected = false;\n\t\tlet providerState = {};\n\t\tlet detectedHostProviders = [];\n\t\tconst hostLocalLlmRunning = derived(() => providerState[\"ollama\"]?.ollamaMode === \"running\" || detectedHostProviders.some((p) => p.provider === \"ollama\" || p.provider === \"lmstudio\"));\n\t\tlet expandedProvider = null;\n\t\tlet detectedProviders = [];\n\t\tlet detecting = false;\n\t\tlet opencodeAvailable = false;\n\t\tlet opencodeProviders = [];\n\t\tlet opencodeAuth = {};\n\t\tlet ocFilterQuery = \"\";\n\t\tlet hostProviderCount = 0;\n\t\tlet hostStatusWarning = null;\n\t\tlet allowEmptyInstall = false;\n\t\tlet recommendation = null;\n\t\tlet recommendationAlert = \"\";\n\t\tlet recommendationApplied = false;\n\t\tlet voiceEngineUnknownTts = false;\n\t\tlet voiceEngineUnknownStt = false;\n\t\t/** Generation counter per provider — discard stale verify results */\n\t\tconst verifyGeneration = {};\n\t\t/** AbortControllers for in-flight OAuth long-poll requests */\n\t\tconst oauthAbortControllers = {};\n\t\tlet modelSelection = {};\n\t\tlet step2Error = \"\";\n\t\tlet step2EmbDimWarning = \"\";\n\t\tlet voiceTts = { engine: \"\" };\n\t\tlet voiceStt = { engine: \"\" };\n\t\tlet voiceProfiles = [];\n\t\tlet selectedVoiceProfile = \"\";\n\t\tlet channelSelection = {\n\t\t\tdiscord: {\n\t\t\t\tenabled: false,\n\t\t\t\tbotToken: \"\",\n\t\t\t\tapplicationId: \"\"\n\t\t\t},\n\t\t\tslack: {\n\t\t\t\tenabled: false,\n\t\t\t\tslackBotToken: \"\",\n\t\t\t\tslackAppToken: \"\"\n\t\t\t}\n\t\t};\n\t\tlet ollamaEnabled = false;\n\t\tlet ollamaProfiles = [];\n\t\tlet selectedOllamaProfile = \"\";\n\t\tlet imageTag = \"\";\n\t\tlet hostAkmEnabled = false;\n\t\tlet hostAkmAvailable = false;\n\t\tlet step4Error = \"\";\n\t\tlet installError = \"\";\n\t\tlet installing = false;\n\t\tlet emptyAiAck = false;\n\t\tlet deployData = {};\n\t\tlet deployDone = false;\n\t\tlet deployHasWarnings = false;\n\t\tlet deployError = null;\n\t\tlet deployTimer = null;\n\t\tlet deployPollErrors = 0;\n\t\tconst verifiedCount = derived(() => {\n\t\t\treturn PROVIDERS.map((p) => p.id).filter((id) => providerState[id]?.verified).length;\n\t\t});\n\t\tconst verifiedProviders = derived(() => {\n\t\t\treturn PROVIDERS.filter((p) => providerState[p.id]?.verified);\n\t\t});\n\t\tconst hasOllamaVerified = derived(() => PROVIDERS.some((p) => p.id === \"ollama\" && providerState[p.id]?.verified));\n\t\tconst hasVerifiedProvider = derived(() => verifiedProviders().length > 0);\n\t\tconst canComplete = derived(() => hasVerifiedProvider() && !!modelSelection.llm?.model || allowEmptyInstall);\n\t\tconst hasOpenAI = derived(() => PROVIDERS.some((p) => p.id === \"openai\" && providerState[p.id]?.verified));\n\t\tconst voiceDefaults = derived(() => hasOpenAI() ? {\n\t\t\ttts: \"openai-tts\",\n\t\t\tstt: \"openai-stt\"\n\t\t} : {\n\t\t\ttts: \"browser-tts\",\n\t\t\tstt: \"browser-stt\"\n\t\t});\n\t\tconst displayedVoiceTts = derived(() => {\n\t\t\tif (voiceTts.engine) return voiceTts;\n\t\t\tif (enableVoice) return { engine: \"openpalm-voice\" };\n\t\t\treturn { engine: voiceDefaults().tts };\n\t\t});\n\t\tconst displayedVoiceStt = derived(() => {\n\t\t\tif (voiceStt.engine) return voiceStt;\n\t\t\tif (enableVoice) return { engine: \"openpalm-voice\" };\n\t\t\treturn { engine: voiceDefaults().stt };\n\t\t});\n\t\tconst persistedVoiceTts = derived(() => {\n\t\t\tif (voiceTts.engine) return voiceTts;\n\t\t\tif (enableVoice) return { engine: \"openpalm-voice\" };\n\t\t\treturn { engine: \"\" };\n\t\t});\n\t\tconst persistedVoiceStt = derived(() => {\n\t\t\tif (voiceStt.engine) return voiceStt;\n\t\t\tif (enableVoice) return { engine: \"openpalm-voice\" };\n\t\t\treturn { engine: \"\" };\n\t\t});\n\t\tconst selectedVoiceProfileLabel = derived(() => {\n\t\t\tif (!selectedVoiceProfile) return \"\";\n\t\t\tconst profile = voiceProfiles.find((p) => p.id === selectedVoiceProfile);\n\t\t\treturn profile?.label ?? profile?.id ?? selectedVoiceProfile;\n\t\t});\n\t\tconst selectedOllamaProfileLabel = derived(() => {\n\t\t\tif (!selectedOllamaProfile) return \"\";\n\t\t\tconst profile = ollamaProfiles.find((p) => p.id === selectedOllamaProfile);\n\t\t\treturn profile?.label ?? profile?.id ?? selectedOllamaProfile;\n\t\t});\n\t\tfunction addonProfileId(addon, variant) {\n\t\t\treturn `addon.${addon}.${variant}`;\n\t\t}\n\t\tconst payload = derived(() => {\n\t\t\tconst llm = modelSelection.llm;\n\t\t\tconst emb = modelSelection.embedding;\n\t\t\tconst small = modelSelection.small;\n\t\t\tconst capabilityProviderIds = {};\n\t\t\tif (llm) capabilityProviderIds[llm.connId] = true;\n\t\t\tif (emb) capabilityProviderIds[emb.connId] = true;\n\t\t\tif (small?.model) capabilityProviderIds[small.connId] = true;\n\t\t\tconst capabilities = verifiedProviders().filter((p) => capabilityProviderIds[p.id]).map((p) => {\n\t\t\t\tconst st = providerState[p.id];\n\t\t\t\treturn {\n\t\t\t\t\tid: p.id,\n\t\t\t\t\tname: p.name,\n\t\t\t\t\tprovider: p.id,\n\t\t\t\t\tbaseUrl: st?.baseUrl ?? p.baseUrl,\n\t\t\t\t\tapiKey: st?.apiKey ?? \"\"\n\t\t\t\t};\n\t\t\t});\n\t\t\tconst llmConnId = llm?.connId ?? \"\";\n\t\t\tconst embConnId = emb?.connId ?? \"\";\n\t\t\tconst llmCap = capabilities.find((c) => c.id === llmConnId);\n\t\t\tconst embCap = capabilities.find((c) => c.id === embConnId);\n\t\t\tconst llmProvider = llmCap?.provider ?? \"\";\n\t\t\tconst embProvider = embCap?.provider ?? \"\";\n\t\t\tconst addons = {};\n\t\t\tif (ollamaEnabled && !hostLocalLlmRunning()) addons.ollama = true;\n\t\t\tif (persistedVoiceTts().engine === \"openpalm-voice\" || persistedVoiceStt().engine === \"openpalm-voice\") addons.voice = true;\n\t\t\tconst channelCredentials = {};\n\t\t\tconst channelsConfig = buildChannelsConfig();\n\t\t\tfor (const chId of Object.keys(channelsConfig)) {\n\t\t\t\tconst chVal = channelsConfig[chId];\n\t\t\t\tif (chVal === true) addons[chId] = true;\n\t\t\t\telse if (typeof chVal === \"object\" && chVal !== null) {\n\t\t\t\t\taddons[chId] = true;\n\t\t\t\t\tconst creds = {};\n\t\t\t\t\tfor (const key of Object.keys(chVal)) if (key !== \"enabled\" && chVal[key]) creds[key] = String(chVal[key]);\n\t\t\t\t\tif (Object.keys(creds).length > 0) channelCredentials[chId] = creds;\n\t\t\t\t}\n\t\t\t}\n\t\t\tconst result = {\n\t\t\t\tversion: 2,\n\t\t\t\taddons,\n\t\t\t\tsecurity: { uiLoginPassword },\n\t\t\t\tconnections: capabilities\n\t\t\t};\n\t\t\tif (llmProvider && llm?.model) result.llm = {\n\t\t\t\tprovider: llmProvider,\n\t\t\t\tmodel: llm.model,\n\t\t\t\tbaseUrl: llmCap?.baseUrl ?? \"\"\n\t\t\t};\n\t\t\tif (embProvider && emb?.model) result.embedding = {\n\t\t\t\tprovider: embProvider,\n\t\t\t\tmodel: emb.model,\n\t\t\t\tdims: emb.dims ?? 1536,\n\t\t\t\tbaseUrl: embCap?.baseUrl ?? \"\"\n\t\t\t};\n\t\t\tconst voicePayload = (v) => {\n\t\t\t\tif (!v.engine || v.engine.startsWith(\"skip-\")) return void 0;\n\t\t\t\tconst out = {\n\t\t\t\t\tenabled: true,\n\t\t\t\t\tengine: v.engine\n\t\t\t\t};\n\t\t\t\tif (v.provider) out.provider = v.provider;\n\t\t\t\tif (v.baseURL) out.baseURL = v.baseURL;\n\t\t\t\tif (v.model) out.model = v.model;\n\t\t\t\tif (v.voice) out.voice = v.voice;\n\t\t\t\tif (v.language) out.language = v.language;\n\t\t\t\treturn out;\n\t\t\t};\n\t\t\tconst ttsCap = voicePayload(persistedVoiceTts());\n\t\t\tif (ttsCap) result.tts = ttsCap;\n\t\t\tconst sttCap = voicePayload(persistedVoiceStt());\n\t\t\tif (sttCap) result.stt = sttCap;\n\t\t\tif ((persistedVoiceTts().engine === \"openpalm-voice\" || persistedVoiceStt().engine === \"openpalm-voice\") && selectedVoiceProfile) result.voiceProfile = selectedVoiceProfile;\n\t\t\tif (ollamaEnabled && selectedOllamaProfile) result.ollamaProfile = selectedOllamaProfile;\n\t\t\tif (Object.keys(channelCredentials).length > 0) result.channelCredentials = channelCredentials;\n\t\t\tif (imageTag.trim()) result.imageTag = imageTag.trim();\n\t\t\tif (hostAkmEnabled) result.hostAkm = true;\n\t\t\treturn result;\n\t\t});\n\t\tfunction buildChannelsConfig() {\n\t\t\tconst result = {};\n\t\t\tfor (const ch of CHANNELS) {\n\t\t\t\tconst sel = channelSelection[ch.id];\n\t\t\t\tif (ch.locked) result[ch.id] = true;\n\t\t\t\telse if (typeof sel === \"object\" && sel !== null) {\n\t\t\t\t\tif (sel.enabled) {\n\t\t\t\t\t\tconst entry = { enabled: true };\n\t\t\t\t\t\tif (ch.credentials) for (const cred of ch.credentials) {\n\t\t\t\t\t\t\tconst v = sel[cred.key];\n\t\t\t\t\t\t\tif (v) entry[cred.key] = v;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tresult[ch.id] = entry;\n\t\t\t\t\t}\n\t\t\t\t} else if (sel) result[ch.id] = true;\n\t\t\t}\n\t\t\treturn result;\n\t\t}\n\t\tfunction validateStep0() {\n\t\t\tif (uiLoginPassword.trim().length < 8) {\n\t\t\t\tstep0Error = \"UI login password must be at least 8 characters.\";\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\tstep0Error = \"\";\n\t\t\treturn true;\n\t\t}\n\t\tfunction enableRecommendedOllama(variant) {\n\t\t\tollamaEnabled = true;\n\t\t\tconst st = providerState[\"ollama\"];\n\t\t\tif (st) {\n\t\t\t\tst.selected = true;\n\t\t\t\tst.verified = true;\n\t\t\t\tst.ollamaMode = \"instack\";\n\t\t\t\tst.baseUrl = \"http://ollama:11434\";\n\t\t\t\tif (st.models.length === 0) st.models = [\"qwen3:4b\"];\n\t\t\t}\n\t\t\tconst preferred = addonProfileId(\"ollama\", variant ?? (gpuDetected ? \"cuda\" : \"cpu\"));\n\t\t\tselectedOllamaProfile = (ollamaProfiles.find((p) => p.id === preferred && p.available !== false) ?? ollamaProfiles.find((p) => p.available !== false))?.id ?? preferred;\n\t\t}\n\t\tlet recommendationFetched = false;\n\t\tasync function fetchRecommendation() {\n\t\t\tif (recommendationFetched || recommendation) return;\n\t\t\ttry {\n\t\t\t\tconst res = await fetch(\"/api/setup/recommend\");\n\t\t\t\tif (res.ok) {\n\t\t\t\t\tconst data = await res.json();\n\t\t\t\t\tif (data.ok && data.recommendation) recommendation = data.recommendation;\n\t\t\t\t\tif (data.ok && Array.isArray(data.hostProviders)) detectedHostProviders = data.hostProviders;\n\t\t\t\t}\n\t\t\t} catch {} finally {\n\t\t\t\trecommendationFetched = true;\n\t\t\t}\n\t\t}\n\t\tasync function fetchAndApplyRecommendation() {\n\t\t\tif (recommendationApplied) return;\n\t\t\tlet rec;\n\t\t\tif (recommendation) rec = recommendation;\n\t\t\telse try {\n\t\t\t\tconst res = await fetch(\"/api/setup/recommend\");\n\t\t\t\tif (!res.ok) return;\n\t\t\t\tconst data = await res.json();\n\t\t\t\tif (!data.ok || !data.recommendation) return;\n\t\t\t\trec = data.recommendation;\n\t\t\t} catch {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\trecommendationApplied = true;\n\t\t\trecommendation = rec;\n\t\t\tswitch (rec.action) {\n\t\t\t\tcase \"use-cloud\":\n\t\t\t\t\trecommendationAlert = \"\";\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"use-host-providers\":\n\t\t\t\t\trecommendationAlert = rec.alert;\n\t\t\t\t\tif (!hostImportTriggered) {\n\t\t\t\t\t\thostImportTriggered = true;\n\t\t\t\t\t\tawait handleHostImport();\n\t\t\t\t\t}\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"enable-ollama\":\n\t\t\t\t\trecommendationAlert = rec.alert;\n\t\t\t\t\tenableRecommendedOllama(rec.profileVariant);\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"connect-manually\":\n\t\t\t\t\trecommendationAlert = rec.alert;\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t\tasync function handleUseDefaults() {\n\t\t\tif (verifiedProviders().length >= 1) {\n\t\t\t\tautoSelectModels();\n\t\t\t\tif (!modelSelection.llm?.model && !allowEmptyInstall) {\n\t\t\t\t\tgoToStep(3);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tgoToStep(5);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tautoModeImporting = true;\n\t\t\tawait fetchAndApplyRecommendation();\n\t\t\tautoModeImporting = false;\n\t\t\tif (recommendation?.action === \"connect-manually\") {\n\t\t\t\tgoToStep(2);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tautoSelectModels();\n\t\t\tif (!modelSelection.llm?.model && !allowEmptyInstall) {\n\t\t\t\tgoToStep(3);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tgoToStep(5);\n\t\t}\n\t\tfunction handleEnableVoiceChange(v) {\n\t\t\tenableVoice = v;\n\t\t\tif (v) {\n\t\t\t\tif (voiceTts.engine !== \"openpalm-voice\") voiceTts = { engine: \"openpalm-voice\" };\n\t\t\t\tif (voiceStt.engine !== \"openpalm-voice\") voiceStt = { engine: \"openpalm-voice\" };\n\t\t\t\tif (!selectedVoiceProfile) {\n\t\t\t\t\tconst preferred = addonProfileId(\"voice\", gpuDetected ? \"cuda\" : \"cpu\");\n\t\t\t\t\tconst match = voiceProfiles.find((p) => p.id === preferred && p.available !== false) ?? voiceProfiles.find((p) => p.available !== false);\n\t\t\t\t\tif (match) selectedVoiceProfile = match.id;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif (voiceTts.engine === \"openpalm-voice\") voiceTts = { engine: \"\" };\n\t\t\t\tif (voiceStt.engine === \"openpalm-voice\") voiceStt = { engine: \"\" };\n\t\t\t}\n\t\t}\n\t\tfunction handleOptionsOllamaChange(v) {\n\t\t\tif (v) enableRecommendedOllama();\n\t\t\telse {\n\t\t\t\tollamaEnabled = false;\n\t\t\t\tconst st = providerState[\"ollama\"];\n\t\t\t\tif (st && st.ollamaMode !== \"running\") {\n\t\t\t\t\tst.selected = false;\n\t\t\t\t\tst.verified = false;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tfunction validateStep2() {\n\t\t\tif (allowEmptyInstall) {\n\t\t\t\tstep2Error = \"\";\n\t\t\t\treturn true;\n\t\t\t}\n\t\t\tif (verifiedProviders().length === 0) {\n\t\t\t\tstep2Error = \"Connect a provider on the previous step to continue.\";\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\tif (!modelSelection.llm?.model) {\n\t\t\t\tstep2Error = \"Select a chat model to continue.\";\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\tstep2Error = \"\";\n\t\t\treturn true;\n\t\t}\n\t\tfunction validateStep4() {\n\t\t\tconst errors = [];\n\t\t\tfor (const ch of CHANNELS) {\n\t\t\t\tif (!ch.credentials) continue;\n\t\t\t\tconst sel = channelSelection[ch.id];\n\t\t\t\tif (typeof sel !== \"object\" || sel === null) continue;\n\t\t\t\tif (!sel.enabled) continue;\n\t\t\t\tfor (const cred of ch.credentials) if (cred.required && !String(sel[cred.key] ?? \"\").trim()) errors.push(ch.name + \": \" + cred.label + \" is required.\");\n\t\t\t}\n\t\t\tif (errors.length > 0) {\n\t\t\t\tstep4Error = errors.join(\" \");\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\tstep4Error = \"\";\n\t\t\treturn true;\n\t\t}\n\t\tfunction canNavigateTo(step) {\n\t\t\tif (step > maxVisitedStep) return false;\n\t\t\treturn true;\n\t\t}\n\t\tfunction goToStep(n) {\n\t\t\tif (n < 0 || n > 6) return;\n\t\t\tif (n > 0 && !systemCheckPassed) return;\n\t\t\tcurrentStep = n;\n\t\t\tif (n > maxVisitedStep) maxVisitedStep = n;\n\t\t\tshowDeploy = false;\n\t\t\tif (n === 1 && !isRerun) fetchRecommendation();\n\t\t\tif (n === 3) autoSelectModels();\n\t\t\tif (n === 5 && hasOllamaVerified()) ollamaEnabled = providerState.ollama?.ollamaMode === \"instack\";\n\t\t\tif (n === 2 && !isRerun) fetchAndApplyRecommendation();\n\t\t}\n\t\tfunction autoSelectModels() {\n\t\t\tfor (const roleId of [\n\t\t\t\t\"llm\",\n\t\t\t\t\"embedding\",\n\t\t\t\t\"small\"\n\t\t\t]) {\n\t\t\t\tif (modelSelection[roleId]) continue;\n\t\t\t\tif (roleId === \"embedding\") continue;\n\t\t\t\tconst options = getModelOptionsForRole(roleId);\n\t\t\t\tif (options.length === 0) continue;\n\t\t\t\tconst defaultOpt = options.find((o) => o.isDefault) ?? options[0];\n\t\t\t\tmodelSelection[roleId] = {\n\t\t\t\t\tconnId: defaultOpt.connId,\n\t\t\t\t\tmodel: defaultOpt.id,\n\t\t\t\t\tdims: defaultOpt.dims\n\t\t\t\t};\n\t\t\t}\n\t\t}\n\t\tfunction getModelOptionsForRole(roleId) {\n\t\t\tconst options = [];\n\t\t\tfor (const p of verifiedProviders()) {\n\t\t\t\tconst st = providerState[p.id];\n\t\t\t\tconst defaultModel = roleId === \"embedding\" ? p.embModel : p.llmModel;\n\t\t\t\tconst models = st.models.length > 0 ? st.models : [];\n\t\t\t\tif (defaultModel && models.includes(defaultModel)) options.push({\n\t\t\t\t\tid: defaultModel,\n\t\t\t\t\tconnId: p.id,\n\t\t\t\t\tisDefault: true,\n\t\t\t\t\tdims: roleId === \"embedding\" ? KNOWN_EMB_DIMS[defaultModel] ?? KNOWN_EMB_DIMS[defaultModel.replace(/:.*$/, \"\")] ?? p.embDims ?? 0 : 0\n\t\t\t\t});\n\t\t\t\tfor (const m of models) {\n\t\t\t\t\tif (m === defaultModel) continue;\n\t\t\t\t\tconst dims = roleId === \"embedding\" ? KNOWN_EMB_DIMS[m] ?? KNOWN_EMB_DIMS[m.replace(/:.*$/, \"\")] ?? 0 : 0;\n\t\t\t\t\toptions.push({\n\t\t\t\t\t\tid: m,\n\t\t\t\t\t\tconnId: p.id,\n\t\t\t\t\t\tisDefault: false,\n\t\t\t\t\t\tdims\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (roleId === \"embedding\") return options.filter((o) => o.isDefault || o.dims > 0);\n\t\t\treturn options;\n\t\t}\n\t\tasync function apiFetchModels(provider, baseUrl, apiKey) {\n\t\t\tconst url = \"/api/setup/models/\" + encodeURIComponent(provider);\n\t\t\tconst res = await fetch(url, {\n\t\t\t\tmethod: \"POST\",\n\t\t\t\theaders: { \"Content-Type\": \"application/json\" },\n\t\t\t\tbody: JSON.stringify({\n\t\t\t\t\tapiKey: apiKey ?? \"\",\n\t\t\t\t\tbaseUrl: baseUrl ?? \"\"\n\t\t\t\t})\n\t\t\t});\n\t\t\tconst data = await res.json();\n\t\t\tif (!res.ok || data.status === \"recoverable_error\") throw new Error(data.error ?? \"Failed to fetch models (HTTP \" + res.status + \")\");\n\t\t\treturn data;\n\t\t}\n\t\tasync function verifyProvider(id) {\n\t\t\tconst p = PROVIDERS.find((x) => x.id === id);\n\t\t\tif (!p) return;\n\t\t\tconst st = providerState[id];\n\t\t\tif (!st) return;\n\t\t\tif (id === \"ollama\" && st.ollamaMode === \"instack\") {\n\t\t\t\tst.verified = true;\n\t\t\t\tst.error = false;\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tconst gen = (verifyGeneration[id] ?? 0) + 1;\n\t\t\tverifyGeneration[id] = gen;\n\t\t\tst.verifying = true;\n\t\t\tst.error = false;\n\t\t\tconst baseUrl = (st.baseUrl || p.baseUrl).trim();\n\t\t\tconst apiKey = (st.apiKey ?? \"\").trim();\n\t\t\ttry {\n\t\t\t\tconst result = await apiFetchModels(id, baseUrl, apiKey);\n\t\t\t\tif (verifyGeneration[id] !== gen) return;\n\t\t\t\tst.verified = true;\n\t\t\t\tst.error = false;\n\t\t\t\tst.models = result.models ?? [];\n\t\t\t} catch (e) {\n\t\t\t\tif (verifyGeneration[id] !== gen) return;\n\t\t\t\tst.verified = false;\n\t\t\t\tst.error = true;\n\t\t\t\tst.errorMessage = e instanceof Error ? e.message : \"\";\n\t\t\t\tst.models = [];\n\t\t\t}\n\t\t\tst.verifying = false;\n\t\t}\n\t\tasync function startOpenCodeOAuth(providerId, methodIndex) {\n\t\t\tconst st = providerState[providerId];\n\t\t\tif (!st) return;\n\t\t\tst.verifying = true;\n\t\t\tst.error = false;\n\t\t\ttry {\n\t\t\t\tconst res = await fetch(\"/api/setup/opencode/provider/\" + encodeURIComponent(providerId) + \"/oauth/authorize\", {\n\t\t\t\t\tmethod: \"POST\",\n\t\t\t\t\theaders: { \"Content-Type\": \"application/json\" },\n\t\t\t\t\tbody: JSON.stringify({ method: methodIndex })\n\t\t\t\t});\n\t\t\t\tconst oauthRes = await res.json();\n\t\t\t\tif (!res.ok) throw new Error(oauthRes.message ?? \"OAuth failed\");\n\t\t\t\tst.oauthPolling = true;\n\t\t\t\tst.oauthUrl = oauthRes.url ?? \"\";\n\t\t\t\tst.oauthInstructions = oauthRes.instructions ?? \"\";\n\t\t\t\tif (oauthRes.url && oauthRes.method === \"auto\") window.open(oauthRes.url, \"_blank\");\n\t\t\t\tawait pollOpenCodeOAuth(providerId, methodIndex);\n\t\t\t} catch (e) {\n\t\t\t\tst.verifying = false;\n\t\t\t\tst.error = true;\n\t\t\t\tst.errorMessage = e instanceof Error ? e.message : \"OAuth failed\";\n\t\t\t\tst.oauthPolling = false;\n\t\t\t}\n\t\t}\n\t\tasync function pollOpenCodeOAuth(providerId, methodIndex) {\n\t\t\tconst st = providerState[providerId];\n\t\t\tconst ac = new AbortController();\n\t\t\toauthAbortControllers[providerId] = ac;\n\t\t\tconst timeoutSignal = AbortSignal.timeout(10 * 6e4);\n\t\t\tconst combinedSignal = AbortSignal.any ? AbortSignal.any([ac.signal, timeoutSignal]) : ac.signal;\n\t\t\ttry {\n\t\t\t\tconst res = await fetch(\"/api/setup/opencode/provider/\" + encodeURIComponent(providerId) + \"/oauth/callback\", {\n\t\t\t\t\tmethod: \"POST\",\n\t\t\t\t\theaders: { \"Content-Type\": \"application/json\" },\n\t\t\t\t\tbody: JSON.stringify({ method: methodIndex }),\n\t\t\t\t\tsignal: combinedSignal\n\t\t\t\t});\n\t\t\t\tconst data = await res.json().catch(() => null);\n\t\t\t\tif (res.ok && data?.ok) {\n\t\t\t\t\tst.verified = true;\n\t\t\t\t\tst.error = false;\n\t\t\t\t} else {\n\t\t\t\t\tst.error = true;\n\t\t\t\t\tst.errorMessage = data?.message ?? \"Authorization failed\";\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\tif (e instanceof Error && e.name === \"AbortError\" && ac.signal.aborted) return;\n\t\t\t\tif (e instanceof Error && e.name === \"AbortError\") {\n\t\t\t\t\tst.error = true;\n\t\t\t\t\tst.errorMessage = \"Authorization timed out. Try again.\";\n\t\t\t\t} else {\n\t\t\t\t\tst.error = true;\n\t\t\t\t\tst.errorMessage = e instanceof Error ? e.message : \"Authorization failed\";\n\t\t\t\t}\n\t\t\t} finally {\n\t\t\t\tdelete oauthAbortControllers[providerId];\n\t\t\t\tst.oauthPolling = false;\n\t\t\t\tst.verifying = false;\n\t\t\t}\n\t\t}\n\t\tasync function handleInstall() {\n\t\t\tif (installing) return;\n\t\t\tinstallError = \"\";\n\t\t\tif (!!!payload().llm && !isRerun && !emptyAiAck) {\n\t\t\t\tif (!window.confirm(\"No AI provider is configured. Your assistant won’t be able to chat until you add one from the dashboard.\\n\\nInstall anyway?\")) return;\n\t\t\t\temptyAiAck = true;\n\t\t\t}\n\t\t\tinstalling = true;\n\t\t\tif ((persistedVoiceTts().engine === \"openpalm-voice\" || persistedVoiceStt().engine === \"openpalm-voice\") && !selectedVoiceProfile) {\n\t\t\t\tconst preferred = addonProfileId(\"voice\", gpuDetected ? \"cuda\" : \"cpu\");\n\t\t\t\tselectedVoiceProfile = (voiceProfiles.find((p) => p.id === preferred && p.available !== false) ?? voiceProfiles.find((p) => p.id === addonProfileId(\"voice\", \"cpu\") && p.available !== false) ?? voiceProfiles.find((p) => p.available !== false))?.id ?? addonProfileId(\"voice\", \"cpu\");\n\t\t\t}\n\t\t\tif (ollamaEnabled && !selectedOllamaProfile) selectedOllamaProfile = addonProfileId(\"ollama\", gpuDetected ? \"cuda\" : \"cpu\");\n\t\t\ttry {\n\t\t\t\tconst res = await fetch(\"/api/setup/complete\", {\n\t\t\t\t\tmethod: \"POST\",\n\t\t\t\t\theaders: { \"Content-Type\": \"application/json\" },\n\t\t\t\t\tbody: JSON.stringify(payload())\n\t\t\t\t});\n\t\t\t\tconst data = await res.json().catch(() => ({}));\n\t\t\t\tif (!res.ok || !data.ok) {\n\t\t\t\t\tinstallError = data.message ?? data.error ?? \"Install failed.\";\n\t\t\t\t\tinstalling = false;\n\t\t\t\t\tshowDeploy = false;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tshowDeploy = true;\n\t\t\t\tstartDeployPolling();\n\t\t\t} catch (e) {\n\t\t\t\tinstallError = \"Network error: \" + (e instanceof Error ? e.message : \"unable to reach server.\");\n\t\t\t\tinstalling = false;\n\t\t\t}\n\t\t}\n\t\tfunction startDeployPolling() {\n\t\t\tstopDeployPolling();\n\t\t\tpollDeployStatus();\n\t\t\tdeployTimer = setInterval(() => {\n\t\t\t\tpollDeployStatus();\n\t\t\t}, 2500);\n\t\t}\n\t\tfunction stopDeployPolling() {\n\t\t\tif (deployTimer) {\n\t\t\t\tclearInterval(deployTimer);\n\t\t\t\tdeployTimer = null;\n\t\t\t}\n\t\t}\n\t\tasync function pollDeployStatus() {\n\t\t\ttry {\n\t\t\t\tconst res = await fetch(\"/api/setup/deploy-status\");\n\t\t\t\tif (!res.ok) {\n\t\t\t\t\tdeployPollErrors++;\n\t\t\t\t\tif (deployPollErrors >= 5) {\n\t\t\t\t\t\tstopDeployPolling();\n\t\t\t\t\t\tdeployError = \"Lost contact with the installer. Services may still be starting in the background.\";\n\t\t\t\t\t}\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tconst data = await res.json();\n\t\t\t\tdeployPollErrors = 0;\n\t\t\t\tif (data.deployStatus && data.deployStatus.length > 0) data.deployStatus.map((s) => ({\n\t\t\t\t\tservice: s.service,\n\t\t\t\t\tstatus: s.status,\n\t\t\t\t\tlabel: s.label\n\t\t\t\t}));\n\t\t\t\tdeployData = data;\n\t\t\t\tif (data.deployError) {\n\t\t\t\t\tstopDeployPolling();\n\t\t\t\t\tdeployError = data.deployError;\n\t\t\t\t} else if (data.setupComplete && data.deployStatus && data.deployStatus.length > 0) {\n\t\t\t\t\tconst rows = data.deployStatus;\n\t\t\t\t\tconst allRunning = rows.every((s) => s.status === \"running\");\n\t\t\t\t\tconst onlyWarningsLeft = !data.deploying && rows.every((s) => s.status === \"running\" || s.status === \"warning\") && rows.some((s) => s.status === \"warning\");\n\t\t\t\t\tif (allRunning) {\n\t\t\t\t\t\tstopDeployPolling();\n\t\t\t\t\t\tdeployDone = true;\n\t\t\t\t\t} else if (onlyWarningsLeft) {\n\t\t\t\t\t\tstopDeployPolling();\n\t\t\t\t\t\tdeployHasWarnings = true;\n\t\t\t\t\t\tdeployDone = true;\n\t\t\t\t\t}\n\t\t\t\t} else if (data.setupComplete && !data.deploying && (!data.deployStatus || data.deployStatus.length === 0)) {\n\t\t\t\t\tstopDeployPolling();\n\t\t\t\t\tdeployDone = true;\n\t\t\t\t}\n\t\t\t} catch (err) {\n\t\t\t\tdeployPollErrors++;\n\t\t\t\tif (deployPollErrors >= 5) {\n\t\t\t\t\tstopDeployPolling();\n\t\t\t\t\tdeployError = err instanceof Error ? `Lost contact with the installer: ${err.message}` : \"Lost contact with the installer.\";\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tfunction handleToggleFallback(id) {\n\t\t\tconst st = providerState[id];\n\t\t\tif (!st) return;\n\t\t\tif (st.selected) expandedProvider = expandedProvider === id ? null : id;\n\t\t\telse {\n\t\t\t\tst.selected = true;\n\t\t\t\texpandedProvider = id;\n\t\t\t\tconst detected = detectedProviders.find((d) => d.provider === id && d.available);\n\t\t\t\tif (detected) st.baseUrl = detected.url;\n\t\t\t}\n\t\t}\n\t\tfunction handleToggleOpenCode(id) {\n\t\t\texpandedProvider = expandedProvider === id ? null : id;\n\t\t}\n\t\tfunction handleDeselect(id) {\n\t\t\tconst st = providerState[id];\n\t\t\tif (!st) return;\n\t\t\tst.selected = false;\n\t\t\tst.verified = false;\n\t\t\tst.verifying = false;\n\t\t\tst.error = false;\n\t\t\tst.apiKey = \"\";\n\t\t\tst.models = [];\n\t\t\tif (id === \"ollama\") st.ollamaMode = null;\n\t\t\tif (expandedProvider === id) expandedProvider = null;\n\t\t}\n\t\tfunction handleMarkReady(id) {\n\t\t\tconst st = providerState[id];\n\t\t\tif (st) {\n\t\t\t\tst.verified = true;\n\t\t\t\tst.error = false;\n\t\t\t}\n\t\t}\n\t\tfunction handleVerify(id) {\n\t\t\tverifyProvider(id);\n\t\t}\n\t\tfunction handleApiKey(id, key) {\n\t\t\tconst st = providerState[id];\n\t\t\tif (st) st.apiKey = key;\n\t\t}\n\t\tfunction handleBaseUrl(id, url) {\n\t\t\tconst st = providerState[id];\n\t\t\tif (st) st.baseUrl = url;\n\t\t}\n\t\tfunction handleOllamaMode(mode) {\n\t\t\tconst st = providerState.ollama;\n\t\t\tif (st) st.ollamaMode = mode;\n\t\t}\n\t\tfunction handleChannelToggle(id) {\n\t\t\tconst sel = channelSelection[id];\n\t\t\tif (typeof sel === \"object\" && sel !== null) sel.enabled = !sel.enabled;\n\t\t\telse channelSelection[id] = !sel;\n\t\t}\n\t\tfunction handleCredentialChange(chId, credKey, value) {\n\t\t\tconst sel = channelSelection[chId];\n\t\t\tif (typeof sel === \"object\" && sel !== null) sel[credKey] = value;\n\t\t}\n\t\tfunction handleSelectModel(role, connId, modelId, dims) {\n\t\t\tmodelSelection[role] = {\n\t\t\t\tconnId,\n\t\t\t\tmodel: modelId,\n\t\t\t\tdims\n\t\t\t};\n\t\t\tif (role === \"embedding\" && (dims <= 0 || dims === void 0)) step2EmbDimWarning = \"Unknown embedding model dimensions — set manually in akm config after install.\";\n\t\t\telse if (role === \"embedding\") step2EmbDimWarning = \"\";\n\t\t}\n\t\tfunction handleSelectNone(role) {\n\t\t\tdelete modelSelection[role];\n\t\t}\n\t\tfunction handleDeployRetry() {\n\t\t\tinstalling = false;\n\t\t\tdeployError = null;\n\t\t\tdeployDone = false;\n\t\t\tdeployHasWarnings = false;\n\t\t\tdeployData = {};\n\t\t\tdeployPollErrors = 0;\n\t\t\thandleInstall();\n\t\t}\n\t\tfunction handleDeployBack() {\n\t\t\tinstalling = false;\n\t\t\tdeployError = null;\n\t\t\tdeployDone = false;\n\t\t\tdeployHasWarnings = false;\n\t\t\tdeployData = {};\n\t\t\tdeployPollErrors = 0;\n\t\t\tshowDeploy = false;\n\t\t\tcurrentStep = 6;\n\t\t}\n\t\tlet hostImportTriggered = false;\n\t\tlet hostImporting = false;\n\t\tfunction markProviderVerifiedFromImport(id) {\n\t\t\tlet st = providerState[id];\n\t\t\tif (!st) {\n\t\t\t\tst = {\n\t\t\t\t\tselected: true,\n\t\t\t\t\tverified: true,\n\t\t\t\t\tverifying: false,\n\t\t\t\t\terror: false,\n\t\t\t\t\tapiKey: \"\",\n\t\t\t\t\tbaseUrl: \"\",\n\t\t\t\t\tmodels: [],\n\t\t\t\t\tollamaMode: null\n\t\t\t\t};\n\t\t\t\tproviderState[id] = st;\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tst.verified = true;\n\t\t\tst.error = false;\n\t\t}\n\t\tasync function handleHostImport() {\n\t\t\thostImporting = true;\n\t\t\thostStatusWarning = null;\n\t\t\ttry {\n\t\t\t\tconst res = await fetch(\"/api/setup/import-host\", { method: \"POST\" });\n\t\t\t\tconst data = await res.json().catch(() => null);\n\t\t\t\tif (!res.ok || !data?.ok) {\n\t\t\t\t\thostImporting = false;\n\t\t\t\t\thostStatusWarning = data?.error ? `Couldn't import host providers: ${data.error}` : \"Couldn't import providers from host OpenCode. Configure providers manually below.\";\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tconst importedIds = data.importedProviders ?? data.pushedProviders ?? [];\n\t\t\t\tfor (const id of importedIds) markProviderVerifiedFromImport(id);\n\t\t\t\tfor (const id of Object.keys(providerState)) if (!providerState[id].verified && PROVIDERS.some((p) => p.id === id)) verifyProvider(id);\n\t\t\t\thostImporting = false;\n\t\t\t\tif (!isRerun) goToStep(3);\n\t\t\t} catch (e) {\n\t\t\t\thostImporting = false;\n\t\t\t\thostStatusWarning = `Couldn't import providers from host OpenCode: ${e instanceof Error ? e.message : \"network error\"}. Configure providers manually below.`;\n\t\t\t}\n\t\t}\n\t\tlet isRerun = false;\n\t\thead(\"g40i6i\", $$renderer, ($$renderer) => {\n\t\t\t$$renderer.title(($$renderer) => {\n\t\t\t\t$$renderer.push(`<title>OpenPalm Setup</title>`);\n\t\t\t});\n\t\t\t$$renderer.push(`<link rel=\"stylesheet\" href=\"/setup/wizard.css\"/>`);\n\t\t});\n\t\t$$renderer.push(`<main class=\"setup-page\" aria-label=\"Setup wizard\"><div class=\"wizard-card\">`);\n\t\t$$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> <div class=\"wizard-header\"><div class=\"hdr-logo\">OP</div> <h1>OpenPalm <span class=\"hdr-suffix\">${escape_html(\"Setup\")}</span></h1></div> <div class=\"wizard-body\">`);\n\t\tif (!showDeploy) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\tProgressBar($$renderer, {\n\t\t\t\tcurrentStep,\n\t\t\t\tmaxVisitedStep,\n\t\t\t\tonnavigate: goToStep,\n\t\t\t\tcanNavigateTo\n\t\t\t});\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> `);\n\t\tif (!showDeploy && recommendationAlert && (currentStep === 2 || currentStep === 3)) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t$$renderer.push(`<div class=\"feedback feedback--warning\" role=\"alert\" data-testid=\"recommendation-alert\"><span>${escape_html(recommendationAlert)}</span></div>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--> `);\n\t\tif (showDeploy) {\n\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\tDeployStep($$renderer, {\n\t\t\t\tdeployData,\n\t\t\t\tdeployDone,\n\t\t\t\tdeployHasWarnings,\n\t\t\t\tdeployError,\n\t\t\t\tonback: handleDeployBack,\n\t\t\t\tonretry: handleDeployRetry\n\t\t\t});\n\t\t} else if (currentStep === 0) {\n\t\t\t$$renderer.push(\"<!--[1-->\");\n\t\t\t$$renderer.push(`<section class=\"step-content\" id=\"step-0\" data-testid=\"step-system-check\">`);\n\t\t\tSystemCheckStep($$renderer, {\n\t\t\t\tisRerun,\n\t\t\t\tonpass: () => {\n\t\t\t\t\tsystemCheckPassed = true;\n\t\t\t\t},\n\t\t\t\tonnext: () => {\n\t\t\t\t\tsystemCheckPassed = true;\n\t\t\t\t\tgoToStep(1);\n\t\t\t\t},\n\t\t\t\tongpudetected: (_gpu) => {\n\t\t\t\t\tgpuDetected = true;\n\t\t\t\t\tif (voiceProfiles.length > 0 && selectedVoiceProfile !== addonProfileId(\"voice\", \"cuda\")) {\n\t\t\t\t\t\tconst cuda = voiceProfiles.find((p) => p.id === addonProfileId(\"voice\", \"cuda\") && p.available !== false);\n\t\t\t\t\t\tif (cuda) selectedVoiceProfile = cuda.id;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t\t$$renderer.push(`<!----></section>`);\n\t\t} else if (currentStep === 1) {\n\t\t\t$$renderer.push(\"<!--[2-->\");\n\t\t\t$$renderer.push(`<section class=\"step-content\" id=\"step-1\" data-testid=\"step-welcome\">`);\n\t\t\tWelcomeStep($$renderer, {\n\t\t\t\terrorMessage: step0Error,\n\t\t\t\tdetectionReady,\n\t\t\t\tautoModeImporting,\n\t\t\t\trecommendation,\n\t\t\t\trecommendationFetched,\n\t\t\t\tonnext: () => {\n\t\t\t\t\tif (validateStep0()) goToStep(2);\n\t\t\t\t},\n\t\t\t\tonusedefaults: () => {\n\t\t\t\t\tif (validateStep0()) handleUseDefaults();\n\t\t\t\t}\n\t\t\t});\n\t\t\t$$renderer.push(`<!----></section>`);\n\t\t} else if (currentStep === 2) {\n\t\t\t$$renderer.push(\"<!--[3-->\");\n\t\t\t$$renderer.push(`<section class=\"step-content\" id=\"step-2\" data-testid=\"step-capabilities\">`);\n\t\t\tProvidersStep($$renderer, {\n\t\t\t\thostImporting,\n\t\t\t\topencodeAvailable,\n\t\t\t\topencodeProviders,\n\t\t\t\topencodeAuth,\n\t\t\t\tproviderState,\n\t\t\t\texpandedProvider,\n\t\t\t\tdetectedProviders,\n\t\t\t\tdetecting,\n\t\t\t\tocFilterQuery,\n\t\t\t\tverifiedCount: verifiedCount(),\n\t\t\t\thostProviderCount,\n\t\t\t\thostStatusWarning,\n\t\t\t\tallowEmptyInstall,\n\t\t\t\tcanProceed: hasVerifiedProvider() || allowEmptyInstall,\n\t\t\t\tonback: () => goToStep(1),\n\t\t\t\tonnext: () => goToStep(3),\n\t\t\t\tontogglefallback: handleToggleFallback,\n\t\t\t\tontoggleopencode: handleToggleOpenCode,\n\t\t\t\tonverify: handleVerify,\n\t\t\t\tonapikey: handleApiKey,\n\t\t\t\tonbaseurl: handleBaseUrl,\n\t\t\t\tonollamamode: handleOllamaMode,\n\t\t\t\tonoauthstart: startOpenCodeOAuth,\n\t\t\t\tonoauthcancel: (id) => {\n\t\t\t\t\tconst ac = oauthAbortControllers[id];\n\t\t\t\t\tif (ac) {\n\t\t\t\t\t\tac.abort();\n\t\t\t\t\t\tdelete oauthAbortControllers[id];\n\t\t\t\t\t}\n\t\t\t\t\tconst st = providerState[id];\n\t\t\t\t\tif (st) {\n\t\t\t\t\t\tst.oauthPolling = false;\n\t\t\t\t\t\tst.verifying = false;\n\t\t\t\t\t}\n\t\t\t\t},\n\t\t\t\tonmarkready: handleMarkReady,\n\t\t\t\tondeselect: handleDeselect,\n\t\t\t\tonfilterchange: (q) => ocFilterQuery = q,\n\t\t\t\tonhostimport: () => void handleHostImport(),\n\t\t\t\tonallowemptyinstallchange: (v) => allowEmptyInstall = v\n\t\t\t});\n\t\t\t$$renderer.push(`<!----></section>`);\n\t\t} else if (currentStep === 3) {\n\t\t\t$$renderer.push(\"<!--[4-->\");\n\t\t\t$$renderer.push(`<section class=\"step-content\" id=\"step-3\" data-testid=\"step-models\">`);\n\t\t\tif (step2EmbDimWarning) {\n\t\t\t\t$$renderer.push(\"<!--[0-->\");\n\t\t\t\t$$renderer.push(`<div class=\"feedback feedback--warning\" role=\"alert\"><span>${escape_html(step2EmbDimWarning)}</span></div>`);\n\t\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t\t$$renderer.push(`<!--]--> `);\n\t\t\tModelsStep($$renderer, {\n\t\t\t\tverifiedProviders: verifiedProviders(),\n\t\t\t\tproviderState,\n\t\t\t\tmodelSelection,\n\t\t\t\tallowEmptyInstall,\n\t\t\t\tcanComplete: canComplete(),\n\t\t\t\terrorMessage: step2Error,\n\t\t\t\tonback: () => goToStep(2),\n\t\t\t\tonnext: () => {\n\t\t\t\t\tif (validateStep2()) goToStep(4);\n\t\t\t\t},\n\t\t\t\tonselect: handleSelectModel,\n\t\t\t\tonselectnone: handleSelectNone\n\t\t\t});\n\t\t\t$$renderer.push(`<!----></section>`);\n\t\t} else if (currentStep === 4) {\n\t\t\t$$renderer.push(\"<!--[5-->\");\n\t\t\t$$renderer.push(`<section class=\"step-content\" id=\"step-4\" data-testid=\"step-voice\">`);\n\t\t\tVoiceStep($$renderer, {\n\t\t\t\ttts: displayedVoiceTts(),\n\t\t\t\tstt: displayedVoiceStt(),\n\t\t\t\thasOpenAI: hasOpenAI(),\n\t\t\t\tunknownTts: voiceEngineUnknownTts,\n\t\t\t\tunknownStt: voiceEngineUnknownStt,\n\t\t\t\tprofiles: voiceProfiles,\n\t\t\t\tselectedVoiceProfile,\n\t\t\t\tonback: () => goToStep(3),\n\t\t\t\tonnext: () => goToStep(5),\n\t\t\t\tonchangetts: (v) => {\n\t\t\t\t\tvoiceTts = v;\n\t\t\t\t\tvoiceEngineUnknownTts = false;\n\t\t\t\t\tenableVoice = voiceTts.engine === \"openpalm-voice\" || voiceStt.engine === \"openpalm-voice\";\n\t\t\t\t},\n\t\t\t\tonchangestt: (v) => {\n\t\t\t\t\tvoiceStt = v;\n\t\t\t\t\tvoiceEngineUnknownStt = false;\n\t\t\t\t\tenableVoice = voiceTts.engine === \"openpalm-voice\" || voiceStt.engine === \"openpalm-voice\";\n\t\t\t\t},\n\t\t\t\tonprofilechange: (id) => {\n\t\t\t\t\tselectedVoiceProfile = id;\n\t\t\t\t}\n\t\t\t});\n\t\t\t$$renderer.push(`<!----></section>`);\n\t\t} else if (currentStep === 5) {\n\t\t\t$$renderer.push(\"<!--[6-->\");\n\t\t\t$$renderer.push(`<section class=\"step-content\" id=\"step-5\" data-testid=\"step-options\">`);\n\t\t\tOptionsStep($$renderer, {\n\t\t\t\tchannelSelection,\n\t\t\t\timageTag,\n\t\t\t\thostAkmEnabled,\n\t\t\t\thostAkmAvailable,\n\t\t\t\tenableVoice,\n\t\t\t\tvoiceProfiles,\n\t\t\t\tselectedVoiceProfile,\n\t\t\t\tollamaEnabled,\n\t\t\t\tollamaProfiles,\n\t\t\t\tselectedOllamaProfile,\n\t\t\t\thostLocalRunning: hostLocalLlmRunning(),\n\t\t\t\terrorMessage: step4Error,\n\t\t\t\tonback: () => goToStep(4),\n\t\t\t\tonnext: () => {\n\t\t\t\t\tif (validateStep4()) goToStep(6);\n\t\t\t\t},\n\t\t\t\tonchanneltoggle: handleChannelToggle,\n\t\t\t\toncredentialchange: handleCredentialChange,\n\t\t\t\tonimagtagchange: (v) => imageTag = v,\n\t\t\t\tonhostakmchange: (v) => hostAkmEnabled = v,\n\t\t\t\tonenablevoicechange: handleEnableVoiceChange,\n\t\t\t\tonvoiceprofilechange: (id) => {\n\t\t\t\t\tselectedVoiceProfile = id;\n\t\t\t\t},\n\t\t\t\tonollamachange: handleOptionsOllamaChange,\n\t\t\t\tonollamaprofilechange: (id) => {\n\t\t\t\t\tselectedOllamaProfile = id;\n\t\t\t\t}\n\t\t\t});\n\t\t\t$$renderer.push(`<!----></section>`);\n\t\t} else if (currentStep === 6) {\n\t\t\t$$renderer.push(\"<!--[7-->\");\n\t\t\t$$renderer.push(`<section class=\"step-content\" id=\"step-6\" data-testid=\"step-review\">`);\n\t\t\tReviewStep($$renderer, {\n\t\t\t\tuiLoginPassword,\n\t\t\t\tverifiedProviders: verifiedProviders(),\n\t\t\t\tmodelSelection,\n\t\t\t\tactiveTts: persistedVoiceTts().engine,\n\t\t\t\tactiveStt: persistedVoiceStt().engine,\n\t\t\t\tvoiceProfileLabel: selectedVoiceProfileLabel(),\n\t\t\t\tollamaProfileLabel: selectedOllamaProfileLabel(),\n\t\t\t\tchannelSelection,\n\t\t\t\tollamaEnabled,\n\t\t\t\tpayload: payload(),\n\t\t\t\tinstallError,\n\t\t\t\tinstalling,\n\t\t\t\tisRerun,\n\t\t\t\tonback: () => goToStep(5),\n\t\t\t\toninstall: handleInstall,\n\t\t\t\tongostepedit: goToStep\n\t\t\t});\n\t\t\t$$renderer.push(`<!----></section>`);\n\t\t} else $$renderer.push(\"<!--[-1-->\");\n\t\t$$renderer.push(`<!--]--></div></div></main>`);\n\t});\n}\n//#endregion\nexport { _page as default };\n"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"_server.ts-B4p_jHqU.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/api/setup/import-host/_server.ts.js"],"sourcesContent":["import { r as json } from \"../../../../../chunks/exports.js\";\nimport { D as checkDocker, E as buildComposeOptions, kt as authJsonPath, n as importHostOpenCode, t as detectHostOpenCode } from \"../../../../../chunks/src.js\";\nimport { c as getState } from \"../../../../../chunks/endpoints.js\";\nimport { t as opencodeFetch } from \"../../../../../chunks/http.js\";\nimport { t as composeRestart } from \"../../../../../chunks/docker.js\";\nimport { existsSync, readFileSync } from \"node:fs\";\n//#region src/routes/api/setup/import-host/+server.ts\n/**\n* POST /api/setup/import-host\n*\n* Setup-phase equivalent of POST /admin/providers/import-host.\n* No admin auth required — the admin token hasn't been written yet during setup.\n*\n* Copies host OpenCode config + auth into OP_HOME and live-pushes credentials\n* to the running OpenCode subprocess so providers appear connected immediately.\n*/\nasync function pushAuthToOpenCode(authPath) {\n\tlet raw;\n\ttry {\n\t\traw = JSON.parse(readFileSync(authPath, \"utf-8\"));\n\t} catch (err) {\n\t\treturn {\n\t\t\tpushed: [],\n\t\t\terrors: [{\n\t\t\t\tprovider: \"*\",\n\t\t\t\terror: `Could not read auth.json: ${err instanceof Error ? err.message : String(err)}`\n\t\t\t}]\n\t\t};\n\t}\n\tif (!raw || typeof raw !== \"object\" || Array.isArray(raw)) return {\n\t\tpushed: [],\n\t\terrors: [{\n\t\t\tprovider: \"*\",\n\t\t\terror: \"auth.json is not a JSON object\"\n\t\t}]\n\t};\n\tconst pushed = [];\n\tconst errors = [];\n\tfor (const [providerId, value] of Object.entries(raw)) try {\n\t\tawait opencodeFetch(`/auth/${encodeURIComponent(providerId)}`, {\n\t\t\tmethod: \"PUT\",\n\t\t\tbody: JSON.stringify(value)\n\t\t});\n\t\tpushed.push(providerId);\n\t} catch (err) {\n\t\terrors.push({\n\t\t\tprovider: providerId,\n\t\t\terror: err instanceof Error ? err.message : String(err)\n\t\t});\n\t}\n\treturn {\n\t\tpushed,\n\t\terrors\n\t};\n}\n/** Restart provider-consuming services so they re-read imported startup config. */\nasync function restartProviderConsumers(state) {\n\tconst services = [\"assistant\"];\n\tif (!(await checkDocker()).ok) return {\n\t\trestarted: [],\n\t\tfailed: services.map((s) => ({\n\t\t\tservice: s,\n\t\t\terror: \"docker unavailable\"\n\t\t}))\n\t};\n\tconst opts = buildComposeOptions(state);\n\tconst restarted = [];\n\tconst failed = [];\n\tfor (const service of services) try {\n\t\tconst r = await composeRestart([service], opts);\n\t\tif (r.ok) restarted.push(service);\n\t\telse failed.push({\n\t\t\tservice,\n\t\t\terror: r.stderr || `exit ${r.code}`\n\t\t});\n\t} catch (err) {\n\t\tfailed.push({\n\t\t\tservice,\n\t\t\terror: err instanceof Error ? err.message : String(err)\n\t\t});\n\t}\n\treturn {\n\t\trestarted,\n\t\tfailed\n\t};\n}\n/** Read the provider ids present in an auth.json, ignoring read/parse errors. */\nfunction providerIdsFromAuth(authPath) {\n\ttry {\n\t\tconst raw = JSON.parse(readFileSync(authPath, \"utf-8\"));\n\t\tif (raw && typeof raw === \"object\" && !Array.isArray(raw)) return Object.keys(raw);\n\t} catch {}\n\treturn [];\n}\nvar POST = async () => {\n\tconst state = getState();\n\tlet result;\n\ttry {\n\t\tresult = importHostOpenCode(state, { overwriteConflicts: false });\n\t} catch (err) {\n\t\treturn json({\n\t\t\tok: false,\n\t\t\terror: `Could not copy host OpenCode config: ${err instanceof Error ? err.message : String(err)}`\n\t\t}, { status: 500 });\n\t}\n\tconst hostStatus = detectHostOpenCode();\n\tconst importedAuthPath = authJsonPath(state);\n\tconst authPathToUse = existsSync(importedAuthPath) ? importedAuthPath : hostStatus.authPath ?? null;\n\tconst importedProviderIds = authPathToUse ? providerIdsFromAuth(authPathToUse) : [];\n\tlet pushResult = {\n\t\tpushed: [],\n\t\terrors: []\n\t};\n\tif (authPathToUse) pushResult = await pushAuthToOpenCode(authPathToUse);\n\tconst restart = await restartProviderConsumers(state);\n\treturn json({\n\t\tok: true,\n\t\timported: result.imported,\n\t\timportedProviders: importedProviderIds,\n\t\tconflicts: result.conflicts.length,\n\t\tlivePushed: pushResult.pushed.length,\n\t\tpushedProviders: pushResult.pushed,\n\t\terrors: pushResult.errors,\n\t\trestarted: restart.restarted,\n\t\trestartFailed: restart.failed\n\t});\n};\n//#endregion\nexport { POST };\n"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"_server.ts-CAycEHO4.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/api/setup/recommend/_server.ts.js"],"sourcesContent":["import { r as json } from \"../../../../../chunks/exports.js\";\nimport { It as resolveStackDir, Z as isSetupComplete, c as detectGpu, kt as authJsonPath, l as detectLocalProviders, s as recommendSetup, zt as PROVIDER_KEY_MAP } from \"../../../../../chunks/src.js\";\nimport { c as getState } from \"../../../../../chunks/endpoints.js\";\nimport { a as getOpenCodeClient, f as requireAdmin, o as getRequestId } from \"../../../../../chunks/helpers.js\";\nimport { existsSync, readFileSync } from \"node:fs\";\n//#region src/routes/api/setup/recommend/+server.ts\n/** Local providers are detected separately as host providers — exclude from \"cloud\". */\nvar LOCAL_PROVIDER_IDS = new Set([\n\t\"ollama\",\n\t\"lmstudio\",\n\t\"model-runner\",\n\t\"openai-compatible\"\n]);\n/** Providers that have credentials stored in OP_HOME auth.json (API key or OAuth). */\nfunction authJsonConnected() {\n\ttry {\n\t\tconst path = authJsonPath(getState());\n\t\tif (!existsSync(path)) return [];\n\t\tconst data = JSON.parse(readFileSync(path, \"utf-8\"));\n\t\treturn Object.keys(data ?? {});\n\t} catch {\n\t\treturn [];\n\t}\n}\n/** Fallback: providers whose API-key env var is present in the process env. */\nfunction envKeyConnected() {\n\tconst out = [];\n\tfor (const [provider, envVar] of Object.entries(PROVIDER_KEY_MAP)) if (process.env[envVar]) out.push(provider);\n\treturn out;\n}\n/** Cloud providers = OpenCode connected[] ∪ auth.json credentials, minus locals.\n* Falls back to env-key detection when OpenCode is unavailable. */\nasync function detectCloudProviders() {\n\tlet connected = [];\n\ttry {\n\t\tconst client = getOpenCodeClient();\n\t\tif (await client.isAvailable()) {\n\t\t\tconst catalog = await client.proxy(\"/provider\");\n\t\t\tconst raw = catalog.ok ? catalog.data : {};\n\t\t\tconnected = Array.from(new Set([...raw.connected ?? [], ...authJsonConnected()]));\n\t\t} else connected = Array.from(new Set([...authJsonConnected(), ...envKeyConnected()]));\n\t} catch {\n\t\tconnected = Array.from(new Set([...authJsonConnected(), ...envKeyConnected()]));\n\t}\n\treturn connected.filter((id) => !LOCAL_PROVIDER_IDS.has(id));\n}\nvar GET = async (event) => {\n\tif (isSetupComplete(resolveStackDir())) {\n\t\tconst authError = requireAdmin(event, getRequestId(event));\n\t\tif (authError) return authError;\n\t}\n\tconst [cloudProviders, gpu, localDetections] = await Promise.all([\n\t\tdetectCloudProviders(),\n\t\tdetectGpu(),\n\t\tdetectLocalProviders()\n\t]);\n\tconst hostProviders = localDetections.filter((p) => p.available).map((p) => ({\n\t\tprovider: p.provider,\n\t\turl: p.url\n\t}));\n\treturn json({\n\t\tok: true,\n\t\trecommendation: recommendSetup({\n\t\t\tcloudProviders,\n\t\t\thostProviders,\n\t\t\tgpu\n\t\t}),\n\t\tgpu,\n\t\tcloudProviders,\n\t\thostProviders\n\t});\n};\n//#endregion\nexport { GET };\n"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"_server.ts-kVbBWaDD.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/api/setup/current-config/_server.ts.js"],"sourcesContent":["import { r as json } from \"../../../../../chunks/exports.js\";\nimport { at as getAddonProfileSelection, ot as getAddonProfiles, rt as annotateAddonProfileAvailability, ut as listEnabledAddonIds, xt as readStackSecretEnv, yt as readStackEnv } from \"../../../../../chunks/src.js\";\nimport { c as getState } from \"../../../../../chunks/endpoints.js\";\nimport { f as requireAdmin, o as getRequestId, s as getUiLoginPassword } from \"../../../../../chunks/helpers.js\";\nimport { existsSync, readFileSync } from \"node:fs\";\nimport { join } from \"node:path\";\n//#region src/routes/api/setup/current-config/+server.ts\nfunction readAkmConfig(configDir) {\n\tconst path = join(configDir, \"akm\", \"config.json\");\n\tif (!existsSync(path)) return {};\n\ttry {\n\t\treturn JSON.parse(readFileSync(path, \"utf-8\"));\n\t} catch {\n\t\treturn {};\n\t}\n}\nfunction deriveBaseUrl(endpoint) {\n\tif (!endpoint) return \"\";\n\treturn endpoint.replace(/\\/chat\\/completions\\/?$/, \"\").replace(/\\/embeddings\\/?$/, \"\").replace(/\\/+$/, \"\");\n}\nvar GET = async (event) => {\n\tconst authError = requireAdmin(event, getRequestId(event));\n\tif (authError) return authError;\n\tconst state = getState();\n\tconst configured = getUiLoginPassword();\n\tconst env = readStackEnv(state.stackDir);\n\tconst secretEnv = readStackSecretEnv(state.stackDir);\n\tconst akm = readAkmConfig(state.configDir);\n\tconst voiceProfiles = await annotateAddonProfileAvailability(getAddonProfiles(state.homeDir, \"voice\"));\n\tconst selectedVoiceProfile = getAddonProfileSelection(state.stackDir, \"voice\");\n\tconst ollamaProfiles = await annotateAddonProfileAvailability(getAddonProfiles(state.homeDir, \"ollama\"));\n\tconst selectedOllamaProfile = getAddonProfileSelection(state.stackDir, \"ollama\");\n\tconst hostHome = process.env.HOME ?? process.env.USERPROFILE ?? \"\";\n\tconst hostAkm = !!hostHome && env.OP_AKM_STASH === `${hostHome}/akm` && env.OP_AKM_CONFIG === `${hostHome}/.config/akm`;\n\tconst meta = (envKey) => ({\n\t\tenvKey,\n\t\tpresent: Boolean(secretEnv[envKey])\n\t});\n\tconst discord = {};\n\tfor (const [field, envKey] of Object.entries({\n\t\tbotToken: \"DISCORD_BOT_TOKEN\",\n\t\tapplicationId: \"DISCORD_APPLICATION_ID\",\n\t\tregisterCommands: \"DISCORD_REGISTER_COMMANDS\",\n\t\tallowedGuilds: \"DISCORD_ALLOWED_GUILDS\",\n\t\tallowedRoles: \"DISCORD_ALLOWED_ROLES\",\n\t\tallowedUsers: \"DISCORD_ALLOWED_USERS\",\n\t\tblockedUsers: \"DISCORD_BLOCKED_USERS\"\n\t})) if (secretEnv[envKey]) discord[field] = meta(envKey);\n\tconst slack = {};\n\tfor (const [field, envKey] of Object.entries({\n\t\tslackBotToken: \"SLACK_BOT_TOKEN\",\n\t\tslackAppToken: \"SLACK_APP_TOKEN\",\n\t\tallowedChannels: \"SLACK_ALLOWED_CHANNELS\",\n\t\tallowedUsers: \"SLACK_ALLOWED_USERS\",\n\t\tblockedUsers: \"SLACK_BLOCKED_USERS\"\n\t})) if (secretEnv[envKey]) slack[field] = meta(envKey);\n\tconst channelCredentials = {};\n\tif (Object.keys(discord).length > 0) channelCredentials.discord = discord;\n\tif (Object.keys(slack).length > 0) channelCredentials.slack = slack;\n\treturn json({\n\t\tok: true,\n\t\thasPassword: typeof configured === \"string\" && configured.length > 0,\n\t\timageTag: env.OP_IMAGE_TAG ?? \"\",\n\t\thostAkm,\n\t\tllm: akm.llm ? {\n\t\t\tprovider: akm.llm.provider ?? \"\",\n\t\t\tmodel: akm.llm.model ?? \"\",\n\t\t\tbaseUrl: deriveBaseUrl(akm.llm.endpoint)\n\t\t} : null,\n\t\tembedding: akm.embedding ? {\n\t\t\tprovider: akm.embedding.provider ?? \"\",\n\t\t\tmodel: akm.embedding.model ?? \"\",\n\t\t\tdims: akm.embedding.dimension ?? 0,\n\t\t\tbaseUrl: deriveBaseUrl(akm.embedding.endpoint)\n\t\t} : null,\n\t\tvoice: {\n\t\t\ttts: {\n\t\t\t\tengine: env.OP_TTS_ENGINE ?? \"\",\n\t\t\t\tbaseURL: env.OP_TTS_BASE_URL ?? \"\",\n\t\t\t\tmodel: env.OP_TTS_MODEL ?? \"\",\n\t\t\t\tvoice: env.OP_TTS_VOICE ?? \"\"\n\t\t\t},\n\t\t\tstt: {\n\t\t\t\tengine: env.OP_STT_ENGINE ?? \"\",\n\t\t\t\tbaseURL: env.OP_STT_BASE_URL ?? \"\",\n\t\t\t\tmodel: env.OP_STT_MODEL ?? \"\",\n\t\t\t\tlanguage: env.OP_STT_LANGUAGE ?? \"\"\n\t\t\t},\n\t\t\tprofiles: voiceProfiles,\n\t\t\tselectedProfile: selectedVoiceProfile\n\t\t},\n\t\tollama: {\n\t\t\tprofiles: ollamaProfiles,\n\t\t\tselectedProfile: selectedOllamaProfile\n\t\t},\n\t\tenabledAddons: listEnabledAddonIds(state.homeDir),\n\t\tchannelCredentials\n\t});\n};\n//#endregion\nexport { GET };\n"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"setup-deploy-D0Om28m3.js","sources":["../../../.svelte-kit/adapter-node/chunks/setup-deploy.js"],"sourcesContent":["import { C as buildManagedServices, E as buildComposeOptions, It as resolveStackDir, M as composePs, N as composePull, Nt as parseEnvFile, R as composeUp, Rt as createLogger, V as resolveComposeProjectName, Z as isSetupComplete, at as getAddonProfileSelection, ft as setAddonProfileSelection, k as composeDown, ot as getAddonProfiles, pt as addonProfileId, ut as listEnabledAddonIds, y as applyInstall, z as detectExistingProject } from \"./src.js\";\nimport { existsSync, readFileSync, renameSync, writeFileSync } from \"node:fs\";\n//#region src/lib/server/setup-deploy.ts\n/**\n* In-process deploy state for the setup wizard.\n*\n* Tracks Docker Compose deploy progress during first-time setup.\n* State lives in this module so the polling endpoint can read it\n* without a database or filesystem dependency.\n*/\nvar logger = createLogger(\"admin:setup-deploy\");\nfunction projectNameForState(state) {\n\treturn resolveComposeProjectName(parseEnvFile(`${state.stashDir}/env/stack.env`));\n}\nfunction projectNameForComposeOptions(composeOpts) {\n\treturn resolveComposeProjectName(Object.assign({}, ...(composeOpts.envFiles ?? []).map((f) => parseEnvFile(f))));\n}\nvar _state = {\n\tdeploying: false,\n\tsetupComplete: false,\n\tdeployStatus: [],\n\tdeployError: null,\n\tphase: \"writing-config\"\n};\nfunction getDeployState() {\n\tif (!_state.setupComplete && !_state.deploying && isSetupComplete(resolveStackDir())) _state.setupComplete = true;\n\treturn {\n\t\t..._state,\n\t\tdeployStatus: [..._state.deployStatus]\n\t};\n}\nfunction resetDeployState() {\n\t_state = {\n\t\tdeploying: false,\n\t\tsetupComplete: false,\n\t\tdeployStatus: [],\n\t\tdeployError: null,\n\t\tphase: \"writing-config\"\n\t};\n}\n/**\n* Resolve the effective OP_IMAGE_TAG for a deploy.\n* Reads exclusively from stack.env files — by the time startDeploy() runs,\n* applyInstall() has already written the wizard's chosen tag to stack.env.\n* Process env is intentionally ignored so shell variables can never silently\n* override what the user configured in the wizard.\n*/\nfunction resolveImageTag(composeOpts) {\n\tfor (const envFile of composeOpts.envFiles ?? []) {\n\t\tif (!existsSync(envFile)) continue;\n\t\tconst parsed = parseEnvFile(envFile);\n\t\tif (parsed.OP_IMAGE_TAG) return parsed.OP_IMAGE_TAG;\n\t}\n\treturn \"\";\n}\n/**\n* Map opaque Docker/compose stderr text to a human-friendly error message.\n* If no pattern matches, the raw message is returned prefixed with a generic header.\n*/\nfunction mapDockerError(raw) {\n\tif (/cannot connect to the docker daemon|docker daemon is not running/i.test(raw)) return \"Docker Desktop appears to have stopped. Start Docker, then click Retry.\";\n\tconst portMatch = /bind: address already in use.*?:(\\d+)/i.exec(raw);\n\tif (portMatch) return `Port ${portMatch[1]} is already in use by another program. Free it (or quit the other app) and click Retry.`;\n\tif (/Cannot find specified .* file|no such file or directory/i.test(raw)) return \"A required configuration file is missing. Try re-running setup.\";\n\tif (/permission denied/i.test(raw)) return \"Permission denied. Check that ~/.openpalm and Docker have permission to write.\";\n\tif (/no space left on device|ENOSPC/i.test(raw)) return \"Your disk is full. Free up space and click Retry.\";\n\treturn `Deployment ran into a problem: ${raw}`;\n}\n/**\n* Atomic-merge OP_SETUP_COMPLETE=true into stack.env. Called only after every\n* container has reported healthy — until then the wizard must remain\n* resumable, so the flag is intentionally not written by performSetup.\n*/\nfunction markSetupComplete(state) {\n\tconst path = `${state.stashDir}/env/stack.env`;\n\tconst lines = (existsSync(path) ? readFileSync(path, \"utf-8\") : \"\").split(\"\\n\");\n\tlet replaced = false;\n\tfor (let i = 0; i < lines.length; i++) {\n\t\tconst trimmed = lines[i].trimStart();\n\t\tconst eq = trimmed.indexOf(\"=\");\n\t\tif (eq > 0 && trimmed.slice(0, eq).trim() === \"OP_SETUP_COMPLETE\") {\n\t\t\tlines[i] = \"OP_SETUP_COMPLETE=true\";\n\t\t\treplaced = true;\n\t\t\tbreak;\n\t\t}\n\t}\n\tif (!replaced) if (lines.length > 0 && lines[lines.length - 1] === \"\") {\n\t\tlines[lines.length - 1] = \"OP_SETUP_COMPLETE=true\";\n\t\tlines.push(\"\");\n\t} else lines.push(\"OP_SETUP_COMPLETE=true\");\n\tlet merged = lines.join(\"\\n\");\n\tif (!merged.endsWith(\"\\n\")) merged += \"\\n\";\n\tconst tmp = `${path}.tmp`;\n\twriteFileSync(tmp, merged, { mode: 384 });\n\trenameSync(tmp, path);\n}\n/**\n* Parse `docker compose ps --format json` output into a list of container states.\n* Compose outputs one JSON object per line (NDJSON), not a JSON array.\n*/\nfunction parseComposePsOutput(stdout) {\n\tconst results = [];\n\tfor (const line of stdout.split(\"\\n\")) {\n\t\tconst trimmed = line.trim();\n\t\tif (!trimmed) continue;\n\t\ttry {\n\t\t\tconst obj = JSON.parse(trimmed);\n\t\t\tresults.push({\n\t\t\t\tname: String(obj[\"Name\"] ?? obj[\"Service\"] ?? \"\"),\n\t\t\t\tstate: String(obj[\"State\"] ?? \"\"),\n\t\t\t\thealth: String(obj[\"Health\"] ?? \"\")\n\t\t\t});\n\t\t} catch {}\n\t}\n\treturn results;\n}\n/**\n* Poll container health for `services` until all are running (and healthy if\n* they declare a healthcheck). Updates `_state.deployStatus` with intermediate\n* labels as containers flip states.\n*\n* @returns null on success, or an error string if timeout fires with unhealthy services.\n*/\nasync function pollContainerHealth(composeOpts, services, timeoutMs) {\n\tconst deadline = Date.now() + timeoutMs;\n\tconst POLL_INTERVAL_MS = 2e3;\n\twhile (Date.now() < deadline) {\n\t\tawait new Promise((r) => setTimeout(r, POLL_INTERVAL_MS));\n\t\tconst psResult = await composePs(composeOpts);\n\t\tif (!psResult.ok) {\n\t\t\tlogger.warn(\"composePs failed during health poll\", { stderr: psResult.stderr });\n\t\t\tcontinue;\n\t\t}\n\t\tconst containers = parseComposePsOutput(psResult.stdout);\n\t\t_state.deployStatus = _state.deployStatus.map((entry) => {\n\t\t\tconst found = containers.find((c) => c.name === entry.service || c.name.endsWith(`-${entry.service}-1`) || c.name.endsWith(`_${entry.service}_1`));\n\t\t\tif (!found) return {\n\t\t\t\t...entry,\n\t\t\t\tstatus: \"pending\",\n\t\t\t\tlabel: \"Starting...\"\n\t\t\t};\n\t\t\tif (found.state === \"running\") {\n\t\t\t\tconst health = found.health;\n\t\t\t\tif (health === \"unhealthy\") return {\n\t\t\t\t\t...entry,\n\t\t\t\t\tstatus: \"error\",\n\t\t\t\t\tlabel: \"Unhealthy\"\n\t\t\t\t};\n\t\t\t\tif (health === \"starting\") return {\n\t\t\t\t\t...entry,\n\t\t\t\t\tstatus: \"pending\",\n\t\t\t\t\tlabel: \"Health check running...\"\n\t\t\t\t};\n\t\t\t\treturn {\n\t\t\t\t\t...entry,\n\t\t\t\t\tstatus: \"running\",\n\t\t\t\t\tlabel: \"Running\"\n\t\t\t\t};\n\t\t\t}\n\t\t\tif (found.state === \"exited\" || found.state === \"dead\") return {\n\t\t\t\t...entry,\n\t\t\t\tstatus: \"error\",\n\t\t\t\tlabel: `Exited (${found.state})`\n\t\t\t};\n\t\t\treturn {\n\t\t\t\t...entry,\n\t\t\t\tstatus: \"pending\",\n\t\t\t\tlabel: `Starting (${found.state})...`\n\t\t\t};\n\t\t});\n\t\tif (services.every((svc) => {\n\t\t\treturn _state.deployStatus.find((e) => e.service === svc)?.status === \"running\";\n\t\t})) return null;\n\t\tconst failed = _state.deployStatus.filter((e) => e.status === \"error\").map((e) => e.service);\n\t\tif (failed.length > 0) {\n\t\t\tconst projectName = projectNameForComposeOptions(composeOpts);\n\t\t\treturn `Services started but the following did not become healthy: ${failed.join(\", \")}. Check logs: docker compose -p ${projectName} logs ${failed.join(\" \")}.`;\n\t\t}\n\t}\n\tconst unhealthy = _state.deployStatus.filter((e) => e.status !== \"running\").map((e) => e.service);\n\tconst projectName = projectNameForComposeOptions(composeOpts);\n\treturn `Services started but some did not become healthy in time: ${unhealthy.join(\", \")}. Check logs: docker compose -p ${projectName} logs ${unhealthy.join(\" \")}.`;\n}\n/**\n* Pre-flight: refuse to deploy if existing containers in this compose\n* project belong to a DIFFERENT OP_HOME than the one we're about to deploy.\n* Without this, two stacks (e.g. dev and host) that share the default\n* \"openpalm\" project name will silently clobber each other.\n*\n* Detection logic lives in lib (detectExistingProject) so the CLI and UI\n* share the same ours-vs-foreign decision (CLAUDE.md: control-plane logic\n* in lib). An existing OURS project is fine — startDeploy's down + force-recreate\n* reconciles it. Only a FOREIGN project produces a refusal.\n*/\nasync function checkProjectNameCollision(state) {\n\tconst projectName = projectNameForState(state);\n\tconst existing = await detectExistingProject({\n\t\tprojectName,\n\t\texpectedWorkingDir: state.homeDir\n\t});\n\tif (existing.exists && !existing.isOurs) return `Refusing to deploy: docker project \"${projectName}\" is already running from ${existing.workingDir || \"another OpenPalm install\"}, but this deploy would use OP_HOME=${state.homeDir}. Set OP_PROJECT_NAME to a distinct value in stack.env, or stop the existing stack first.`;\n\treturn null;\n}\n/** Kick off a background Docker Compose deploy. Returns immediately. */\nfunction startDeploy(state) {\n\tif (_state.deploying) {\n\t\t_state.deployError = \"install_in_progress: A deploy is already running. Wait for it to finish.\";\n\t\tlogger.warn(\"deploy rejected: deploy already in progress\");\n\t\treturn;\n\t}\n\t_state.deploying = true;\n\t_state.deployError = null;\n\t_state.phase = \"writing-config\";\n\t(async () => {\n\t\ttry {\n\t\t\tconst collision = await checkProjectNameCollision(state);\n\t\t\tif (collision) {\n\t\t\t\tlogger.error(\"deploy aborted: project name collision\", { error: collision });\n\t\t\t\t_state.deployError = collision;\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tawait applyInstall(state);\n\t\t\tif (listEnabledAddonIds(state.homeDir).includes(\"ollama\") && !getAddonProfileSelection(state.stackDir, \"ollama\")) try {\n\t\t\t\tsetAddonProfileSelection(state.stackDir, \"ollama\", addonProfileId(\"ollama\", \"cpu\"), state);\n\t\t\t} catch (err) {\n\t\t\t\tlogger.warn(\"ollama: failed to persist default profile selection (continuing)\", { error: err instanceof Error ? err.message : String(err) });\n\t\t\t}\n\t\t\tconst services = await buildManagedServices(state);\n\t\t\t_state.deployStatus = services.map((s) => ({\n\t\t\t\tservice: s,\n\t\t\t\tstatus: \"pending\",\n\t\t\t\tlabel: \"Waiting...\"\n\t\t\t}));\n\t\t\tconst composeOpts = buildComposeOptions(state);\n\t\t\ttry {\n\t\t\t\tconst downResult = await composeDown({\n\t\t\t\t\t...composeOpts,\n\t\t\t\t\tremoveVolumes: false\n\t\t\t\t});\n\t\t\t\tif (!downResult.ok) logger.info(\"pre-deploy compose down returned non-zero (likely nothing to remove)\", { stderr: downResult.stderr?.slice(0, 500) });\n\t\t\t} catch (err) {\n\t\t\t\tlogger.warn(\"pre-deploy compose down threw — continuing\", { error: err instanceof Error ? err.message : String(err) });\n\t\t\t}\n\t\t\t_state.phase = \"pulling-images\";\n\t\t\tconst imageTag = resolveImageTag(composeOpts);\n\t\t\tconst isDevTag = imageTag.startsWith(\"dev\");\n\t\t\tlet pullResult = null;\n\t\t\tif (!isDevTag) {\n\t\t\t\tconst pullDelaysMs = [\n\t\t\t\t\t0,\n\t\t\t\t\t5e3,\n\t\t\t\t\t15e3\n\t\t\t\t];\n\t\t\t\tfor (let attempt = 0; attempt < pullDelaysMs.length; attempt++) {\n\t\t\t\t\tif (pullDelaysMs[attempt] > 0) {\n\t\t\t\t\t\tlogger.info(\"retrying image pull\", {\n\t\t\t\t\t\t\tattempt: attempt + 1,\n\t\t\t\t\t\t\tdelayMs: pullDelaysMs[attempt]\n\t\t\t\t\t\t});\n\t\t\t\t\t\tawait new Promise((r) => setTimeout(r, pullDelaysMs[attempt]));\n\t\t\t\t\t}\n\t\t\t\t\tpullResult = await composePull(composeOpts);\n\t\t\t\t\tif (pullResult.ok) break;\n\t\t\t\t\tconst stderr = pullResult.stderr ?? \"\";\n\t\t\t\t\tif (/manifest unknown|manifest for .* not found|unauthorized|authentication required|access denied/i.test(stderr)) {\n\t\t\t\t\t\tlogger.error(\"image pull failed with permanent error\", { stderr: stderr.slice(0, 500) });\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tlogger.warn(\"image pull failed (transient?)\", {\n\t\t\t\t\t\tattempt: attempt + 1,\n\t\t\t\t\t\tstderr: stderr.slice(0, 500)\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (isDevTag || !pullResult || !pullResult.ok) if (await allServiceImagesPresent(composeOpts, services)) if (isDevTag) logger.info(\"dev image tag — skipping registry pull, all images present locally\", {\n\t\t\t\timageTag,\n\t\t\t\tservices\n\t\t\t});\n\t\t\telse logger.info(\"image pull failed but all images present locally — continuing\", {\n\t\t\t\tservices,\n\t\t\t\tstderrSlice: (pullResult?.stderr ?? \"\").slice(0, 200)\n\t\t\t});\n\t\t\telse {\n\t\t\t\tlet msg;\n\t\t\t\tif (isDevTag) {\n\t\t\t\t\tconst missing = await missingServiceImages(composeOpts, services);\n\t\t\t\t\tmsg = `Dev images not found locally (tag: ${imageTag}): ${missing.length > 0 ? missing.join(\", \") : \"one or more images\"}. Run \\`bun run dev:build\\` from the project root to build them, then retry setup.`;\n\t\t\t\t} else msg = mapDockerError(pullResult?.stderr?.trim() || \"Image pull failed\");\n\t\t\t\t_state.deployStatus = _state.deployStatus.map((e) => ({\n\t\t\t\t\t...e,\n\t\t\t\t\tstatus: \"error\",\n\t\t\t\t\tlabel: \"Image pull failed\"\n\t\t\t\t}));\n\t\t\t\t_state.deployError = msg;\n\t\t\t\treturn;\n\t\t\t}\n\t\t\t_state.phase = \"starting\";\n\t\t\t_state.deployStatus = _state.deployStatus.map((e) => ({\n\t\t\t\t...e,\n\t\t\t\tstatus: \"pending\",\n\t\t\t\tlabel: \"Starting...\"\n\t\t\t}));\n\t\t\tconst result = await composeUp({\n\t\t\t\t...composeOpts,\n\t\t\t\tforceRecreate: true,\n\t\t\t\tremoveOrphans: true\n\t\t\t});\n\t\t\tif (!result.ok) {\n\t\t\t\tconst msg = mapDockerError(result.stderr ?? \"compose up failed\");\n\t\t\t\t_state.deployStatus = _state.deployStatus.map((e) => ({\n\t\t\t\t\t...e,\n\t\t\t\t\tstatus: \"error\",\n\t\t\t\t\tlabel: msg\n\t\t\t\t}));\n\t\t\t\t_state.deployError = msg;\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tconst healthError = await pollContainerHealth(composeOpts, services, 5 * 6e4);\n\t\t\tif (healthError) {\n\t\t\t\t_state.deployError = healthError;\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tconst voiceError = await bringUpVoiceIfEnabled(state, composeOpts);\n\t\t\tif (voiceError) {\n\t\t\t\t_state.deployError = voiceError;\n\t\t\t\treturn;\n\t\t\t}\n\t\t\ttry {\n\t\t\t\tmarkSetupComplete(state);\n\t\t\t} catch (err) {\n\t\t\t\tlogger.error(\"failed to persist OP_SETUP_COMPLETE after healthy deploy\", { error: err instanceof Error ? err.message : String(err) });\n\t\t\t\t_state.deployError = \"Deployment succeeded but failed to mark setup complete. Try Retry; if it persists, check disk space and permissions on knowledge/env/stack.env.\";\n\t\t\t\treturn;\n\t\t\t}\n\t\t\t_state.setupComplete = true;\n\t\t\t_state.phase = \"ready\";\n\t\t} catch (err) {\n\t\t\tconst raw = String(err);\n\t\t\tconst msg = mapDockerError(raw);\n\t\t\tlogger.error(\"deploy failed\", { error: raw });\n\t\t\t_state.deployStatus = _state.deployStatus.map((e) => ({\n\t\t\t\t...e,\n\t\t\t\tstatus: \"error\",\n\t\t\t\tlabel: msg\n\t\t\t}));\n\t\t\t_state.deployError = msg;\n\t\t} finally {\n\t\t\t_state.deploying = false;\n\t\t}\n\t})();\n}\nvar VOICE_ADDON = \"voice\";\nvar VOICE_HEALTH_TIMEOUT_MS = 10 * 6e4;\n/**\n* Return the image names for services whose images are NOT present on the\n* local Docker daemon. Used to build actionable error messages.\n*/\nasync function missingServiceImages(composeOpts, services) {\n\tif (services.length === 0) return [];\n\tconst { execFile } = await import(\"node:child_process\");\n\tconst args = [\n\t\t\"compose\",\n\t\t...composeOpts.files.flatMap((f) => [\"-f\", f]),\n\t\t...(composeOpts.envFiles ?? []).filter((f) => existsSync(f)).flatMap((f) => [\"--env-file\", f]),\n\t\t...composeOpts.profiles.flatMap((p) => [\"--profile\", p]),\n\t\t\"config\",\n\t\t\"--format\",\n\t\t\"json\"\n\t];\n\tconst serviceConfig = (await new Promise((resolve) => {\n\t\texecFile(\"docker\", args, { timeout: 3e4 }, (err, stdout) => {\n\t\t\tif (err) return resolve({});\n\t\t\ttry {\n\t\t\t\tresolve(JSON.parse(stdout.toString()));\n\t\t\t} catch {\n\t\t\t\tresolve({});\n\t\t\t}\n\t\t});\n\t})).services ?? {};\n\tconst missing = [];\n\tfor (const svc of services) {\n\t\tconst image = serviceConfig[svc]?.image;\n\t\tif (!image) {\n\t\t\tmissing.push(`${svc} (image unknown)`);\n\t\t\tcontinue;\n\t\t}\n\t\tif (!await new Promise((resolve) => {\n\t\t\texecFile(\"docker\", [\n\t\t\t\t\"image\",\n\t\t\t\t\"inspect\",\n\t\t\t\timage\n\t\t\t], { timeout: 5e3 }, (err) => resolve(!err));\n\t\t})) missing.push(image);\n\t}\n\treturn missing;\n}\n/**\n* Resolve each service's image via `docker compose config` and verify\n* `docker image inspect` finds it locally. Lets the deploy proceed\n* after a registry-pull failure when the operator has the images\n* cached (e.g. dev mode with locally-built `:dev` tags). Returns false\n* on any service whose image we can't confirm is present, including\n* services with no resolvable image and any docker-side error.\n*/\nasync function allServiceImagesPresent(composeOpts, services) {\n\tif (services.length === 0) return false;\n\tconst { execFile } = await import(\"node:child_process\");\n\tconst args = [\n\t\t\"compose\",\n\t\t...composeOpts.files.flatMap((f) => [\"-f\", f]),\n\t\t...(composeOpts.envFiles ?? []).filter((f) => existsSync(f)).flatMap((f) => [\"--env-file\", f]),\n\t\t...composeOpts.profiles.flatMap((p) => [\"--profile\", p]),\n\t\t\"config\",\n\t\t\"--format\",\n\t\t\"json\"\n\t];\n\tconst serviceConfig = (await new Promise((resolve) => {\n\t\texecFile(\"docker\", args, { timeout: 3e4 }, (err, stdout) => {\n\t\t\tif (err) return resolve({});\n\t\t\ttry {\n\t\t\t\tresolve(JSON.parse(stdout.toString()));\n\t\t\t} catch {\n\t\t\t\tresolve({});\n\t\t\t}\n\t\t});\n\t})).services ?? {};\n\tfor (const svc of services) {\n\t\tconst image = serviceConfig[svc]?.image;\n\t\tif (!image) return false;\n\t\tif (!await new Promise((resolve) => {\n\t\t\texecFile(\"docker\", [\n\t\t\t\t\"image\",\n\t\t\t\t\"inspect\",\n\t\t\t\timage\n\t\t\t], { timeout: 5e3 }, (err) => {\n\t\t\t\tresolve(!err);\n\t\t\t});\n\t\t})) return false;\n\t}\n\treturn true;\n}\n/**\n* Pull + bring up the voice addon's chosen profile if\n* the addon is enabled. Runs after the core stack is healthy so the\n* deploy progress UI shows voice as a distinct phase (\"starting-voice\")\n* with its own status row.\n*\n* Returns null on success or a user-friendly error string on failure.\n* The caller surfaces the error via _state.deployError.\n*/\nasync function bringUpVoiceIfEnabled(state, composeOpts) {\n\tif (!listEnabledAddonIds(state.homeDir).includes(VOICE_ADDON)) return null;\n\tconst profiles = getAddonProfiles(state.homeDir, VOICE_ADDON);\n\tconst stored = getAddonProfileSelection(state.stackDir, VOICE_ADDON);\n\tconst profileId = stored ?? profiles.find((p) => p.id === addonProfileId(VOICE_ADDON, \"cpu\"))?.id ?? profiles[0]?.id ?? addonProfileId(VOICE_ADDON, \"cpu\");\n\tif (!stored) try {\n\t\tsetAddonProfileSelection(state.stackDir, VOICE_ADDON, profileId, state);\n\t} catch (err) {\n\t\tlogger.warn(\"voice: failed to persist profile selection (continuing)\", { error: err instanceof Error ? err.message : String(err) });\n\t}\n\tconst profileServices = profiles.find((p) => p.id === profileId)?.services ?? [];\n\tif (profileServices.length === 0) {\n\t\tlogger.warn(\"voice: no services found for chosen profile (skipping)\", { profileId });\n\t\treturn null;\n\t}\n\t_state.phase = \"starting-voice\";\n\t_state.deployStatus = [..._state.deployStatus, ...profileServices.map((svc) => ({\n\t\tservice: svc,\n\t\tstatus: \"pending\",\n\t\tlabel: \"Voice — starting container…\"\n\t}))];\n\tconst upResult = await composeUp({\n\t\t...composeOpts,\n\t\tservices: profileServices,\n\t\tprofiles: [profileId],\n\t\tforceRecreate: true\n\t});\n\tif (!upResult.ok) {\n\t\tconst msg = mapDockerError(upResult.stderr ?? \"Voice container failed to start\");\n\t\t_state.deployStatus = _state.deployStatus.map((e) => profileServices.includes(e.service) ? {\n\t\t\t...e,\n\t\t\tstatus: \"error\",\n\t\t\tlabel: msg\n\t\t} : e);\n\t\treturn `Voice addon: ${msg}`;\n\t}\n\tconst probeUrl = \"http://127.0.0.1:8880/health\";\n\tconst deadline = Date.now() + VOICE_HEALTH_TIMEOUT_MS;\n\tlet healthy = false;\n\twhile (Date.now() < deadline) {\n\t\ttry {\n\t\t\tif ((await fetch(probeUrl, { signal: AbortSignal.timeout(1500) })).ok) {\n\t\t\t\thealthy = true;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t} catch {}\n\t\tawait new Promise((r) => setTimeout(r, 2e3));\n\t}\n\tif (!healthy) {\n\t\t_state.deployStatus = _state.deployStatus.map((e) => profileServices.includes(e.service) ? {\n\t\t\t...e,\n\t\t\tstatus: \"warning\",\n\t\t\tlabel: \"Voice is still warming up. You can finish setup; check the Voice tab in admin.\"\n\t\t} : e);\n\t\tlogger.warn(\"voice: container did not become healthy in time\", { timeoutMs: VOICE_HEALTH_TIMEOUT_MS });\n\t\treturn null;\n\t}\n\t_state.deployStatus = _state.deployStatus.map((e) => profileServices.includes(e.service) ? {\n\t\t...e,\n\t\tstatus: \"running\",\n\t\tlabel: \"Voice — ready\"\n\t} : e);\n\treturn null;\n}\n//#endregion\nexport { resetDeployState as n, startDeploy as r, getDeployState as t };\n"],"names":[],"mappings":"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"}
|