@chaibuilder/pages 0.16.13 → 0.16.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (83) hide show
  1. package/dist/{2AITGKQY-D1mM4eEh.js → 2AITGKQY-B7xwscsX.js} +2 -2
  2. package/dist/{2AITGKQY-AK2WgbeT.cjs → 2AITGKQY-B9AnRLq_.cjs} +1 -1
  3. package/dist/{NCMVHL6D-BeRsWdGV.js → NCMVHL6D-B1mwht0Q.js} +4 -4
  4. package/dist/{NCMVHL6D-DItDf9IY.cjs → NCMVHL6D-CRMC-wXy.cjs} +1 -1
  5. package/dist/{ZDWCUMSJ-COSBY-at.cjs → ZDWCUMSJ-BqqPEOij.cjs} +1 -1
  6. package/dist/{ZDWCUMSJ-D6caRaY7.js → ZDWCUMSJ-CxKNtXtp.js} +1 -1
  7. package/dist/{add-new-language-page-CQcFi0Tp.cjs → add-new-language-page-D2a6GK-7.cjs} +1 -1
  8. package/dist/{add-new-language-page-nnaUe-qk.js → add-new-language-page-DD0qvJJs.js} +2 -2
  9. package/dist/{add-new-page-DxObnvo_.cjs → add-new-page-01GDCaa4.cjs} +1 -1
  10. package/dist/{add-new-page-Ba1fq6LH.js → add-new-page-CYtuChN1.js} +1 -1
  11. package/dist/ai-panel-content-DfdnvlS8.js +123 -0
  12. package/dist/ai-panel-content-Ouz6pu_0.cjs +1 -0
  13. package/dist/ai-panel-default-lang-Bi2fH1so.js +317 -0
  14. package/dist/ai-panel-default-lang-N1pb8rzQ.cjs +3 -0
  15. package/dist/{ai-panel-other-lang-B4euTuod.js → ai-panel-other-lang-2JPRSyO1.js} +10 -9
  16. package/dist/ai-panel-other-lang-BysU1464.cjs +1 -0
  17. package/dist/ai-prompt-input-DadL_cng.js +1071 -0
  18. package/dist/ai-prompt-input-JeIqWZco.cjs +1 -0
  19. package/dist/{ai-translation-prompt-CVuPbgXw.js → ai-translation-prompt-B0si-R0R.js} +1 -1
  20. package/dist/{ai-translation-prompt-Ip7w2_Ey.cjs → ai-translation-prompt-CQb1L7NM.cjs} +1 -1
  21. package/dist/{delete-page-CbY8q5M3.cjs → delete-page-C8Nt7IYF.cjs} +1 -1
  22. package/dist/{delete-page-SX9X35nA.js → delete-page-_96Di9yN.js} +1 -1
  23. package/dist/{digital-asset-manager-CIMo79Di.cjs → digital-asset-manager-B5FQGtGY.cjs} +1 -1
  24. package/dist/{digital-asset-manager-SAFNO_mx.js → digital-asset-manager-jfnmWRJj.js} +1 -1
  25. package/dist/{duplicate-page-CXK2HcxD.cjs → duplicate-page-BNjfZ7Wd.cjs} +1 -1
  26. package/dist/{duplicate-page-5SwLvmkX.js → duplicate-page-CERjaPIW.js} +9 -9
  27. package/dist/{dynamic-page-selector-Crd3y4Hk.cjs → dynamic-page-selector-Bpz_bvRu.cjs} +1 -1
  28. package/dist/{dynamic-page-selector-DfcuTqRN.js → dynamic-page-selector-XEWV4iCf.js} +1 -1
  29. package/dist/{index-Bz7smSC0.cjs → index-Pdb5tSRL.cjs} +2 -2
  30. package/dist/{index-EnM7J19_.js → index-e9WlBH0R.js} +70 -70
  31. package/dist/index.cjs +1 -1
  32. package/dist/index.js +4 -4
  33. package/dist/{json-diff-viewer-CDwpbuag.js → json-diff-viewer-DyvKomxd.js} +1 -1
  34. package/dist/{json-diff-viewer-D34kDA_c.cjs → json-diff-viewer-H-2DkGza.cjs} +1 -1
  35. package/dist/{lang-panel-CUIeO5bb.js → lang-panel-BWP5A-FD.js} +2 -2
  36. package/dist/{lang-panel-CaFrYllL.cjs → lang-panel-DcZ7u4em.cjs} +1 -1
  37. package/dist/{mark-as-template-D0dLQaIB.js → mark-as-template-1oVraE1x.js} +1 -1
  38. package/dist/{mark-as-template-v182tmN6.cjs → mark-as-template-B_FyVRRO.cjs} +1 -1
  39. package/dist/{no-language-page-content-ByRFD_qA.js → no-language-page-content-CEci_4j7.js} +1 -1
  40. package/dist/{no-language-page-content-Bk4fEx_p.cjs → no-language-page-content-JO4YYUx7.cjs} +1 -1
  41. package/dist/{page-creator-BnvaGZVI.cjs → page-creator-BGgoOA92.cjs} +1 -1
  42. package/dist/{page-creator-Bh0IUGR3.js → page-creator-DJJFl7px.js} +2 -2
  43. package/dist/{page-lock-request-C2b1kqyA.cjs → page-lock-request-BoYzkcyt.cjs} +1 -1
  44. package/dist/{page-lock-request-CaNqxfD6.js → page-lock-request-WzpcD2ZN.js} +6 -6
  45. package/dist/{page-locked-by-dialog--WLDdkw9.js → page-locked-by-dialog-Djvjp2Hx.js} +1 -1
  46. package/dist/{page-locked-by-dialog-90ElC8aG.cjs → page-locked-by-dialog-bvI27OZ6.cjs} +1 -1
  47. package/dist/{page-manager-new-SNRQn7Az.cjs → page-manager-new-CMfGorRQ.cjs} +1 -1
  48. package/dist/{page-manager-new-Bo4-zwfW.js → page-manager-new-DmVX0qLk.js} +14 -14
  49. package/dist/{page-manager-search-and-filter-BETHSa3y.js → page-manager-search-and-filter-DbUoW8Di.js} +1 -1
  50. package/dist/{page-manager-search-and-filter-hyUIHOD_.cjs → page-manager-search-and-filter-Dgh8iyGp.cjs} +1 -1
  51. package/dist/{page-revisions-content-BCMjvZRZ.cjs → page-revisions-content-CwoXXE53.cjs} +1 -1
  52. package/dist/{page-revisions-content-VWthKL7O.js → page-revisions-content-CxEJGxLY.js} +18 -18
  53. package/dist/pages.css +1 -1
  54. package/dist/{publish-pages-content-CaBwfekc.cjs → publish-pages-content-BRu7qwAo.cjs} +1 -1
  55. package/dist/{publish-pages-content-6N7aEcM1.js → publish-pages-content-CfAlmivf.js} +6 -6
  56. package/dist/{save-to-lib-YYBxY7MV.js → save-to-lib-BCaBfh0I.js} +1 -1
  57. package/dist/{save-to-lib-CtGpDkC6.cjs → save-to-lib-DpyJA0y1.cjs} +1 -1
  58. package/dist/{selected-block-display-DdW-DWF1.js → selected-block-display-BmNhvYKu.js} +1 -1
  59. package/dist/{selected-block-display-BEbuJn0l.cjs → selected-block-display-CqnwyGRp.cjs} +1 -1
  60. package/dist/{seo-panel-CqJDhbj-.js → seo-panel-BH8fcGqr.js} +1 -1
  61. package/dist/{seo-panel-B9P7fXjo.cjs → seo-panel-D-nKfsRJ.cjs} +1 -1
  62. package/dist/server.cjs +1 -1
  63. package/dist/server.js +39 -39
  64. package/dist/{shared-json-ld-CyxmC9y5.cjs → shared-json-ld-m_OsVv8h.cjs} +1 -1
  65. package/dist/{shared-json-ld-DxEPILj_.js → shared-json-ld-zTDoJzUv.js} +1 -1
  66. package/dist/{slug-input-j5z5ZQn9.js → slug-input-CumDDlCk.js} +1 -1
  67. package/dist/{slug-input-RNiSrU3p.cjs → slug-input-vzNtu37S.cjs} +1 -1
  68. package/dist/{theme-panel-footer-CCsiDIVl.cjs → theme-panel-footer-CKccBcd9.cjs} +1 -1
  69. package/dist/{theme-panel-footer-DD2yalfG.js → theme-panel-footer-CdUmjB-e.js} +1 -1
  70. package/dist/{unmark-as-template-B2hKhAHn.js → unmark-as-template-6ew-7bf8.js} +1 -1
  71. package/dist/{unmark-as-template-DXjLbqOM.cjs → unmark-as-template-BNFOsxIg.cjs} +1 -1
  72. package/dist/{unpublish-page-BdJScWMX.cjs → unpublish-page-BZQpTpU3.cjs} +1 -1
  73. package/dist/{unpublish-page-BvB1PGSz.js → unpublish-page-BomE76Wg.js} +1 -1
  74. package/dist/{web-preview-BI4jd0O7.cjs → web-preview-C5QTX7bS.cjs} +1 -1
  75. package/dist/{web-preview-CwVpkcwU.js → web-preview-jo8lnpEx.js} +1 -1
  76. package/package.json +1 -1
  77. package/dist/ai-panel-content-B2AgBWqo.cjs +0 -1
  78. package/dist/ai-panel-content-M1UnzG_f.js +0 -54
  79. package/dist/ai-panel-default-lang-CHOFEwmV.js +0 -313
  80. package/dist/ai-panel-default-lang-sy6vkQJh.cjs +0 -3
  81. package/dist/ai-panel-other-lang-BwjSDD3L.cjs +0 -1
  82. package/dist/ai-prompt-input-B_NRADBT.js +0 -988
  83. package/dist/ai-prompt-input-DcyVXcLG.cjs +0 -1
@@ -1,7 +1,7 @@
1
1
  var xs = Object.defineProperty;
2
2
  var ws = (e, t, n) => t in e ? xs(e, t, { enumerable: !0, configurable: !0, writable: !0, value: n }) : e[t] = n;
3
3
  var _e = (e, t, n) => ws(e, typeof t != "symbol" ? t + "" : t, n);
4
- import { w as Vn, x as jn, y as K, z as sr, C as H, v as y, D as W, E as oe, S as R, s as O, F as $e, G as Ce, H as G, I as A, J as He, K as ft, M as ve, P as Ro, N as V, O as $s, Q as P, R as wt, U as un, V as k, W as T, X as Cs, Y as Kt, Z as Ss, _ as ks, $ as Cn, a0 as Es, a1 as Ds, a2 as Ms, a3 as Nt, a4 as As, a5 as Ts, a6 as Fs, a7 as ar, a8 as Hr, a9 as qs, aa as _t, ab as Ko, ac as Ur, ad as Is, ae as Os, af as Kn, ag as Ls, ah as Ps, ai as _s } from "./index-EnM7J19_.js";
4
+ import { v as Vn, w as jn, x as K, y as sr, z as H, s as y, C as W, D as oe, S as R, r as O, E as $e, F as Ce, G, H as A, I as He, J as ft, K as ve, P as Ro, M as V, N as $s, O as P, Q as wt, R as un, U as k, V as T, W as Cs, X as Kt, Y as Ss, Z as ks, _ as Cn, $ as Es, a0 as Ds, a1 as Ms, a2 as Nt, a3 as As, a4 as Ts, a5 as Fs, a6 as ar, a7 as Hr, a8 as qs, a9 as _t, aa as Ko, ab as Ur, ac as Is, ad as Os, ae as Kn, af as Ls, ag as Ps, ah as _s } from "./index-e9WlBH0R.js";
5
5
  var zs = (e) => e != null, Rs = (e) => e.filter(zs);
6
6
  function Ks(e) {
7
7
  return (...t) => {
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),V=require("./slug-input-RNiSrU3p.cjs"),f=require("./index-Bz7smSC0.cjs"),w=require("@chaibuilder/sdk"),S=require("@chaibuilder/sdk/ui"),Y=require("lodash-es"),is=require("lucide-react"),N=require("react"),X=({edit:c,lang:h,languages:a,name:u,setLang:t,setName:i,primaryPageObject:o})=>{const{t:s}=w.useTranslation();return e.jsxs("div",{className:"space-y-1",children:[e.jsx(S.Label,{htmlFor:"lang",children:s("Language")}),e.jsxs("select",{value:c?"":h,disabled:c||!a.length,onChange:l=>{const x=l.target.value;t(x),!c&&(Y.startsWith(u,o==null?void 0:o.name)||u.length===0)&&i(`${o==null?void 0:o.name} - ${f.LANGUAGES[x]}`)},className:"col-span-3 flex h-9 w-full rounded-md border border-border bg-background px-3 py-1 text-sm shadow-sm transition-colors file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50",children:[e.jsx("option",{value:"",disabled:!0,children:c?f.LANGUAGES[h]||h:a.length?s("Choose language"):s("All available language page is created.")}),a.map(l=>e.jsx("option",{value:l,children:f.LANGUAGES[l]||l},l))]})]})},Z=({lang:c,name:h,setName:a,parentHasSelectedLanguagePage:u})=>{const{t}=w.useTranslation();return e.jsxs("div",{className:"space-y-1",children:[e.jsx(S.Label,{htmlFor:"name",children:t("Page Name")}),e.jsx(S.Input,{id:"name",value:c?h:"",onChange:i=>a(i.target.value),required:!0,placeholder:t(c?"Enter page name":"Choose language to add slug"),disabled:!u||!c})]})},ds=({dynamic:c,isNonSlugPageType:h,isRootPage:a,lang:u,useLanguagePrefix:t,setUseLanguagePrefix:i,isHomePage:o,parentSlug:s,parentHasSelectedLanguagePage:l,slug:x,setSlug:d,setIsSlugValid:m,getSlug:g})=>{const{t:r}=w.useTranslation();return h?null:e.jsxs("div",{className:"space-y-1",children:[a&&u&&e.jsxs("div",{className:"flex items-center space-x-2 pb-1",children:[e.jsx("input",{type:"checkbox",id:"useLanguagePrefix",checked:t,onChange:A=>i(A.target.checked),className:"rounded border-gray-300"}),e.jsxs(S.Label,{htmlFor:"useLanguagePrefix",className:"text-sm font-normal leading-tight",children:["Add language code (",e.jsxs("span",{className:"font-mono text-gray-900",children:["/",u]}),") as slug prefix"]})]}),e.jsx(S.Label,{htmlFor:"slug",children:r("Slug")}),c?e.jsx(S.Alert,{variant:"default",className:"p-2 text-xs font-medium italic text-muted-foreground",children:r("This page will use dynamic slug as defined in primary page")}):e.jsx(V.SlugInput,{disabled:!u||!l,value:x,onChange:d,placeholder:r(u?o&&t?"Leave empty for home page":"Enter page slug":"Choose language to add slug"),parentSlug:s,onValidationChange:m,fullSlug:g()})]})},_=({parentHasSelectedLanguagePage:c,name:h,lang:a,slug:u,edit:t,id:i,primaryPageObject:o,pages:s,isNonSlugPageType:l,isHomePage:x,useLanguagePrefix:d,isSlugValid:m,isPending:g})=>{const{t:r}=w.useTranslation(),A=g||!h||!a||s.some(v=>(t?v.id!==i:!0)&&v.parent===(o==null?void 0:o.id)&&v.lang===a)||!l&&!(x&&d)&&(!m||!u);return e.jsx(S.DialogFooter,{children:c?e.jsxs(e.Fragment,{children:[e.jsx(S.Button,{type:"submit",disabled:A&&!o.dynamic,children:g?e.jsxs("span",{className:"flex items-center gap-2",children:[e.jsx("span",{className:"loader mr-2"}),r(t?"Updating...":"Adding...")]}):r(t?"Update":"Add new language page")}),s.some(v=>(t?v.id!==i:!0)&&v.parent===(o==null?void 0:o.id)&&v.lang===a)&&e.jsx("p",{className:"mt-2 text-xs text-red-500",children:r("A page for this language already exists.")})]}):a&&e.jsx(S.Alert,{variant:"destructive",children:e.jsxs("p",{className:"mx-auto w-5/6 text-center",children:[r("You need to create the")," ",e.jsx("span",{className:"font-medium",children:f.LANGUAGES[a]})," ",r("page in the parent to add here.")]})})})},cs=({onSubmit:c,edit:h,lang:a,languages:u,name:t,setLang:i,setName:o,primaryPageObject:s,parentHasSelectedLanguagePage:l,id:x,pages:d,isNonSlugPageType:m,isHomePage:g,useLanguagePrefix:r,slug:A,isSlugValid:v,isPending:E})=>e.jsxs("form",{onSubmit:c,children:[e.jsxs("div",{className:"grid gap-4 py-4",children:[e.jsx(X,{edit:h,lang:a,languages:u,name:t,setLang:i,setName:o,primaryPageObject:s}),e.jsx(Z,{lang:a,name:t,setName:o,parentHasSelectedLanguagePage:l})]}),e.jsx(_,{parentHasSelectedLanguagePage:l,name:t,lang:a,slug:A,edit:h,id:x,primaryPageObject:s,pages:d,isNonSlugPageType:m,isHomePage:g,useLanguagePrefix:r,isSlugValid:v,isPending:E})]}),rs=({loading:c,onSubmit:h,edit:a,lang:u,languages:t,name:i,setLang:o,setName:s,primaryPageObject:l,parentHasSelectedLanguagePage:x,isNonSlugPageType:d,isRootPage:m,useLanguagePrefix:g,setUseLanguagePrefix:r,isHomePage:A,parentSlug:v,slug:E,setSlug:C,isSlugValid:T,setIsSlugValid:R,getSlug:M,isPending:$,id:D,pages:L})=>c?e.jsx("div",{className:"flex h-80 items-center justify-center",children:e.jsx(is.Loader,{className:"animate-spin"})}):d?e.jsx(cs,{onSubmit:h,edit:a,lang:u,languages:t,name:i,setLang:o,setName:s,primaryPageObject:l,parentHasSelectedLanguagePage:x,id:D,pages:L,isNonSlugPageType:d,isHomePage:A,useLanguagePrefix:g,slug:E,isSlugValid:T,isPending:$}):e.jsxs("form",{onSubmit:h,children:[e.jsxs("div",{className:"grid gap-4 py-4",children:[e.jsx(X,{edit:a,lang:u,languages:t,name:i,setLang:o,setName:s,primaryPageObject:l}),e.jsx(Z,{lang:u,name:i,setName:s,parentHasSelectedLanguagePage:x}),e.jsx(ds,{dynamic:l==null?void 0:l.dynamic,isNonSlugPageType:d,isRootPage:m,lang:u,useLanguagePrefix:g,setUseLanguagePrefix:r,isHomePage:A,parentSlug:v,parentHasSelectedLanguagePage:x,slug:E,setSlug:C,isSlugValid:T,setIsSlugValid:R,getSlug:M})]}),e.jsx(_,{parentHasSelectedLanguagePage:x,name:i,lang:u,slug:E,edit:a,id:D,primaryPageObject:l,pages:L,isNonSlugPageType:d,isHomePage:A,useLanguagePrefix:g,isSlugValid:T,isPending:$})]}),hs=({id:c,isOpen:h,onClose:a,primaryPage:u,edit:t=!1,preselectedLang:i})=>{const{data:o=[]}=f.useWebsitePages(),s=N.useMemo(()=>o.find(n=>n.id===u),[o,u]),[l,x]=N.useState(""),[d,m]=N.useState(""),[g,r]=N.useState(""),[A,v]=N.useState(!0),[E,C]=N.useState(!0),{mutate:T,isPending:R}=f.useCreatePage(),{mutate:M,isPending:$}=f.useUpdatePage(),D=R||$,{data:L,isFetching:H}=f.useWebsiteSetting(),j=f.useFallbackLang(),{data:G,isFetching:b}=f.useLanguagePages(u),{data:F=[],isFetching:y}=f.useLanguagePages(s==null?void 0:s.parent),{data:z=[],isFetching:P}=f.usePageTypes(),{setSelectedLang:O}=w.useLanguages(),{t:I}=w.useTranslation(),[,ss]=f.useSearchParams(),[,es]=w.useSidebarActivePanel(),ns=H||b||y||P,U=N.useMemo(()=>Y.filter(L==null?void 0:L.languages,n=>!Y.find(G,{lang:n})),[L,G]),W=N.useMemo(()=>z.find(n=>n.key===(s==null?void 0:s.pageType)),[z,s==null?void 0:s.pageType]),J=!(W!=null&&W.hasSlug),B=(s==null?void 0:s.slug)==="/";N.useEffect(()=>{if(!t&&s&&i&&(m(i),x(`${s.name} - ${f.LANGUAGES[i]}`)),!t||!s)return;const n=G==null?void 0:G.find(us=>us.id===c);if(!n)return;x(n.name),m(n.lang);const p=n.slug||"",{initSlug:k,prefix:as}=V.parseSlugForEdit(p,s);r(k),C(as)},[t,c,G,s,i]),N.useEffect(()=>{if(i)m(i);else if((U==null?void 0:U.length)===1&&!t){const n=U[0];if(!n||!f.LANGUAGES[n])return;m(n),(!l||l===(s==null?void 0:s.name))&&x(`${s==null?void 0:s.name} - ${f.LANGUAGES[n]}`)}},[i,U,t,l,s]);const{parentSlug:K,isRootPage:q}=N.useMemo(()=>{if(B||!d)return{parentSlug:void 0,isRootPage:!(s!=null&&s.parent)};if(!(s!=null&&s.parent))return{parentSlug:E?`/${d}`:void 0,isRootPage:!0};const n=F==null?void 0:F.find(p=>p.lang===d);return{parentSlug:n==null?void 0:n.slug,isRootPage:!1}},[s==null?void 0:s.parent,F,E,d,B]),ts=N.useMemo(()=>q?!0:!!(F!=null&&F.some(n=>(n==null?void 0:n.lang)===d)),[d,F,q]),Q=()=>{let n="";return q?n=`/${E?[d,g].filter(Boolean).join("/"):g}`:n=`${V.removeSlugExtension(K)}/${g}`,n.replace(/\/{2,}/g,"/").replace(/\/$/,"")},os=n=>{const p=new URLSearchParams(window.location.search);j&&n===j?p.delete("lang"):p.set("lang",n),ss(p),window.dispatchEvent(new PopStateEvent("popstate"))},ls=n=>{n.preventDefault();const p={name:l,lang:d,primaryPage:s==null?void 0:s.id,slug:J?"":Q(),pageType:s==null?void 0:s.pageType,...t&&{id:c}},k=()=>{!t&&d&&(O(d),os(d)),es("outline"),a()};t?M(p,{onSuccess:k}):T(p,{onSuccess:k})};return e.jsx(S.Dialog,{open:h,onOpenChange:a,children:h&&e.jsxs(S.DialogContent,{className:"text-slate-600 sm:max-w-[425px]",children:[e.jsxs(S.DialogHeader,{children:[e.jsx(S.DialogTitle,{children:I(t?"Edit language":"Add new language page")}),e.jsx(S.DialogDescription,{className:"font-light",children:I("Enter the details for the language")})]}),e.jsx(rs,{id:c,pages:o,loading:ns,onSubmit:ls,edit:t,lang:d,languages:U,name:l,setLang:m,setName:x,primaryPageObject:s,parentHasSelectedLanguagePage:ts,isNonSlugPageType:J,isRootPage:q,useLanguagePrefix:E,setUseLanguagePrefix:C,isHomePage:B,parentSlug:K,slug:g,setSlug:r,isSlugValid:A,setIsSlugValid:v,getSlug:Q,isPending:D})]})})};exports.default=hs;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),V=require("./slug-input-vzNtu37S.cjs"),f=require("./index-Pdb5tSRL.cjs"),w=require("@chaibuilder/sdk"),S=require("@chaibuilder/sdk/ui"),Y=require("lodash-es"),is=require("lucide-react"),N=require("react"),X=({edit:c,lang:h,languages:a,name:u,setLang:t,setName:i,primaryPageObject:o})=>{const{t:s}=w.useTranslation();return e.jsxs("div",{className:"space-y-1",children:[e.jsx(S.Label,{htmlFor:"lang",children:s("Language")}),e.jsxs("select",{value:c?"":h,disabled:c||!a.length,onChange:l=>{const x=l.target.value;t(x),!c&&(Y.startsWith(u,o==null?void 0:o.name)||u.length===0)&&i(`${o==null?void 0:o.name} - ${f.LANGUAGES[x]}`)},className:"col-span-3 flex h-9 w-full rounded-md border border-border bg-background px-3 py-1 text-sm shadow-sm transition-colors file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50",children:[e.jsx("option",{value:"",disabled:!0,children:c?f.LANGUAGES[h]||h:a.length?s("Choose language"):s("All available language page is created.")}),a.map(l=>e.jsx("option",{value:l,children:f.LANGUAGES[l]||l},l))]})]})},Z=({lang:c,name:h,setName:a,parentHasSelectedLanguagePage:u})=>{const{t}=w.useTranslation();return e.jsxs("div",{className:"space-y-1",children:[e.jsx(S.Label,{htmlFor:"name",children:t("Page Name")}),e.jsx(S.Input,{id:"name",value:c?h:"",onChange:i=>a(i.target.value),required:!0,placeholder:t(c?"Enter page name":"Choose language to add slug"),disabled:!u||!c})]})},ds=({dynamic:c,isNonSlugPageType:h,isRootPage:a,lang:u,useLanguagePrefix:t,setUseLanguagePrefix:i,isHomePage:o,parentSlug:s,parentHasSelectedLanguagePage:l,slug:x,setSlug:d,setIsSlugValid:m,getSlug:g})=>{const{t:r}=w.useTranslation();return h?null:e.jsxs("div",{className:"space-y-1",children:[a&&u&&e.jsxs("div",{className:"flex items-center space-x-2 pb-1",children:[e.jsx("input",{type:"checkbox",id:"useLanguagePrefix",checked:t,onChange:A=>i(A.target.checked),className:"rounded border-gray-300"}),e.jsxs(S.Label,{htmlFor:"useLanguagePrefix",className:"text-sm font-normal leading-tight",children:["Add language code (",e.jsxs("span",{className:"font-mono text-gray-900",children:["/",u]}),") as slug prefix"]})]}),e.jsx(S.Label,{htmlFor:"slug",children:r("Slug")}),c?e.jsx(S.Alert,{variant:"default",className:"p-2 text-xs font-medium italic text-muted-foreground",children:r("This page will use dynamic slug as defined in primary page")}):e.jsx(V.SlugInput,{disabled:!u||!l,value:x,onChange:d,placeholder:r(u?o&&t?"Leave empty for home page":"Enter page slug":"Choose language to add slug"),parentSlug:s,onValidationChange:m,fullSlug:g()})]})},_=({parentHasSelectedLanguagePage:c,name:h,lang:a,slug:u,edit:t,id:i,primaryPageObject:o,pages:s,isNonSlugPageType:l,isHomePage:x,useLanguagePrefix:d,isSlugValid:m,isPending:g})=>{const{t:r}=w.useTranslation(),A=g||!h||!a||s.some(v=>(t?v.id!==i:!0)&&v.parent===(o==null?void 0:o.id)&&v.lang===a)||!l&&!(x&&d)&&(!m||!u);return e.jsx(S.DialogFooter,{children:c?e.jsxs(e.Fragment,{children:[e.jsx(S.Button,{type:"submit",disabled:A&&!o.dynamic,children:g?e.jsxs("span",{className:"flex items-center gap-2",children:[e.jsx("span",{className:"loader mr-2"}),r(t?"Updating...":"Adding...")]}):r(t?"Update":"Add new language page")}),s.some(v=>(t?v.id!==i:!0)&&v.parent===(o==null?void 0:o.id)&&v.lang===a)&&e.jsx("p",{className:"mt-2 text-xs text-red-500",children:r("A page for this language already exists.")})]}):a&&e.jsx(S.Alert,{variant:"destructive",children:e.jsxs("p",{className:"mx-auto w-5/6 text-center",children:[r("You need to create the")," ",e.jsx("span",{className:"font-medium",children:f.LANGUAGES[a]})," ",r("page in the parent to add here.")]})})})},cs=({onSubmit:c,edit:h,lang:a,languages:u,name:t,setLang:i,setName:o,primaryPageObject:s,parentHasSelectedLanguagePage:l,id:x,pages:d,isNonSlugPageType:m,isHomePage:g,useLanguagePrefix:r,slug:A,isSlugValid:v,isPending:E})=>e.jsxs("form",{onSubmit:c,children:[e.jsxs("div",{className:"grid gap-4 py-4",children:[e.jsx(X,{edit:h,lang:a,languages:u,name:t,setLang:i,setName:o,primaryPageObject:s}),e.jsx(Z,{lang:a,name:t,setName:o,parentHasSelectedLanguagePage:l})]}),e.jsx(_,{parentHasSelectedLanguagePage:l,name:t,lang:a,slug:A,edit:h,id:x,primaryPageObject:s,pages:d,isNonSlugPageType:m,isHomePage:g,useLanguagePrefix:r,isSlugValid:v,isPending:E})]}),rs=({loading:c,onSubmit:h,edit:a,lang:u,languages:t,name:i,setLang:o,setName:s,primaryPageObject:l,parentHasSelectedLanguagePage:x,isNonSlugPageType:d,isRootPage:m,useLanguagePrefix:g,setUseLanguagePrefix:r,isHomePage:A,parentSlug:v,slug:E,setSlug:C,isSlugValid:T,setIsSlugValid:R,getSlug:M,isPending:$,id:D,pages:L})=>c?e.jsx("div",{className:"flex h-80 items-center justify-center",children:e.jsx(is.Loader,{className:"animate-spin"})}):d?e.jsx(cs,{onSubmit:h,edit:a,lang:u,languages:t,name:i,setLang:o,setName:s,primaryPageObject:l,parentHasSelectedLanguagePage:x,id:D,pages:L,isNonSlugPageType:d,isHomePage:A,useLanguagePrefix:g,slug:E,isSlugValid:T,isPending:$}):e.jsxs("form",{onSubmit:h,children:[e.jsxs("div",{className:"grid gap-4 py-4",children:[e.jsx(X,{edit:a,lang:u,languages:t,name:i,setLang:o,setName:s,primaryPageObject:l}),e.jsx(Z,{lang:u,name:i,setName:s,parentHasSelectedLanguagePage:x}),e.jsx(ds,{dynamic:l==null?void 0:l.dynamic,isNonSlugPageType:d,isRootPage:m,lang:u,useLanguagePrefix:g,setUseLanguagePrefix:r,isHomePage:A,parentSlug:v,parentHasSelectedLanguagePage:x,slug:E,setSlug:C,isSlugValid:T,setIsSlugValid:R,getSlug:M})]}),e.jsx(_,{parentHasSelectedLanguagePage:x,name:i,lang:u,slug:E,edit:a,id:D,primaryPageObject:l,pages:L,isNonSlugPageType:d,isHomePage:A,useLanguagePrefix:g,isSlugValid:T,isPending:$})]}),hs=({id:c,isOpen:h,onClose:a,primaryPage:u,edit:t=!1,preselectedLang:i})=>{const{data:o=[]}=f.useWebsitePages(),s=N.useMemo(()=>o.find(n=>n.id===u),[o,u]),[l,x]=N.useState(""),[d,m]=N.useState(""),[g,r]=N.useState(""),[A,v]=N.useState(!0),[E,C]=N.useState(!0),{mutate:T,isPending:R}=f.useCreatePage(),{mutate:M,isPending:$}=f.useUpdatePage(),D=R||$,{data:L,isFetching:H}=f.useWebsiteSetting(),j=f.useFallbackLang(),{data:G,isFetching:b}=f.useLanguagePages(u),{data:F=[],isFetching:y}=f.useLanguagePages(s==null?void 0:s.parent),{data:z=[],isFetching:P}=f.usePageTypes(),{setSelectedLang:O}=w.useLanguages(),{t:I}=w.useTranslation(),[,ss]=f.useSearchParams(),[,es]=w.useSidebarActivePanel(),ns=H||b||y||P,U=N.useMemo(()=>Y.filter(L==null?void 0:L.languages,n=>!Y.find(G,{lang:n})),[L,G]),W=N.useMemo(()=>z.find(n=>n.key===(s==null?void 0:s.pageType)),[z,s==null?void 0:s.pageType]),J=!(W!=null&&W.hasSlug),B=(s==null?void 0:s.slug)==="/";N.useEffect(()=>{if(!t&&s&&i&&(m(i),x(`${s.name} - ${f.LANGUAGES[i]}`)),!t||!s)return;const n=G==null?void 0:G.find(us=>us.id===c);if(!n)return;x(n.name),m(n.lang);const p=n.slug||"",{initSlug:k,prefix:as}=V.parseSlugForEdit(p,s);r(k),C(as)},[t,c,G,s,i]),N.useEffect(()=>{if(i)m(i);else if((U==null?void 0:U.length)===1&&!t){const n=U[0];if(!n||!f.LANGUAGES[n])return;m(n),(!l||l===(s==null?void 0:s.name))&&x(`${s==null?void 0:s.name} - ${f.LANGUAGES[n]}`)}},[i,U,t,l,s]);const{parentSlug:K,isRootPage:q}=N.useMemo(()=>{if(B||!d)return{parentSlug:void 0,isRootPage:!(s!=null&&s.parent)};if(!(s!=null&&s.parent))return{parentSlug:E?`/${d}`:void 0,isRootPage:!0};const n=F==null?void 0:F.find(p=>p.lang===d);return{parentSlug:n==null?void 0:n.slug,isRootPage:!1}},[s==null?void 0:s.parent,F,E,d,B]),ts=N.useMemo(()=>q?!0:!!(F!=null&&F.some(n=>(n==null?void 0:n.lang)===d)),[d,F,q]),Q=()=>{let n="";return q?n=`/${E?[d,g].filter(Boolean).join("/"):g}`:n=`${V.removeSlugExtension(K)}/${g}`,n.replace(/\/{2,}/g,"/").replace(/\/$/,"")},os=n=>{const p=new URLSearchParams(window.location.search);j&&n===j?p.delete("lang"):p.set("lang",n),ss(p),window.dispatchEvent(new PopStateEvent("popstate"))},ls=n=>{n.preventDefault();const p={name:l,lang:d,primaryPage:s==null?void 0:s.id,slug:J?"":Q(),pageType:s==null?void 0:s.pageType,...t&&{id:c}},k=()=>{!t&&d&&(O(d),os(d)),es("outline"),a()};t?M(p,{onSuccess:k}):T(p,{onSuccess:k})};return e.jsx(S.Dialog,{open:h,onOpenChange:a,children:h&&e.jsxs(S.DialogContent,{className:"text-slate-600 sm:max-w-[425px]",children:[e.jsxs(S.DialogHeader,{children:[e.jsx(S.DialogTitle,{children:I(t?"Edit language":"Add new language page")}),e.jsx(S.DialogDescription,{className:"font-light",children:I("Enter the details for the language")})]}),e.jsx(rs,{id:c,pages:o,loading:ns,onSubmit:ls,edit:t,lang:d,languages:U,name:l,setLang:m,setName:x,primaryPageObject:s,parentHasSelectedLanguagePage:ts,isNonSlugPageType:J,isRootPage:q,useLanguagePrefix:E,setUseLanguagePrefix:C,isHomePage:B,parentSlug:K,slug:g,setSlug:r,isSlugValid:A,setIsSlugValid:v,getSlug:Q,isPending:D})]})})};exports.default=hs;
@@ -1,6 +1,6 @@
1
1
  import { jsx as t, jsxs as g, Fragment as hn } from "react/jsx-runtime";
2
- import { p as fn, r as gn, S as mn } from "./slug-input-j5z5ZQn9.js";
3
- import { b as xn, c as vn, d as Sn, e as pn, f as Nn, g as Z, h as Fn, i as wn, L as A } from "./index-EnM7J19_.js";
2
+ import { p as fn, r as gn, S as mn } from "./slug-input-CumDDlCk.js";
3
+ import { b as xn, c as vn, d as Sn, e as pn, f as Nn, g as Z, h as Fn, i as wn, L as A } from "./index-e9WlBH0R.js";
4
4
  import { useLanguages as An, useTranslation as T, useSidebarActivePanel as Cn } from "@chaibuilder/sdk";
5
5
  import { Dialog as En, DialogContent as $n, DialogHeader as Dn, DialogTitle as Ln, DialogDescription as Tn, Label as I, Input as Un, Alert as H, DialogFooter as kn, Button as Rn } from "@chaibuilder/sdk/ui";
6
6
  import { filter as Wn, find as Bn, startsWith as In } from "lodash-es";
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),a=require("@chaibuilder/sdk"),n=require("@chaibuilder/sdk/ui"),t=require("react"),u=t.lazy(()=>Promise.resolve().then(()=>require("./page-creator-BnvaGZVI.cjs"))),x=({addEditPage:s,setAddEditPage:r,closePanel:c})=>{const{t:o}=a.useTranslation(),i=!!(s!=null&&s.id),l=!!s;return e.jsx(n.Dialog,{open:l,onOpenChange:()=>r(void 0),children:l&&e.jsxs(n.DialogContent,{className:"sm:max-w-[425px]",children:[e.jsxs(n.DialogHeader,{children:[e.jsxs(n.DialogTitle,{children:[o(i?"Edit":"Add New")," "]}),e.jsx(n.DialogDescription,{children:o(i?"Update your page name":"Enter details to create a new page")})]}),e.jsx(t.Suspense,{fallback:e.jsx("div",{className:"min-h-40"}),children:e.jsx(u,{closePanel:c,addEditPage:s,close:()=>r(void 0)})})]})})};exports.default=x;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),a=require("@chaibuilder/sdk"),n=require("@chaibuilder/sdk/ui"),t=require("react"),u=t.lazy(()=>Promise.resolve().then(()=>require("./page-creator-BGgoOA92.cjs"))),x=({addEditPage:s,setAddEditPage:r,closePanel:c})=>{const{t:o}=a.useTranslation(),i=!!(s!=null&&s.id),l=!!s;return e.jsx(n.Dialog,{open:l,onOpenChange:()=>r(void 0),children:l&&e.jsxs(n.DialogContent,{className:"sm:max-w-[425px]",children:[e.jsxs(n.DialogHeader,{children:[e.jsxs(n.DialogTitle,{children:[o(i?"Edit":"Add New")," "]}),e.jsx(n.DialogDescription,{children:o(i?"Update your page name":"Enter details to create a new page")})]}),e.jsx(t.Suspense,{fallback:e.jsx("div",{className:"min-h-40"}),children:e.jsx(u,{closePanel:c,addEditPage:s,close:()=>r(void 0)})})]})})};exports.default=x;
@@ -2,7 +2,7 @@ import { jsx as e, jsxs as r } from "react/jsx-runtime";
2
2
  import { useTranslation as a } from "@chaibuilder/sdk";
3
3
  import { Dialog as c, DialogContent as m, DialogHeader as p, DialogTitle as h, DialogDescription as f } from "@chaibuilder/sdk/ui";
4
4
  import { lazy as D, Suspense as u } from "react";
5
- const x = D(() => import("./page-creator-Bh0IUGR3.js")), C = ({
5
+ const x = D(() => import("./page-creator-DJJFl7px.js")), C = ({
6
6
  addEditPage: o,
7
7
  setAddEditPage: i,
8
8
  closePanel: t
@@ -0,0 +1,123 @@
1
+ import { jsxs as g, Fragment as k, jsx as n } from "react/jsx-runtime";
2
+ import { an as A, i as F } from "./index-e9WlBH0R.js";
3
+ import { useTranslation as G, useLanguages as B } from "@chaibuilder/sdk";
4
+ import { Button as I } from "@chaibuilder/sdk/ui";
5
+ import { Plus as _ } from "lucide-react";
6
+ import { lazy as C, useState as i, useEffect as z, Suspense as O } from "react";
7
+ import { toast as T } from "sonner";
8
+ const v = [
9
+ {
10
+ id: "google/gemini-2.5-flash",
11
+ name: "Gemini 2.5 Flash",
12
+ provider: "google",
13
+ description: "0.5x Credits",
14
+ multiplier: 0.5
15
+ },
16
+ {
17
+ id: "google/gemini-2.5-flash-pro",
18
+ name: "Gemini 2.5 Flash Pro",
19
+ provider: "google",
20
+ description: "1.25x Credits",
21
+ multiplier: 1.25
22
+ },
23
+ {
24
+ id: "google/gemini-3-pro",
25
+ name: "Gemini 3 Pro",
26
+ provider: "google",
27
+ description: "2.5x Credits",
28
+ multiplier: 2.5
29
+ },
30
+ {
31
+ id: "openai/gpt-5",
32
+ name: "GPT-5",
33
+ provider: "openai",
34
+ description: "2x Credits",
35
+ multiplier: 2
36
+ },
37
+ {
38
+ id: "anthropic/claude-haiku-4.5",
39
+ name: "Claude Haiku 4.5",
40
+ provider: "anthropic",
41
+ description: "1x Credits",
42
+ multiplier: 1
43
+ },
44
+ {
45
+ id: "anthropic/claude-sonnet-4",
46
+ name: "Claude Sonnet 4",
47
+ provider: "anthropic",
48
+ description: "3x Credits",
49
+ multiplier: 3
50
+ },
51
+ {
52
+ id: "anthropic/claude-sonnet-4.5",
53
+ name: "Claude Sonnet 4.5",
54
+ provider: "anthropic",
55
+ description: "3x Credits",
56
+ multiplier: 3
57
+ },
58
+ {
59
+ id: "openai/gpt-4.1",
60
+ name: "GPT-4.1",
61
+ provider: "openai",
62
+ description: "2x Credits",
63
+ multiplier: 2
64
+ }
65
+ ], X = (o) => v.find((s) => s.id === o), D = () => v[0], E = C(() => import("./ai-panel-default-lang-Bi2fH1so.js")), R = C(() => import("./ai-panel-other-lang-2JPRSyO1.js")), H = () => {
66
+ const { t: o } = G(), [s, a] = i(""), [e, l] = i([]), [c, d] = i(!1), [u, p] = i(null), [P, m] = i(null), [b, S] = i(D().id), { selectedLang: f, fallbackLang: w } = B(), L = A(), [M] = F(), y = M.get("page"), N = (e == null ? void 0 : e.filter((t) => t.role === "user").length) >= 4, j = (e == null ? void 0 : e.filter((t) => t.role === "user").length) >= 10;
67
+ z(() => {
68
+ l([]);
69
+ }, [f, y]);
70
+ const h = () => {
71
+ l([]), a(""), m(null), p(null), d(!1);
72
+ }, x = {
73
+ t: o,
74
+ fetch: L,
75
+ input: s,
76
+ messages: e,
77
+ setInput: a,
78
+ isLoading: c,
79
+ handleStop: () => {
80
+ u && (u.abort(), p(null)), d(!1), a(""), m(null), l((t) => {
81
+ const r = t[t.length - 1];
82
+ return r && r.role === "assistant" && r.isReasoning && r.isStreaming ? t.slice(0, -1) : t;
83
+ }), T.info(o("Generation stopped"));
84
+ },
85
+ handleReset: h,
86
+ setMessages: l,
87
+ setIsLoading: d,
88
+ currentBlock: P,
89
+ fallbackLang: w,
90
+ abortController: u,
91
+ setCurrentBlock: m,
92
+ setAbortController: p,
93
+ forceNewConversation: j,
94
+ suggestNewConversation: N,
95
+ selectedModel: b,
96
+ onModelChange: S
97
+ };
98
+ return /* @__PURE__ */ g(k, { children: [
99
+ c && /* @__PURE__ */ n("div", { className: "fixed inset-0 left-0 top-0 z-40 flex h-screen w-screen flex-col items-center justify-center bg-transparent" }),
100
+ /* @__PURE__ */ g("div", { className: "flex h-full w-full flex-col", children: [
101
+ /* @__PURE__ */ g("div", { className: "flex w-full items-center justify-between", children: [
102
+ /* @__PURE__ */ n("p", { className: "text-xs text-gray-500", children: o("Your conversation will not be saved") }),
103
+ (e == null ? void 0 : e.length) > 0 && /* @__PURE__ */ n(I, { variant: "outline", size: "icon", onClick: h, className: "h-6 w-6", disabled: c, children: /* @__PURE__ */ n(_, {}) })
104
+ ] }),
105
+ /* @__PURE__ */ n(
106
+ O,
107
+ {
108
+ fallback: /* @__PURE__ */ n("div", { className: "flex h-full w-full items-center justify-center text-xs", children: "Loading AI Panel" }),
109
+ children: f ? /* @__PURE__ */ n(R, { ...x, selectedLang: f }) : /* @__PURE__ */ n(E, { ...x })
110
+ }
111
+ )
112
+ ] })
113
+ ] });
114
+ }, Z = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
115
+ __proto__: null,
116
+ default: H
117
+ }, Symbol.toStringTag, { value: "Module" }));
118
+ export {
119
+ v as A,
120
+ X as a,
121
+ Z as b,
122
+ D as g
123
+ };
@@ -0,0 +1 @@
1
+ "use strict";const e=require("react/jsx-runtime"),C=require("./index-Pdb5tSRL.cjs"),S=require("@chaibuilder/sdk"),N=require("@chaibuilder/sdk/ui"),A=require("lucide-react"),n=require("react"),I=require("sonner"),h=[{id:"google/gemini-2.5-flash",name:"Gemini 2.5 Flash",provider:"google",description:"0.5x Credits",multiplier:.5},{id:"google/gemini-2.5-flash-pro",name:"Gemini 2.5 Flash Pro",provider:"google",description:"1.25x Credits",multiplier:1.25},{id:"google/gemini-3-pro",name:"Gemini 3 Pro",provider:"google",description:"2.5x Credits",multiplier:2.5},{id:"openai/gpt-5",name:"GPT-5",provider:"openai",description:"2x Credits",multiplier:2},{id:"anthropic/claude-haiku-4.5",name:"Claude Haiku 4.5",provider:"anthropic",description:"1x Credits",multiplier:1},{id:"anthropic/claude-sonnet-4",name:"Claude Sonnet 4",provider:"anthropic",description:"3x Credits",multiplier:3},{id:"anthropic/claude-sonnet-4.5",name:"Claude Sonnet 4.5",provider:"anthropic",description:"3x Credits",multiplier:3},{id:"openai/gpt-4.1",name:"GPT-4.1",provider:"openai",description:"2x Credits",multiplier:2}],B=s=>h.find(r=>r.id===s),j=()=>h[0],F=n.lazy(()=>Promise.resolve().then(()=>require("./ai-panel-default-lang-N1pb8rzQ.cjs"))),G=n.lazy(()=>Promise.resolve().then(()=>require("./ai-panel-other-lang-BysU1464.cjs"))),_=()=>{const{t:s}=S.useTranslation(),[r,a]=n.useState(""),[t,o]=n.useState([]),[c,d]=n.useState(!1),[u,p]=n.useState(null),[v,g]=n.useState(null),[P,b]=n.useState(j().id),{selectedLang:f,fallbackLang:M}=S.useLanguages(),y=C.useBuilderFetch(),[L]=C.useSearchParams(),q=L.get("page"),w=(t==null?void 0:t.filter(i=>i.role==="user").length)>=4,k=(t==null?void 0:t.filter(i=>i.role==="user").length)>=10;n.useEffect(()=>{o([])},[f,q]);const m=()=>{o([]),a(""),g(null),p(null),d(!1)},x={t:s,fetch:y,input:r,messages:t,setInput:a,isLoading:c,handleStop:()=>{u&&(u.abort(),p(null)),d(!1),a(""),g(null),o(i=>{const l=i[i.length-1];return l&&l.role==="assistant"&&l.isReasoning&&l.isStreaming?i.slice(0,-1):i}),I.toast.info(s("Generation stopped"))},handleReset:m,setMessages:o,setIsLoading:d,currentBlock:v,fallbackLang:M,abortController:u,setCurrentBlock:g,setAbortController:p,forceNewConversation:k,suggestNewConversation:w,selectedModel:P,onModelChange:b};return e.jsxs(e.Fragment,{children:[c&&e.jsx("div",{className:"fixed inset-0 left-0 top-0 z-40 flex h-screen w-screen flex-col items-center justify-center bg-transparent"}),e.jsxs("div",{className:"flex h-full w-full flex-col",children:[e.jsxs("div",{className:"flex w-full items-center justify-between",children:[e.jsx("p",{className:"text-xs text-gray-500",children:s("Your conversation will not be saved")}),(t==null?void 0:t.length)>0&&e.jsx(N.Button,{variant:"outline",size:"icon",onClick:m,className:"h-6 w-6",disabled:c,children:e.jsx(A.Plus,{})})]}),e.jsx(n.Suspense,{fallback:e.jsx("div",{className:"flex h-full w-full items-center justify-center text-xs",children:"Loading AI Panel"}),children:f?e.jsx(G,{...x,selectedLang:f}):e.jsx(F,{...x})})]})]})},z=Object.freeze(Object.defineProperty({__proto__:null,default:_},Symbol.toStringTag,{value:"Module"}));exports.AI_MODELS=h;exports.aiPanelContent=z;exports.getDefaultModel=j;exports.getModelById=B;
@@ -0,0 +1,317 @@
1
+ import { jsxs as C, Fragment as F, jsx as f } from "react/jsx-runtime";
2
+ import { C as P, a as W, b as O, R as $, c as q, d as V, T as K, M as _, e as j, f as G, h as z, S as Q, i as U } from "./selected-block-display-BmNhvYKu.js";
3
+ import { useAddBlock as J, useReplaceBlock as X, useRemoveBlocks as Y, getBlocksFromHTML as L, useSelectedBlock as Z, useSelectedBlockIds as tt, useBlocksHtmlForAi as et } from "@chaibuilder/sdk";
4
+ import { Bot as nt } from "lucide-react";
5
+ import { useCallback as rt, lazy as st, Fragment as ot, Suspense as it } from "react";
6
+ import { toast as at } from "sonner";
7
+ import { g as ct } from "./ai-panel-content-DfdnvlS8.js";
8
+ import { useQueryClient as lt } from "@tanstack/react-query";
9
+ const ut = () => {
10
+ const { addPredefinedBlock: k } = J(), x = X(), y = Y(), v = lt(), w = async (s, e) => {
11
+ if (!e) return;
12
+ const r = L(e);
13
+ await k(r, s.parentId, s.position);
14
+ }, I = async (s, e) => {
15
+ if (!s.blockId || !e) return;
16
+ const r = L(e);
17
+ await x(s.blockId, r);
18
+ }, S = async (s) => {
19
+ !s.ids || s.ids.length === 0 || await y(s.ids);
20
+ };
21
+ let d = null;
22
+ const T = (s, e) => {
23
+ const r = document.getElementById("canvas-iframe");
24
+ if (!r)
25
+ return null;
26
+ const c = r == null ? void 0 : r.contentDocument;
27
+ if (!c)
28
+ return null;
29
+ c.querySelectorAll("[data-stream-canvas]").forEach((u) => u.remove());
30
+ let n = null;
31
+ if (s && s !== "undefined" && (n = c.querySelector(`[data-block-id="${s}"]`)), n || (n = c.body), !n)
32
+ return null;
33
+ if (d = c.createElement("div"), d.setAttribute("data-stream-canvas", "true"), e !== void 0 && e >= 0 && n.children) {
34
+ const u = Math.min(e, n.children.length);
35
+ u < n.children.length ? n.insertBefore(d, n.children[u]) : n.appendChild(d);
36
+ } else
37
+ n.appendChild(d);
38
+ return d;
39
+ }, N = (s) => {
40
+ var n;
41
+ const e = document.getElementById("canvas-iframe");
42
+ if (!e)
43
+ return null;
44
+ const r = e == null ? void 0 : e.contentDocument;
45
+ if (!r)
46
+ return null;
47
+ r.querySelectorAll("[data-stream-canvas]").forEach((u) => u.remove());
48
+ const l = r.querySelector(`[data-block-id="${s}"]`);
49
+ return l ? (d = r.createElement("div"), d.setAttribute("data-stream-canvas", "true"), (n = l.parentNode) == null || n.insertBefore(d, l.nextSibling), l.style.display = "none", d) : null;
50
+ }, E = (s, e, r) => {
51
+ const c = T(e, r);
52
+ if (c) {
53
+ c.innerHTML = s;
54
+ const l = c.getBoundingClientRect(), n = document.getElementById("canvas-iframe"), u = n == null ? void 0 : n.contentWindow;
55
+ u && (l.top >= 0 && l.bottom <= u.innerHeight || c.scrollIntoView({ behavior: "smooth", block: "nearest" }));
56
+ }
57
+ }, B = (s, e) => {
58
+ const r = N(e);
59
+ r && (r.innerHTML = s);
60
+ }, M = (s) => {
61
+ const e = s.match(/^--ACTION=(.+)--$/);
62
+ if (!e) return null;
63
+ let c = e[1].replace(/--/g, "").split("|");
64
+ const n = { type: c[0] };
65
+ return c.forEach((u) => {
66
+ const t = u.trim();
67
+ if (t.startsWith("PARENT=")) {
68
+ const p = t.substring(7);
69
+ n.parentId = p === "undefined" ? void 0 : p;
70
+ } else t.startsWith("POS=") ? n.position = parseInt(t.substring(4)) : t.startsWith("ID=") ? n.blockId = t.substring(3) : t.startsWith("IDS=") && (n.ids = t.substring(4).split(",").map((p) => p.trim()));
71
+ }), n;
72
+ };
73
+ return rt(
74
+ async (s, e) => {
75
+ const r = new TextDecoder();
76
+ let c = "", l = "", n = !1, u = null;
77
+ const t = {
78
+ isInAction: !1,
79
+ currentAction: null,
80
+ htmlBuffer: "",
81
+ isCapturingHtml: !1
82
+ }, p = async (m) => {
83
+ const o = m.trim();
84
+ if (o === "--START--") {
85
+ n = !0;
86
+ return;
87
+ }
88
+ if (n) {
89
+ if (o === "--END--") {
90
+ t.currentAction && (t.htmlBuffer || t.currentAction.type === "REMOVE") && await b(t.currentAction, t.htmlBuffer), d && (d.remove(), d = null);
91
+ return;
92
+ }
93
+ if (o.startsWith("--THINKING=")) {
94
+ const i = o.substring(11);
95
+ e((a) => {
96
+ const g = [...a], h = g[g.length - 1];
97
+ if (h && h.role === "assistant" && h.isReasoning)
98
+ h.content = i, h.isStreaming = !1;
99
+ else {
100
+ const A = {
101
+ id: Date.now().toString(),
102
+ role: "assistant",
103
+ content: i,
104
+ isReasoning: !0,
105
+ isStreaming: !1
106
+ };
107
+ g.push(A);
108
+ }
109
+ return g;
110
+ });
111
+ return;
112
+ }
113
+ if (o.startsWith("--TASK=")) {
114
+ const i = o.substring(7), a = `task-${Date.now()}-${Math.random().toString(36).substr(2, 9)}`, g = {
115
+ id: a,
116
+ role: "assistant",
117
+ content: i.replace(/--$/, ""),
118
+ isTask: !0,
119
+ isTaskLoading: !0,
120
+ isTaskCompleted: !1
121
+ };
122
+ u = a, e((h) => [...h, g]);
123
+ return;
124
+ }
125
+ if (o.startsWith("--MSG=")) {
126
+ const i = o.substring(6), a = {
127
+ id: Date.now().toString(),
128
+ role: "assistant",
129
+ content: i.replace(/--$/g, ""),
130
+ isReasoning: !1,
131
+ isStreaming: !1
132
+ };
133
+ e((g) => [...g, a]);
134
+ return;
135
+ }
136
+ if (o.startsWith("--ACTION=")) {
137
+ t.currentAction && (t.htmlBuffer || t.currentAction.type === "REMOVE") && await b(t.currentAction, t.htmlBuffer), t.currentAction = M(o), t.htmlBuffer = "", t.isInAction = !0;
138
+ return;
139
+ }
140
+ if (o === "--ENDACTION--") {
141
+ t.currentAction && (t.htmlBuffer || t.currentAction.type === "REMOVE") && await b(t.currentAction, t.htmlBuffer), u && (e((i) => i.map((a) => a.isTask ? { ...a, isTaskCompleted: !0 } : a)), u = null), t.currentAction = null, t.htmlBuffer = "", t.isInAction = !1;
142
+ return;
143
+ }
144
+ if (o === "--HTML--") {
145
+ t.isCapturingHtml = !0;
146
+ return;
147
+ }
148
+ if (o === "--ENDHTML--") {
149
+ t.isCapturingHtml = !1;
150
+ return;
151
+ }
152
+ if (o.startsWith("--HTML--") && o.includes("--ENDHTML--")) {
153
+ const i = o.match(/^--HTML--(.+?)--ENDHTML--$/);
154
+ if (i && t.currentAction) {
155
+ const a = i[1];
156
+ t.htmlBuffer += a, t.currentAction.type === "ADD" ? E(t.htmlBuffer, t.currentAction.parentId, t.currentAction.position) : t.currentAction.type === "EDIT" && t.currentAction.blockId && B(t.htmlBuffer, t.currentAction.blockId);
157
+ }
158
+ return;
159
+ }
160
+ t.isCapturingHtml && t.currentAction && (t.htmlBuffer += m + `
161
+ `, t.currentAction.type === "ADD" ? E(t.htmlBuffer, t.currentAction.parentId, t.currentAction.position) : t.currentAction.type === "EDIT" && t.currentAction.blockId && B(t.htmlBuffer, t.currentAction.blockId));
162
+ }
163
+ }, b = async (m, o) => {
164
+ try {
165
+ switch (m.type) {
166
+ case "ADD":
167
+ await w(m, o);
168
+ break;
169
+ case "EDIT":
170
+ await I(m, o);
171
+ break;
172
+ case "REMOVE":
173
+ await S(m);
174
+ break;
175
+ }
176
+ e((i) => i.filter((a) => !a.isTask));
177
+ } catch (i) {
178
+ console.log(i);
179
+ }
180
+ };
181
+ try {
182
+ for (; ; ) {
183
+ const { done: m, value: o } = await s.read();
184
+ if (m) break;
185
+ const i = r.decode(o, { stream: !0 });
186
+ c += i, l += i;
187
+ const a = l.split(`
188
+ `);
189
+ l = a.pop() || "";
190
+ for (const g of a)
191
+ await p(g);
192
+ }
193
+ l && await p(l), v.invalidateQueries({
194
+ queryKey: ["AI_USAGE"]
195
+ });
196
+ } catch (m) {
197
+ console.log(m);
198
+ }
199
+ },
200
+ [y]
201
+ );
202
+ }, dt = st(() => import("./ai-prompt-input-DadL_cng.js")), bt = ({
203
+ t: k,
204
+ fetch: x,
205
+ input: y,
206
+ messages: v,
207
+ setInput: w,
208
+ isLoading: I,
209
+ setMessages: S,
210
+ handleStop: d,
211
+ setIsLoading: T,
212
+ currentBlock: N,
213
+ fallbackLang: E,
214
+ setCurrentBlock: B,
215
+ setAbortController: M,
216
+ selectedModel: s = ct().id,
217
+ onModelChange: e
218
+ }) => {
219
+ const r = Z(), [, c] = tt(), l = et(), n = ut(), u = async (t, p, b, m) => {
220
+ var h;
221
+ if (!t || I) return;
222
+ B(r);
223
+ const o = l(r ? { blockId: r._id, additionalCoreBlocks: ["Icon"] } : { additionalCoreBlocks: ["Icon"] });
224
+ if (r && !o) {
225
+ at.error(k("Something went wrong. Please try again."));
226
+ return;
227
+ }
228
+ const i = {
229
+ id: Date.now().toString(),
230
+ role: "user",
231
+ content: U({
232
+ language: E,
233
+ userInput: p || t,
234
+ currentHtml: o
235
+ }),
236
+ userMessage: t
237
+ }, a = {
238
+ id: (Date.now() + 1).toString(),
239
+ role: "assistant",
240
+ content: "",
241
+ isReasoning: !0,
242
+ isStreaming: !0
243
+ };
244
+ S((A) => [...A, i, a]), T(!0);
245
+ const g = new AbortController();
246
+ M(g);
247
+ try {
248
+ const A = {
249
+ messages: [i].map((H) => ({
250
+ role: H.role,
251
+ content: H.content
252
+ })),
253
+ model: m || s
254
+ };
255
+ b && (A.image = b);
256
+ const D = await x({ body: { action: "ASK_AI", data: A }, streamResponse: !0 });
257
+ if (!D.ok)
258
+ throw new Error(k("Failed to get AI response"));
259
+ const R = (h = D.body) == null ? void 0 : h.getReader();
260
+ if (!R) throw new Error(k("Response body is not readable"));
261
+ await n(R, S);
262
+ } catch (A) {
263
+ if (A.name !== "AbortError") {
264
+ const D = {
265
+ id: (Date.now() + 1).toString(),
266
+ role: "assistant",
267
+ content: k("Sorry, I encountered an error. Please try again.")
268
+ };
269
+ S((R) => [...R, D]);
270
+ }
271
+ } finally {
272
+ w(""), T(!1), B(null), M(null);
273
+ }
274
+ };
275
+ return /* @__PURE__ */ C(F, { children: [
276
+ /* @__PURE__ */ C(P, { className: "no-scrollbar", children: [
277
+ /* @__PURE__ */ C(W, { className: "gap-2 px-0", children: [
278
+ v.length === 0 && /* @__PURE__ */ f(
279
+ O,
280
+ {
281
+ icon: /* @__PURE__ */ f(nt, { size: 48, className: "text-gray-300" }),
282
+ title: "Start a conversation",
283
+ description: k("Start a conversation with the AI assistant to add/edit current page")
284
+ }
285
+ ),
286
+ v.map(
287
+ (t) => t.role !== "system" && /* @__PURE__ */ f(ot, { children: t.isReasoning ? /* @__PURE__ */ C($, { isStreaming: t.isStreaming, defaultOpen: !0, children: [
288
+ /* @__PURE__ */ f(q, { className: "text-xs [&_p]:text-muted-foreground" }),
289
+ /* @__PURE__ */ f(V, { className: "p-0 text-xs", children: t.content })
290
+ ] }) : t.isTask && !t.isTaskCompleted ? /* @__PURE__ */ f(K, { content: t.content, isLoading: t.isTaskLoading }) : /* @__PURE__ */ f(_, { from: t.role, children: /* @__PURE__ */ f(j, { className: "p-0", children: t.role === "assistant" ? /* @__PURE__ */ f(G, { className: "p-0 text-xs", children: t.content }) : /* @__PURE__ */ f("div", { className: "p-0 text-xs", children: t.userMessage || t.content }) }) }) }, t.id)
291
+ )
292
+ ] }),
293
+ /* @__PURE__ */ f(z, {})
294
+ ] }),
295
+ /* @__PURE__ */ C("div", { className: "border-gray-200 pb-2", children: [
296
+ /* @__PURE__ */ f(Q, { onRemove: () => c([]), isLoading: I }),
297
+ /* @__PURE__ */ f(it, { fallback: /* @__PURE__ */ f("div", { children: "Loading..." }), children: /* @__PURE__ */ f(
298
+ dt,
299
+ {
300
+ input: y,
301
+ setInput: w,
302
+ onSend: u,
303
+ onStop: d,
304
+ isLoading: I,
305
+ selectedLang: "",
306
+ currentBlock: r || N,
307
+ disabled: (y == null ? void 0 : y.length) === 0,
308
+ selectedModel: s,
309
+ onModelChange: e
310
+ }
311
+ ) })
312
+ ] })
313
+ ] });
314
+ };
315
+ export {
316
+ bt as default
317
+ };
@@ -0,0 +1,3 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("react/jsx-runtime"),g=require("./selected-block-display-CqnwyGRp.cjs"),y=require("@chaibuilder/sdk"),L=require("lucide-react"),j=require("react"),P=require("sonner"),F=require("./ai-panel-content-Ouz6pu_0.cjs"),O=require("@tanstack/react-query"),W=()=>{const{addPredefinedBlock:b}=y.useAddBlock(),H=y.useReplaceBlock(),I=y.useRemoveBlocks(),C=O.useQueryClient(),T=async(s,e)=>{if(!e)return;const r=y.getBlocksFromHTML(e);await b(r,s.parentId,s.position)},B=async(s,e)=>{if(!s.blockId||!e)return;const r=y.getBlocksFromHTML(e);await H(s.blockId,r)},v=async s=>{!s.ids||s.ids.length===0||await I(s.ids)};let f=null;const w=(s,e)=>{const r=document.getElementById("canvas-iframe");if(!r)return null;const l=r==null?void 0:r.contentDocument;if(!l)return null;l.querySelectorAll("[data-stream-canvas]").forEach(d=>d.remove());let n=null;if(s&&s!=="undefined"&&(n=l.querySelector(`[data-block-id="${s}"]`)),n||(n=l.body),!n)return null;if(f=l.createElement("div"),f.setAttribute("data-stream-canvas","true"),e!==void 0&&e>=0&&n.children){const d=Math.min(e,n.children.length);d<n.children.length?n.insertBefore(f,n.children[d]):n.appendChild(f)}else n.appendChild(f);return f},N=s=>{var n;const e=document.getElementById("canvas-iframe");if(!e)return null;const r=e==null?void 0:e.contentDocument;if(!r)return null;r.querySelectorAll("[data-stream-canvas]").forEach(d=>d.remove());const u=r.querySelector(`[data-block-id="${s}"]`);return u?(f=r.createElement("div"),f.setAttribute("data-stream-canvas","true"),(n=u.parentNode)==null||n.insertBefore(f,u.nextSibling),u.style.display="none",f):null},E=(s,e,r)=>{const l=w(e,r);if(l){l.innerHTML=s;const u=l.getBoundingClientRect(),n=document.getElementById("canvas-iframe"),d=n==null?void 0:n.contentWindow;d&&(u.top>=0&&u.bottom<=d.innerHeight||l.scrollIntoView({behavior:"smooth",block:"nearest"}))}},x=(s,e)=>{const r=N(e);r&&(r.innerHTML=s)},M=s=>{const e=s.match(/^--ACTION=(.+)--$/);if(!e)return null;let l=e[1].replace(/--/g,"").split("|");const n={type:l[0]};return l.forEach(d=>{const t=d.trim();if(t.startsWith("PARENT=")){const A=t.substring(7);n.parentId=A==="undefined"?void 0:A}else t.startsWith("POS=")?n.position=parseInt(t.substring(4)):t.startsWith("ID=")?n.blockId=t.substring(3):t.startsWith("IDS=")&&(n.ids=t.substring(4).split(",").map(A=>A.trim()))}),n};return j.useCallback(async(s,e)=>{const r=new TextDecoder;let l="",u="",n=!1,d=null;const t={isInAction:!1,currentAction:null,htmlBuffer:"",isCapturingHtml:!1},A=async m=>{const o=m.trim();if(o==="--START--"){n=!0;return}if(n){if(o==="--END--"){t.currentAction&&(t.htmlBuffer||t.currentAction.type==="REMOVE")&&await S(t.currentAction,t.htmlBuffer),f&&(f.remove(),f=null);return}if(o.startsWith("--THINKING=")){const i=o.substring(11);e(c=>{const h=[...c],p=h[h.length-1];if(p&&p.role==="assistant"&&p.isReasoning)p.content=i,p.isStreaming=!1;else{const k={id:Date.now().toString(),role:"assistant",content:i,isReasoning:!0,isStreaming:!1};h.push(k)}return h});return}if(o.startsWith("--TASK=")){const i=o.substring(7),c=`task-${Date.now()}-${Math.random().toString(36).substr(2,9)}`,h={id:c,role:"assistant",content:i.replace(/--$/,""),isTask:!0,isTaskLoading:!0,isTaskCompleted:!1};d=c,e(p=>[...p,h]);return}if(o.startsWith("--MSG=")){const i=o.substring(6),c={id:Date.now().toString(),role:"assistant",content:i.replace(/--$/g,""),isReasoning:!1,isStreaming:!1};e(h=>[...h,c]);return}if(o.startsWith("--ACTION=")){t.currentAction&&(t.htmlBuffer||t.currentAction.type==="REMOVE")&&await S(t.currentAction,t.htmlBuffer),t.currentAction=M(o),t.htmlBuffer="",t.isInAction=!0;return}if(o==="--ENDACTION--"){t.currentAction&&(t.htmlBuffer||t.currentAction.type==="REMOVE")&&await S(t.currentAction,t.htmlBuffer),d&&(e(i=>i.map(c=>c.isTask?{...c,isTaskCompleted:!0}:c)),d=null),t.currentAction=null,t.htmlBuffer="",t.isInAction=!1;return}if(o==="--HTML--"){t.isCapturingHtml=!0;return}if(o==="--ENDHTML--"){t.isCapturingHtml=!1;return}if(o.startsWith("--HTML--")&&o.includes("--ENDHTML--")){const i=o.match(/^--HTML--(.+?)--ENDHTML--$/);if(i&&t.currentAction){const c=i[1];t.htmlBuffer+=c,t.currentAction.type==="ADD"?E(t.htmlBuffer,t.currentAction.parentId,t.currentAction.position):t.currentAction.type==="EDIT"&&t.currentAction.blockId&&x(t.htmlBuffer,t.currentAction.blockId)}return}t.isCapturingHtml&&t.currentAction&&(t.htmlBuffer+=m+`
2
+ `,t.currentAction.type==="ADD"?E(t.htmlBuffer,t.currentAction.parentId,t.currentAction.position):t.currentAction.type==="EDIT"&&t.currentAction.blockId&&x(t.htmlBuffer,t.currentAction.blockId))}},S=async(m,o)=>{try{switch(m.type){case"ADD":await T(m,o);break;case"EDIT":await B(m,o);break;case"REMOVE":await v(m);break}e(i=>i.filter(c=>!c.isTask))}catch(i){console.log(i)}};try{for(;;){const{done:m,value:o}=await s.read();if(m)break;const i=r.decode(o,{stream:!0});l+=i,u+=i;const c=u.split(`
3
+ `);u=c.pop()||"";for(const h of c)await A(h)}u&&await A(u),C.invalidateQueries({queryKey:["AI_USAGE"]})}catch(m){console.log(m)}},[I])},$=j.lazy(()=>Promise.resolve().then(()=>require("./ai-prompt-input-JeIqWZco.cjs"))),V=({t:b,fetch:H,input:I,messages:C,setInput:T,isLoading:B,setMessages:v,handleStop:f,setIsLoading:w,currentBlock:N,fallbackLang:E,setCurrentBlock:x,setAbortController:M,selectedModel:s=F.getDefaultModel().id,onModelChange:e})=>{const r=y.useSelectedBlock(),[,l]=y.useSelectedBlockIds(),u=y.useBlocksHtmlForAi(),n=W(),d=async(t,A,S,m)=>{var p;if(!t||B)return;x(r);const o=u(r?{blockId:r._id,additionalCoreBlocks:["Icon"]}:{additionalCoreBlocks:["Icon"]});if(r&&!o){P.toast.error(b("Something went wrong. Please try again."));return}const i={id:Date.now().toString(),role:"user",content:g.getUserPrompt({language:E,userInput:A||t,currentHtml:o}),userMessage:t},c={id:(Date.now()+1).toString(),role:"assistant",content:"",isReasoning:!0,isStreaming:!0};v(k=>[...k,i,c]),w(!0);const h=new AbortController;M(h);try{const k={messages:[i].map(q=>({role:q.role,content:q.content})),model:m||s};S&&(k.image=S);const D=await H({body:{action:"ASK_AI",data:k},streamResponse:!0});if(!D.ok)throw new Error(b("Failed to get AI response"));const R=(p=D.body)==null?void 0:p.getReader();if(!R)throw new Error(b("Response body is not readable"));await n(R,v)}catch(k){if(k.name!=="AbortError"){const D={id:(Date.now()+1).toString(),role:"assistant",content:b("Sorry, I encountered an error. Please try again.")};v(R=>[...R,D])}}finally{T(""),w(!1),x(null),M(null)}};return a.jsxs(a.Fragment,{children:[a.jsxs(g.Conversation,{className:"no-scrollbar",children:[a.jsxs(g.ConversationContent,{className:"gap-2 px-0",children:[C.length===0&&a.jsx(g.ConversationEmptyState,{icon:a.jsx(L.Bot,{size:48,className:"text-gray-300"}),title:"Start a conversation",description:b("Start a conversation with the AI assistant to add/edit current page")}),C.map(t=>t.role!=="system"&&a.jsx(j.Fragment,{children:t.isReasoning?a.jsxs(g.Reasoning,{isStreaming:t.isStreaming,defaultOpen:!0,children:[a.jsx(g.ReasoningTrigger,{className:"text-xs [&_p]:text-muted-foreground"}),a.jsx(g.ReasoningContent,{className:"p-0 text-xs",children:t.content})]}):t.isTask&&!t.isTaskCompleted?a.jsx(g.TaskMessage,{content:t.content,isLoading:t.isTaskLoading}):a.jsx(g.Message,{from:t.role,children:a.jsx(g.MessageContent,{className:"p-0",children:t.role==="assistant"?a.jsx(g.MessageResponse,{className:"p-0 text-xs",children:t.content}):a.jsx("div",{className:"p-0 text-xs",children:t.userMessage||t.content})})})},t.id))]}),a.jsx(g.ConversationScrollButton,{})]}),a.jsxs("div",{className:"border-gray-200 pb-2",children:[a.jsx(g.SelectedBlockDisplay,{onRemove:()=>l([]),isLoading:B}),a.jsx(j.Suspense,{fallback:a.jsx("div",{children:"Loading..."}),children:a.jsx($,{input:I,setInput:T,onSend:d,onStop:f,isLoading:B,selectedLang:"",currentBlock:r||N,disabled:(I==null?void 0:I.length)===0,selectedModel:s,onModelChange:e})})]})]})};exports.default=V;
@@ -1,9 +1,10 @@
1
1
  import { jsxs as i, Fragment as $, jsx as t } from "react/jsx-runtime";
2
- import { C as G, a as H, b as Q, R as X, c as Y, d as Z, T as L, M as ee, e as te, f as ne, S as oe, g as se } from "./selected-block-display-DdW-DWF1.js";
2
+ import { C as G, a as H, b as Q, R as X, c as Y, d as Z, T as L, M as ee, e as te, f as ne, S as oe, g as se } from "./selected-block-display-BmNhvYKu.js";
3
3
  import { useTranslation as ae, useSelectedBlock as re, useSelectedBlockIds as ce, useI18nBlocks as ie, useStreamMultipleBlocksProps as le } from "@chaibuilder/sdk";
4
4
  import { Bot as de } from "lucide-react";
5
5
  import { lazy as v, useRef as ue, useEffect as he, Suspense as B, Fragment as ge } from "react";
6
- const me = v(() => import("./ai-translation-prompt-CVuPbgXw.js")), fe = v(() => import("./ai-prompt-input-B_NRADBT.js")), we = ({
6
+ import { g as me } from "./ai-panel-content-DfdnvlS8.js";
7
+ const fe = v(() => import("./ai-translation-prompt-B0si-R0R.js")), pe = v(() => import("./ai-prompt-input-DadL_cng.js")), be = ({
7
8
  fetch: A,
8
9
  input: s,
9
10
  messages: l,
@@ -18,12 +19,12 @@ const me = v(() => import("./ai-translation-prompt-CVuPbgXw.js")), fe = v(() =>
18
19
  abortController: u,
19
20
  setAbortController: O,
20
21
  setCurrentBlock: f,
21
- selectedModel: p = "google/gemini-2.5-pro",
22
+ selectedModel: p = me().id,
22
23
  onModelChange: P
23
24
  }) => {
24
- const { t: n } = ae(), I = ue(null), c = re(), [, D] = ce(), k = ie(), F = le(), j = () => {
25
+ const { t: n } = ae(), D = ue(null), c = re(), [, I] = ce(), k = ie(), F = le(), j = () => {
25
26
  var e;
26
- (e = I.current) == null || e.scrollIntoView({ behavior: "smooth" });
27
+ (e = D.current) == null || e.scrollIntoView({ behavior: "smooth" });
27
28
  };
28
29
  he(() => {
29
30
  j();
@@ -79,7 +80,7 @@ const me = v(() => import("./ai-translation-prompt-CVuPbgXw.js")), fe = v(() =>
79
80
  };
80
81
  return /* @__PURE__ */ i($, { children: [
81
82
  /* @__PURE__ */ t("div", { className: "py-2", children: /* @__PURE__ */ t(B, { fallback: /* @__PURE__ */ t("div", { children: n("Loading...") }), children: /* @__PURE__ */ t(
82
- me,
83
+ fe,
83
84
  {
84
85
  isLoading: a,
85
86
  selectedBlock: c,
@@ -106,9 +107,9 @@ const me = v(() => import("./ai-translation-prompt-CVuPbgXw.js")), fe = v(() =>
106
107
  )
107
108
  ] }) }),
108
109
  /* @__PURE__ */ i("div", { className: "border-gray-200 pb-2", children: [
109
- /* @__PURE__ */ t(oe, { onRemove: () => D([]), isLoading: a }),
110
+ /* @__PURE__ */ t(oe, { onRemove: () => I([]), isLoading: a }),
110
111
  /* @__PURE__ */ t(B, { fallback: /* @__PURE__ */ t("div", { children: n("Loading...") }), children: /* @__PURE__ */ t(
111
- fe,
112
+ pe,
112
113
  {
113
114
  input: s,
114
115
  setInput: g,
@@ -126,5 +127,5 @@ const me = v(() => import("./ai-translation-prompt-CVuPbgXw.js")), fe = v(() =>
126
127
  ] });
127
128
  };
128
129
  export {
129
- we as default
130
+ be as default
130
131
  };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),n=require("./selected-block-display-CqnwyGRp.cjs"),a=require("@chaibuilder/sdk"),G=require("lucide-react"),o=require("react"),H=require("./ai-panel-content-Ouz6pu_0.cjs"),Q=o.lazy(()=>Promise.resolve().then(()=>require("./ai-translation-prompt-CQb1L7NM.cjs"))),X=o.lazy(()=>Promise.resolve().then(()=>require("./ai-prompt-input-JeIqWZco.cjs"))),Y=({fetch:v,input:c,messages:u,setInput:j,isLoading:i,handleStop:P,setMessages:y,setIsLoading:h,selectedLang:l,currentBlock:q,fallbackLang:A,abortController:x,setAbortController:E,setCurrentBlock:k,selectedModel:S=H.getDefaultModel().id,onModelChange:M})=>{const{t:s}=a.useTranslation(),O=o.useRef(null),d=a.useSelectedBlock(),[,C]=a.useSelectedBlockIds(),T=a.useI18nBlocks(),D=a.useStreamMultipleBlocksProps(),I=()=>{var t;(t=O.current)==null||t.scrollIntoView({behavior:"smooth"})};o.useEffect(()=>{I()},[u,i]);const f=async(t,m,F)=>{var b;d&&k(d);const p=(t==null?void 0:t.toLowerCase())==="translate",R={id:Date.now().toString(),role:"user",content:n.getTranslationUserPrompt({fallbackLang:A,userInput:m||t,language:l,blocks:p?T():T(l)}),userMessage:m||t||s("Translate the content")},_={id:(Date.now()+1).toString(),role:"assistant",content:"Thinking...",isReasoning:!0,isStreaming:!0};h(!0);const z=new AbortController;E(z),y(w=>[...w,R,_]),h(!0);try{const N=await v({body:{action:"ASK_AI",data:{messages:[R],initiator:p?"TRANSLATE_CONTENT":"UPDATE_CONTENT",model:F||S}},streamResponse:!0});if(!N.ok)throw new Error(s("Failed to get AI response"));const B=(b=N.body)==null?void 0:b.getReader(),U=new TextDecoder;let r="";if(!B)throw new Error(s("Response body is not readable"));for(;;){const{done:K,value:V}=await B.read();if(K)break;const W=U.decode(V,{stream:!0});r+=W,y(g=>(g[g.length-1].content=r,[...g]))}const J=JSON.parse(r==null?void 0:r.replace("```json","").replace("```",""));D(J)}catch{x==null||x.abort()}finally{h(!1),j(""),k(null)}};return e.jsxs(e.Fragment,{children:[e.jsx("div",{className:"py-2",children:e.jsx(o.Suspense,{fallback:e.jsx("div",{children:s("Loading...")}),children:e.jsx(Q,{isLoading:i,selectedBlock:d,selectedLang:l,onClick:f})})}),e.jsx(n.Conversation,{children:e.jsxs(n.ConversationContent,{className:"gap-4 px-0",children:[u.length===0&&e.jsx(n.ConversationEmptyState,{icon:e.jsx(G.Bot,{size:48,className:"text-gray-300"}),title:s("Start a conversation with the AI assistant to translate/edit your content"),description:s("Only content can be edited in secondary languages. To edit layout, styles and more, switch to the default language.")}),u.map(t=>t.role!=="system"&&e.jsx(o.Fragment,{children:t.isReasoning?e.jsxs(n.Reasoning,{isStreaming:t.isStreaming,defaultOpen:!0,children:[e.jsx(n.ReasoningTrigger,{className:"text-xs [&_p]:text-muted-foreground"}),e.jsx(n.ReasoningContent,{className:"p-0 text-xs",children:t.content})]}):t.isTask?e.jsx(n.TaskMessage,{content:t.content,isLoading:t.isTaskLoading}):e.jsx(n.Message,{from:t.role,children:e.jsx(n.MessageContent,{className:"p-0",children:t.role==="assistant"?e.jsx(n.MessageResponse,{className:"p-0 text-xs",children:t.content}):e.jsx("div",{className:"p-0 text-xs",children:t.userMessage||t.content})})})},t.id))]})}),e.jsxs("div",{className:"border-gray-200 pb-2",children:[e.jsx(n.SelectedBlockDisplay,{onRemove:()=>C([]),isLoading:i}),e.jsx(o.Suspense,{fallback:e.jsx("div",{children:s("Loading...")}),children:e.jsx(X,{input:c,setInput:j,onSend:f,onStop:P,isLoading:i,selectedLang:l,currentBlock:d||q,disabled:(c==null?void 0:c.length)===0,selectedModel:S,onModelChange:M})})]})]})};exports.default=Y;