@pickaxeproject/react 5.6.0 → 5.6.1-beta.1

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 (39) hide show
  1. package/dist/cjs/components/Pickaxe/Chat/History/index.js +1 -1
  2. package/dist/cjs/components/Pickaxe/Chat/Input.js +1 -1
  3. package/dist/cjs/components/Pickaxe/Form/Questions/Submit.js +1 -1
  4. package/dist/cjs/components/Pickaxe/Provider.js +1 -1
  5. package/dist/cjs/components/Pickaxe/common/AccessGroupCardPreview.js +1 -0
  6. package/dist/cjs/components/Pickaxe/common/PickaxeAvatar.js +1 -0
  7. package/dist/cjs/components/Pickaxe/common/PickaxeCommon.js +1 -0
  8. package/dist/cjs/components/Pickaxe/common/PickaxeCurrency.js +1 -0
  9. package/dist/cjs/components/Pickaxe/common/PickaxeUpgradeCard.js +1 -1
  10. package/dist/cjs/components/Pickaxe/index.js +1 -1
  11. package/dist/cjs/src/components/Pickaxe/Provider.d.ts +3 -1
  12. package/dist/cjs/src/components/Pickaxe/ResponseProvider.d.ts +6 -3
  13. package/dist/cjs/src/components/Pickaxe/common/AccessGroupCardPreview.d.ts +9 -0
  14. package/dist/cjs/src/components/Pickaxe/common/PickaxeAvatar.d.ts +16 -0
  15. package/dist/cjs/src/components/Pickaxe/common/PickaxeCommon.d.ts +2 -0
  16. package/dist/cjs/src/components/Pickaxe/common/PickaxeCurrency.d.ts +7 -0
  17. package/dist/cjs/src/components/Pickaxe/common/PickaxeUpgradeCard.d.ts +1 -1
  18. package/dist/cjs/src/hooks/pickaxe/usePickaxeContext.d.ts +1 -0
  19. package/dist/cjs/src/types/response.d.ts +8 -0
  20. package/dist/esm/components/Pickaxe/Chat/History/index.js +1 -1
  21. package/dist/esm/components/Pickaxe/Chat/Input.js +1 -1
  22. package/dist/esm/components/Pickaxe/Form/Questions/Submit.js +1 -1
  23. package/dist/esm/components/Pickaxe/Provider.js +1 -1
  24. package/dist/esm/components/Pickaxe/common/AccessGroupCardPreview.js +1 -0
  25. package/dist/esm/components/Pickaxe/common/PickaxeAvatar.js +1 -0
  26. package/dist/esm/components/Pickaxe/common/PickaxeCommon.js +1 -0
  27. package/dist/esm/components/Pickaxe/common/PickaxeCurrency.js +1 -0
  28. package/dist/esm/components/Pickaxe/common/PickaxeUpgradeCard.js +1 -1
  29. package/dist/esm/components/Pickaxe/index.js +1 -1
  30. package/dist/esm/src/components/Pickaxe/Provider.d.ts +3 -1
  31. package/dist/esm/src/components/Pickaxe/ResponseProvider.d.ts +6 -3
  32. package/dist/esm/src/components/Pickaxe/common/AccessGroupCardPreview.d.ts +9 -0
  33. package/dist/esm/src/components/Pickaxe/common/PickaxeAvatar.d.ts +16 -0
  34. package/dist/esm/src/components/Pickaxe/common/PickaxeCommon.d.ts +2 -0
  35. package/dist/esm/src/components/Pickaxe/common/PickaxeCurrency.d.ts +7 -0
  36. package/dist/esm/src/components/Pickaxe/common/PickaxeUpgradeCard.d.ts +1 -1
  37. package/dist/esm/src/hooks/pickaxe/usePickaxeContext.d.ts +1 -0
  38. package/dist/esm/src/types/response.d.ts +8 -0
  39. package/package.json +205 -202
@@ -1 +1 @@
1
- import{__awaiter as e}from"../../../../_virtual/_tslib.js";import{jsxs as t,jsx as s}from"react/jsx-runtime";import{useState as n,useRef as i,useMemo as o}from"react";import{usePickaxeContext as r}from"../../../../hooks/pickaxe/usePickaxeContext.js";import{useAuthContext as a}from"../../Addons/Auth/hooks/useAuthContext.js";import{useResponseContext as l}from"../../../../hooks/pickaxe/useResponseContext.js";import{useDocument as d}from"../../Addons/Document/hooks/useDocument.js";import{useScroll as c}from"../../Addons/Scroll/hooks/useScroll.js";import{useArtifactContext as p}from"../../Addons/Artifact/hooks/useArtifactContext.js";import{extractUrlsFromText as u}from"../../../../common/utils.js";import{encode as m}from"@nem035/gpt-3-encoder";import{createParser as f}from"eventsource-parser";import g from"../../common/PickaxeBranding.js";import h from"../../common/PickaxeButton.js";import v from"../../../../common/error.js";const b=({questions:b,resetQuestions:y})=>{var j;const{origin:O,pickaxeId:x,sender:w,senderType:k,deploymentId:C,pickaxe:S,misc:I,translations:N,isRtl:P,setSessionId:_,setIsNewChat:A,onGenerateComplete:E}=r(),{token:T}=a(),{limits:L,isGenerating:U,setResponse:D,setMessages:J,setStatus:q,setLimitData:B,setError:K,setIsSwitchedToChat:R}=l(),{documents:W,websiteLink:X,isUploading:V,onWebsiteUpload:$,setDocuments:G,setDocumentError:M}=d(),{scrollStartSession:F,scrollEndSession:Q,scrollToTarget:Y}=c({auto:!(null==S?void 0:S.enablechatresponses)}),{artifacts:z,currentPopupType:H,setArtifacts:Z,setCurrentArtifact:ee}=p(),[te,se]=n(!1),ne=i(null),ie=o((()=>b.some((e=>("Short Answer"===e.type||"Long Answer"===e.type||"long"===e.type||"short"===e.type||"Checkbox"===e.type||"Knowledge Upload"===e.type||e.id.includes("documentupload"))&&e.input.length>0))),[b]);return t("div",Object.assign({className:"mt-4 flex flex-wrap justify-between gap-4 items-center",dir:P?"rtl":"ltr"},{children:[t("div",Object.assign({className:"flex items-center flex-grow flex-wrap gap-2"},{children:[s(h,Object.assign({className:"px-5 min-h-[42px]",isDisabled:V||U||te,onClick:()=>e(void 0,void 0,void 0,(function*(){var e,t,s;try{if(U||V||te)return;K(""),M(""),B(null),D(null);const n=["Multiple Choice","Checkbox"];for(const e of b){if(m(e.input).length>e.maxLength&&!n.includes(e.type))throw new Error("One or more of your responses is too long!");if(e.isRequired&&!e.input.trim()&&"userinput:documentupload"!==e.id)throw new Error("You must fill out all required fields.")}const i=W.filter((e=>"finished"===e.status)),o=W.map((e=>e.name)),r=null!==(t=null===(e=null==S?void 0:S.documentuploadtype)||void 0===e?void 0:e.startsWith("enduserupload"))&&void 0!==t&&t,a=b.some((e=>"userinput:documentupload"===e.id&&e.isRequired)),l=u(X).filter((e=>!o.includes(e)));if(l.length){const e=l[l.length-1];se(!0);const t=yield $(e);t&&(i.push(t),yield new Promise((e=>setTimeout(e,5e3)))),se(!1)}else if(a&&r&&!i.length)return void M("Please paste a valid website/video link or drag a file to add to the knowledge base.");const d=i.map((e=>e.documentId||"")).filter(Boolean),c=r&&d.length>0,p={};b.forEach((e=>{p[e.id]="Knowledge Upload"===e.type||e.id.includes("documentupload")?i.map((e=>e.name)).join(",")||"":e.input})),q("fetching"),F(),Y();const g=yield fetch(`${process.env.NEXT_PUBLIC_PICKAXE_API_URL}/submit`,{method:"POST",headers:Object.assign({"Content-Type":"application/json"},process.env.NEXT_PUBLIC_PICKAXE_SESSION_TOKEN&&{"x-pickaxe-session-token":process.env.NEXT_PUBLIC_PICKAXE_SESSION_TOKEN}),body:JSON.stringify(Object.assign(Object.assign(Object.assign(Object.assign({origin:O,pickaxeId:x,senderType:k,valueObj:p},c&&{documentIds:d}),w&&{sender:w}),T&&{studioSessionToken:T}),C&&{deploymentId:C}))}),h=yield g.json();if(!h.success)throw new Error(h.error||"Failed to start generation");const v=h.submissionId,y=h.sessionId,j={sessionId:y,documentIds:c?d:[],question:{inputs:b.map((e=>({id:e.id,question:e.main,answer:e.input}))),responseParts:[]},messageCount:0,sentAt:new Date};D(j),(null==S?void 0:S.enablechatresponses)&&(_(y),A(!1),R(!0),J([{id:0,role:"assistant",parts:[],documentIds:[]}])),c&&G([]),q("streaming"),ne.current=new AbortController;const I=[];let N=[...null!=z?z:[]],P=0,L=!1,Q="";for(;!L;)try{const e=yield fetch(`${process.env.NEXT_PUBLIC_PICKAXE_API_URL}/stream/${v}?index=${P}`,{signal:null===(s=ne.current)||void 0===s?void 0:s.signal,headers:{"Cache-Control":"no-cache",Connection:"keep-alive"}});if(!e.body)throw new Error("No response body");const t=e.body.getReader(),n=new TextDecoder,i=f({onEvent:e=>{var t,s;if(e.event&&"ping"!==e.event&&P++,"stop"!==e.event){if("error"===e.event){const t=JSON.parse(e.data).error||"Something went wrong.";return K(t),void(L=!0)}if("delta"===e.event){const n=JSON.parse(e.data);if("text-start"===n.type)Q="",I.push({type:"text",content:"",isVisible:null===(t=n.isVisible)||void 0===t||t});else if("text-delta"===n.type)Q+=n.delta,I[I.length-1].content=Q;else if("text-end"===n.type)Q="";else if("reasoning-start"===n.type)Q="",I.push({type:"reasoning",content:"",isVisible:null===(s=n.isVisible)||void 0===s||s});else if("reasoning-delta"===n.type)Q+=n.delta,I[I.length-1].content=Q;else if("reasoning-end"===n.type)Q="";else if(n.type.startsWith("data-")){const e=n;I.push({type:e.type,content:JSON.stringify(e.data),isVisible:!0})}const i=Object.assign(Object.assign({},j),{question:Object.assign(Object.assign({},j.question),{responseParts:[...I]})});D(i),(null==S?void 0:S.enablechatresponses)&&J([{id:0,role:"assistant",parts:[...I],documentIds:[]}])}else if("artifact_created"===e.event){const t=JSON.parse(e.data);N=N.filter((e=>!(e.id===t.id&&e.version===t.version))),N.push(Object.assign(Object.assign({},t),{content:"",status:"streaming"})),Z([...N]),H.startsWith("inline")||ee({id:t.id,version:t.version})}else if("artifact_updated"===e.event){const t=JSON.parse(e.data);N=N.filter((e=>!(e.id===t.id&&e.version===t.version))),N.push(Object.assign(Object.assign({},t),{content:"",status:"updating"})),Z([...N]),H.startsWith("inline")||ee({id:t.id,version:t.version})}else if("artifact_rewrite"===e.event){const t=JSON.parse(e.data);N=N.filter((e=>!(e.id===t.id&&e.version===t.version))),N.push(Object.assign(Object.assign({},t),{content:"",status:"streaming"})),Z([...N]),H.startsWith("inline")||ee({id:t.id,version:t.version})}else if("artifact_content"===e.event){const t=JSON.parse(e.data),s=t.token.replace(/\u200B/g,"");N=N.map((e=>e.id===t.id&&e.version===t.version?Object.assign(Object.assign({},e),{content:e.content+s,status:"streaming"}):e)),Z([...N])}else if("artifact_finished"===e.event){const t=JSON.parse(e.data);Z(N.map((e=>e.id===t.id?Object.assign(Object.assign({},e),{status:"finished"}):e)))}}else L=!0}});for(;;){const{value:e,done:s}=yield t.read();if(s)break;i.feed(n.decode(e))}L||(yield new Promise((e=>setTimeout(e,1e3))))}catch(e){if("AbortError"===e.name)return void(L=!0);console.warn("Stream connection lost, retrying...",e),yield new Promise((e=>setTimeout(e,1e3)))}null==E||E(y)}catch(e){let t=v(e)||"";t&&!t.includes("Unexpected token 'A',")||(t="Oops! We're experiencing high traffic at the moment. Please try again later.");const s=Object.entries(L).find((([e])=>t.includes(e)));s?B(s[1]):K(t),Y()}finally{q("idle"),se(!1),Q()}}))},{children:te?(null==N?void 0:N.processing)||"Processing...":V?(null==N?void 0:N.uploading)||"Uploading...":U?(null==N?void 0:N.loading)||"Loading...":null!==(j=null==S?void 0:S.submittext)&&void 0!==j?j:"Submit"})),ie&&s(h,Object.assign({variant:"transparent-text",className:"min-h-[42px] px-5",isDisabled:V||U||te,onClick:y},{children:(null==N?void 0:N["clear-form"])||"Clear form"}))]})),!I.isWhiteLabel&&s(g,{containerClassName:"justify-end"})]}))};export{b as default};
1
+ import{__awaiter as e}from"../../../../_virtual/_tslib.js";import{jsxs as t,jsx as s}from"react/jsx-runtime";import{useState as n,useRef as i,useMemo as o}from"react";import{usePickaxeContext as r}from"../../../../hooks/pickaxe/usePickaxeContext.js";import{useAuthContext as a}from"../../Addons/Auth/hooks/useAuthContext.js";import{useResponseContext as l}from"../../../../hooks/pickaxe/useResponseContext.js";import{useDocument as d}from"../../Addons/Document/hooks/useDocument.js";import{useScroll as c}from"../../Addons/Scroll/hooks/useScroll.js";import{useArtifactContext as p}from"../../Addons/Artifact/hooks/useArtifactContext.js";import{extractUrlsFromText as u}from"../../../../common/utils.js";import{encode as m}from"@nem035/gpt-3-encoder";import{createParser as f}from"eventsource-parser";import g from"../../common/PickaxeBranding.js";import h from"../../common/PickaxeButton.js";import v from"../../../../common/error.js";const b=({questions:b,resetQuestions:y})=>{var j;const{origin:O,pickaxeId:x,sender:w,senderType:k,deploymentId:C,pickaxe:S,misc:I,translations:N,isRtl:P,setSessionId:_,setIsNewChat:A,onGenerateComplete:E}=r(),{token:T}=a(),{isGenerating:D,setResponse:L,setMessages:U,setStatus:J,setLimitData:q,setError:B,setIsSwitchedToChat:K}=l(),{documents:R,websiteLink:W,isUploading:X,onWebsiteUpload:V,setDocuments:$,setDocumentError:G}=d(),{scrollStartSession:M,scrollEndSession:F,scrollToTarget:Q}=c({auto:!(null==S?void 0:S.enablechatresponses)}),{artifacts:Y,currentPopupType:z,setArtifacts:H,setCurrentArtifact:Z}=p(),[ee,te]=n(!1),se=i(null),ne=o((()=>b.some((e=>("Short Answer"===e.type||"Long Answer"===e.type||"long"===e.type||"short"===e.type||"Checkbox"===e.type||"Knowledge Upload"===e.type||e.id.includes("documentupload"))&&e.input.length>0))),[b]);return t("div",Object.assign({className:"mt-4 flex flex-wrap justify-between gap-4 items-center",dir:P?"rtl":"ltr"},{children:[t("div",Object.assign({className:"flex items-center flex-grow flex-wrap gap-2"},{children:[s(h,Object.assign({className:"px-5 min-h-[42px]",isDisabled:X||D||ee,onClick:()=>e(void 0,void 0,void 0,(function*(){var e,t,s;try{if(D||X||ee)return;B(""),G(""),q(null),L(null);const n=["Multiple Choice","Checkbox"];for(const e of b){if(m(e.input).length>e.maxLength&&!n.includes(e.type))throw new Error("One or more of your responses is too long!");if(e.isRequired&&!e.input.trim()&&"userinput:documentupload"!==e.id)throw new Error("You must fill out all required fields.")}const i=R.filter((e=>"finished"===e.status)),o=R.map((e=>e.name)),r=null!==(t=null===(e=null==S?void 0:S.documentuploadtype)||void 0===e?void 0:e.startsWith("enduserupload"))&&void 0!==t&&t,a=b.some((e=>"userinput:documentupload"===e.id&&e.isRequired)),l=u(W).filter((e=>!o.includes(e)));if(l.length){const e=l[l.length-1];te(!0);const t=yield V(e);t&&(i.push(t),yield new Promise((e=>setTimeout(e,5e3)))),te(!1)}else if(a&&r&&!i.length)return void G("Please paste a valid website/video link or drag a file to add to the knowledge base.");const d=i.map((e=>e.documentId||"")).filter(Boolean),c=r&&d.length>0,p={};b.forEach((e=>{p[e.id]="Knowledge Upload"===e.type||e.id.includes("documentupload")?i.map((e=>e.name)).join(",")||"":e.input})),J("fetching"),M(),Q();const g=yield fetch(`${process.env.NEXT_PUBLIC_PICKAXE_API_URL}/submit`,{method:"POST",headers:Object.assign({"Content-Type":"application/json"},process.env.NEXT_PUBLIC_PICKAXE_SESSION_TOKEN&&{"x-pickaxe-session-token":process.env.NEXT_PUBLIC_PICKAXE_SESSION_TOKEN}),body:JSON.stringify(Object.assign(Object.assign(Object.assign(Object.assign({origin:O,pickaxeId:x,senderType:k,valueObj:p},c&&{documentIds:d}),w&&{sender:w}),T&&{studioSessionToken:T}),C&&{deploymentId:C}))}),h=yield g.json();if(!h.success){const e=new Error(h.error||"Failed to start generation");throw h.limitData&&(e.limitData=h.limitData),e}const v=h.submissionId,y=h.sessionId,j={sessionId:y,documentIds:c?d:[],question:{inputs:b.map((e=>({id:e.id,question:e.main,answer:e.input}))),responseParts:[]},messageCount:0,sentAt:new Date};L(j),(null==S?void 0:S.enablechatresponses)&&(_(y),A(!1),K(!0),U([{id:0,role:"assistant",parts:[],documentIds:[]}])),c&&$([]),J("streaming"),se.current=new AbortController;const I=[];let N=[...null!=Y?Y:[]],P=0,F=!1,ne="";for(;!F;)try{const e=yield fetch(`${process.env.NEXT_PUBLIC_PICKAXE_API_URL}/stream/${v}?index=${P}`,{signal:null===(s=se.current)||void 0===s?void 0:s.signal,headers:{"Cache-Control":"no-cache",Connection:"keep-alive"}});if(!e.body)throw new Error("No response body");const t=e.body.getReader(),n=new TextDecoder,i=f({onEvent:e=>{var t,s;if(e.event&&"ping"!==e.event&&P++,"stop"!==e.event){if("error"===e.event){const t=JSON.parse(e.data).error||"Something went wrong.";return B(t),void(F=!0)}if("delta"===e.event){const n=JSON.parse(e.data);if("text-start"===n.type)ne="",I.push({type:"text",content:"",isVisible:null===(t=n.isVisible)||void 0===t||t});else if("text-delta"===n.type)ne+=n.delta,I[I.length-1].content=ne;else if("text-end"===n.type)ne="";else if("reasoning-start"===n.type)ne="",I.push({type:"reasoning",content:"",isVisible:null===(s=n.isVisible)||void 0===s||s});else if("reasoning-delta"===n.type)ne+=n.delta,I[I.length-1].content=ne;else if("reasoning-end"===n.type)ne="";else if(n.type.startsWith("data-")){const e=n;I.push({type:e.type,content:JSON.stringify(e.data),isVisible:!0})}const i=Object.assign(Object.assign({},j),{question:Object.assign(Object.assign({},j.question),{responseParts:[...I]})});L(i),(null==S?void 0:S.enablechatresponses)&&U([{id:0,role:"assistant",parts:[...I],documentIds:[]}])}else if("artifact_created"===e.event){const t=JSON.parse(e.data);N=N.filter((e=>!(e.id===t.id&&e.version===t.version))),N.push(Object.assign(Object.assign({},t),{content:"",status:"streaming"})),H([...N]),z.startsWith("inline")||Z({id:t.id,version:t.version})}else if("artifact_updated"===e.event){const t=JSON.parse(e.data);N=N.filter((e=>!(e.id===t.id&&e.version===t.version))),N.push(Object.assign(Object.assign({},t),{content:"",status:"updating"})),H([...N]),z.startsWith("inline")||Z({id:t.id,version:t.version})}else if("artifact_rewrite"===e.event){const t=JSON.parse(e.data);N=N.filter((e=>!(e.id===t.id&&e.version===t.version))),N.push(Object.assign(Object.assign({},t),{content:"",status:"streaming"})),H([...N]),z.startsWith("inline")||Z({id:t.id,version:t.version})}else if("artifact_content"===e.event){const t=JSON.parse(e.data),s=t.token.replace(/\u200B/g,"");N=N.map((e=>e.id===t.id&&e.version===t.version?Object.assign(Object.assign({},e),{content:e.content+s,status:"streaming"}):e)),H([...N])}else if("artifact_finished"===e.event){const t=JSON.parse(e.data);H(N.map((e=>e.id===t.id?Object.assign(Object.assign({},e),{status:"finished"}):e)))}}else F=!0}});for(;;){const{value:e,done:s}=yield t.read();if(s)break;i.feed(n.decode(e))}F||(yield new Promise((e=>setTimeout(e,1e3))))}catch(e){if("AbortError"===e.name)return void(F=!0);console.warn("Stream connection lost, retrying...",e),yield new Promise((e=>setTimeout(e,1e3)))}null==E||E(y)}catch(e){let t=v(e)||"";t&&!t.includes("Unexpected token 'A',")||(t="Oops! We're experiencing high traffic at the moment. Please try again later."),B(t),Q()}finally{J("idle"),te(!1),F()}}))},{children:ee?(null==N?void 0:N.processing)||"Processing...":X?(null==N?void 0:N.uploading)||"Uploading...":D?(null==N?void 0:N.loading)||"Loading...":null!==(j=null==S?void 0:S.submittext)&&void 0!==j?j:"Submit"})),ne&&s(h,Object.assign({variant:"transparent-text",className:"min-h-[42px] px-5",isDisabled:X||D||ee,onClick:y},{children:(null==N?void 0:N["clear-form"])||"Clear form"}))]})),!I.isWhiteLabel&&s(g,{containerClassName:"justify-end"})]}))};export{b as default};
@@ -1 +1 @@
1
- import{__awaiter as e}from"../../_virtual/_tslib.js";import{jsx as o}from"react/jsx-runtime";import{createContext as i,useState as t,useEffect as s}from"react";import{ArtifactProvider as n}from"./Addons/Artifact/Provider.js";import r from"./DimensionProvider.js";import a from"./ResponseProvider.js";import l from"./Addons/Document/Provider.js";import d from"./Addons/Auth/Provider.js";const c=i({}),m=({children:i,origin:m,sender:p,senderType:y,deploymentId:h,deploymentType:f,deploymentDimensions:u,deploymentMisc:b,styles:g,colors:v,limits:F={},misc:w={isWhiteLabel:!0,isProfileImage:!0,isChatImage:!0,isTitle:!0,isDescription:!0,isHistory:!0},translations:x,artifact:S={popupType:"auto"},responsiveBy:I="viewport",locale:k="en",opacity:P=1,forceMobile:j=!1,disableHtml:C=!1,disableJs:T=!1,disableCss:D=!1,loadFont:H=!0,isRtl:L=!1,isEmbed:O=!1,isDropShadow:R=!1,isEmailLogin:E=!1,allowGuestUsage:A=!0,onGenerateComplete:M})=>{const[B,G]=t(""),[N,U]=t(""),[W,J]=t(""),[_,z]=t(""),[Y,q]=t(p),[K,Q]=t(y),[V,X]=t(null),[Z,$]=t(!1),[ee,oe]=t(!0),[ie,te]=t(!0),[se,ne]=t(!1);return s((()=>{$(!1)}),[null==g?void 0:g.font]),s((()=>{e(void 0,void 0,void 0,(function*(){if("undefined"!=typeof window&&H&&!Z&&(null==g?void 0:g.font)&&"Real Head Pro"!==g.font)try{(yield import("webfontloader")).default.load({google:{families:[g.font]},active:()=>{$(!0)},inactive:()=>{console.error("[pxe] failed to load font {styles.font}"),$(!0)}})}catch(e){console.error("[pxe] failed to load font:",e),$(!0)}}))}),[H,Z,null==g?void 0:g.font]),s((()=>{q(p)}),[p]),o(c.Provider,Object.assign({value:Object.assign({origin:m,contextId:B,pickaxeId:N,sessionId:W,lastSessionId:_,sender:Y,senderType:K,deploymentId:h,deploymentType:f,deploymentDimensions:u,deploymentMisc:b,pickaxe:V,styles:Object.assign({theme:"light",font:"Real Head Pro",fontSize:"md",formFieldStyle:"box",btnStyle:"filled",outlineThickness:1,cornerRadius:4},g),colors:Object.assign({primary:"#F6F8FA",text:"#000000",secondary:"#FFFFFF",secondaryText:"#000000",accent:"#228DD7",accentText:"#FFFFFF",error:"#EF4444"},v),misc:w,translations:Object.assign({"new-chat":"New chat","see-history":"See history","see-input":"See input","hide-input":"Hide input",processing:"Processing...",uploading:"Uploading...",loading:"Loading...","powered-by-pickaxe":"Powered by Pickaxe","form-doc-placeholder":"Paste a website/video link or drag a file",website:"Website",copy:"Copy","file-limit-reached":"You have reached the file limit.",save:"Save","save-as":"Save as","please-enter-email-to-continue":"Please enter your email to continue:","enter-email-to-continue":"Enter here your email to continue",submit:"Submit",sending:"Sending...","check-your-inbox":"Check your inbox","we-sent-your-an-activation-link":"We sent you an activation link. Please be sure to check your spam folder too.",resend:"Resend",resending:"Resending...","chat-history":"Chat History","exit-chat-history":"Exit Chat History","no-history":"No history yet.","log-out":"Log Out","clear-form":"Clear form"},x),artifact:S,responsiveBy:I,locale:k,opacity:P,forceMobile:j,loadFont:H,disableHtml:C,disableJs:T,disableCss:D,isFontLoaded:Z,isNewChat:ee,isShowIceBreaker:ie,isShowFeedbackMessage:se,isRtl:L,isEmbed:O,isDropShadow:R,isEmailLogin:E,allowGuestUsage:A,setContextId:G,setPickaxeId:U,setSessionId:J,setLastSessionId:z,setSender:q,setSenderType:Q,setPickaxe:X,setIsFontLoaded:$,setIsNewChat:oe,setIsShowIceBreaker:te,setIsShowFeedbackMessage:ne},M&&{onGenerateComplete:M})},{children:o(d,{children:o(r,{children:o(a,Object.assign({limits:F},{children:o(l,{children:o(n,Object.assign({},S,{children:i}))})}))})})}))};export{c as PickaxeContext,m as PickaxeProvider};
1
+ import{__awaiter as e}from"../../_virtual/_tslib.js";import{jsx as o}from"react/jsx-runtime";import{createContext as i,useState as t,useEffect as s}from"react";import{ArtifactProvider as n}from"./Addons/Artifact/Provider.js";import r from"./DimensionProvider.js";import a from"./ResponseProvider.js";import l from"./Addons/Document/Provider.js";import d from"./Addons/Auth/Provider.js";const c=i({}),m=({children:i,origin:m,sender:p,senderType:y,portalId:h,deploymentId:f,deploymentType:u,deploymentDimensions:b,deploymentMisc:g,styles:v,colors:F,limits:w={},misc:x={isWhiteLabel:!0,isProfileImage:!0,isChatImage:!0,isTitle:!0,isDescription:!0,isHistory:!0},translations:I,artifact:S={popupType:"auto"},responsiveBy:k="viewport",locale:P="en",opacity:j=1,forceMobile:C=!1,disableHtml:T=!1,disableJs:D=!1,disableCss:H=!1,loadFont:L=!0,isRtl:O=!1,isEmbed:R=!1,isDropShadow:E=!1,isEmailLogin:A=!1,allowGuestUsage:M=!0,onGenerateComplete:B})=>{const[G,N]=t(""),[U,W]=t(""),[J,_]=t(""),[z,Y]=t(""),[q,K]=t(p),[Q,V]=t(y),[X,Z]=t(null),[$,ee]=t(!1),[oe,ie]=t(!0),[te,se]=t(!0),[ne,re]=t(!1);return s((()=>{ee(!1)}),[null==v?void 0:v.font]),s((()=>{e(void 0,void 0,void 0,(function*(){if("undefined"!=typeof window&&L&&!$&&(null==v?void 0:v.font)&&"Real Head Pro"!==v.font)try{(yield import("webfontloader")).default.load({google:{families:[v.font]},active:()=>{ee(!0)},inactive:()=>{console.error("[pxe] failed to load font {styles.font}"),ee(!0)}})}catch(e){console.error("[pxe] failed to load font:",e),ee(!0)}}))}),[L,$,null==v?void 0:v.font]),s((()=>{K(p)}),[p]),o(c.Provider,Object.assign({value:Object.assign({origin:m,contextId:G,pickaxeId:U,sessionId:J,lastSessionId:z,sender:q,senderType:Q,portalId:h,deploymentId:f,deploymentType:u,deploymentDimensions:b,deploymentMisc:g,pickaxe:X,styles:Object.assign({theme:"light",font:"Real Head Pro",fontSize:"md",formFieldStyle:"box",btnStyle:"filled",outlineThickness:1,cornerRadius:4},v),colors:Object.assign({primary:"#F6F8FA",text:"#000000",secondary:"#FFFFFF",secondaryText:"#000000",accent:"#228DD7",accentText:"#FFFFFF",error:"#EF4444"},F),misc:x,translations:Object.assign({"new-chat":"New chat","see-history":"See history","see-input":"See input","hide-input":"Hide input",processing:"Processing...",uploading:"Uploading...",loading:"Loading...","powered-by-pickaxe":"Powered by Pickaxe","form-doc-placeholder":"Paste a website/video link or drag a file",website:"Website",copy:"Copy","file-limit-reached":"You have reached the file limit.",save:"Save","save-as":"Save as","please-enter-email-to-continue":"Please enter your email to continue:","enter-email-to-continue":"Enter here your email to continue",submit:"Submit",sending:"Sending...","check-your-inbox":"Check your inbox","we-sent-your-an-activation-link":"We sent you an activation link. Please be sure to check your spam folder too.",resend:"Resend",resending:"Resending...","chat-history":"Chat History","exit-chat-history":"Exit Chat History","no-history":"No history yet.","log-out":"Log Out","clear-form":"Clear form"},I),artifact:S,responsiveBy:k,locale:P,opacity:j,forceMobile:C,loadFont:L,disableHtml:T,disableJs:D,disableCss:H,isFontLoaded:$,isNewChat:oe,isShowIceBreaker:te,isShowFeedbackMessage:ne,isRtl:O,isEmbed:R,isDropShadow:E,isEmailLogin:A,allowGuestUsage:M,setContextId:N,setPickaxeId:W,setSessionId:_,setLastSessionId:Y,setSender:K,setSenderType:V,setPickaxe:Z,setIsFontLoaded:ee,setIsNewChat:ie,setIsShowIceBreaker:se,setIsShowFeedbackMessage:re},B&&{onGenerateComplete:B})},{children:o(d,{children:o(r,{children:o(a,Object.assign({limits:w},{children:o(l,{children:o(n,Object.assign({},S,{children:i}))})}))})})}))};export{c as PickaxeContext,m as PickaxeProvider};
@@ -0,0 +1 @@
1
+ import{__awaiter as e}from"../../../_virtual/_tslib.js";import{jsxs as t,jsx as i}from"react/jsx-runtime";import{useMemo as s}from"react";import{usePickaxeContext as o}from"../../../hooks/pickaxe/usePickaxeContext.js";import a from"./PickaxeButton.js";import{STUDIO_INFINITY_VALUE as r,intervalToSuffix as n}from"./PickaxeCommon.js";import{currencyOptions as c}from"./PickaxeCurrency.js";import{Avatar as l,AvatarImage as d,AvatarFallback as m}from"./PickaxeAvatar.js";import{useAuthContext as p}from"../Addons/Auth/hooks/useAuthContext.js";import u from"../../../common/api/pickaxe.js";import{isInIframe as f}from"../../../common/utils.js";import{useResponseContext as x}from"../../../hooks/pickaxe/useResponseContext.js";const b=({data:b,children:h,upgradeUrl:j})=>{var v;const{limitData:g}=x(),{colors:k,sender:y,pickaxe:w}=o(),{token:N}=p(),O=s((()=>{var e;return null!==(e=b.displayName)&&void 0!==e?e:b.name}),[b]),C=s((()=>{var e;return null!==(e=b.displayDescription)&&void 0!==e?e:b.description}),[b]),I=s((()=>{var e;const{price:t,priceInterval:i,currency:s}=b;if(!t)return{price:"Free",suffix:""};const o=n(i,!0);return{price:`${(null!==(e=c.find((e=>e.id===s)))&&void 0!==e?e:c[0]).symbol}${t.toLocaleString()}`,suffix:o}}),[b]),U=s((()=>{const{limit:e,limitInterval:t}=b;if(e===r)return{limit:"Unlimited",suffix:""};const i=n(t,!0);return{limit:e.toLocaleString(),suffix:i}}),[b]);return t("div",Object.assign({className:"relative flex min-h-[260px] w-[220px] shrink-0 snap-center flex-col justify-between rounded-xl border p-4 shadow-sm",style:{backgroundColor:k.secondary,color:k.secondaryText}},{children:[h,t("div",Object.assign({className:"flex flex-col"},{children:[t("div",Object.assign({className:"flex flex-col"},{children:[t(l,Object.assign({className:"h-8 w-8"},{children:[i(d,{src:null!==(v=b.image)&&void 0!==v?v:"",alt:O}),i(m,{})]})),i("p",Object.assign({className:"mt-2 text-sm font-semibold line-clamp-1",title:O},{children:O})),Boolean(C)&&i("p",Object.assign({className:"mt-1 text-[10px] opacity-70 line-clamp-2 leading-tight"},{children:C})),t("p",Object.assign({className:"mt-2 text-base font-semibold"},{children:[I.price,i("span",Object.assign({className:"text-xs font-normal opacity-70"},{children:I.suffix}))]}))]})),t("div",Object.assign({className:"mt-3 flex flex-col border-t py-2",style:{borderTopColor:k.secondaryText}},{children:[i("span",Object.assign({className:"text-[10px] font-bold opacity-50"},{children:"USES"})),t("p",Object.assign({className:"text-base font-semibold"},{children:[U.limit,i("span",Object.assign({className:"text-xs font-normal opacity-70"},{children:U.suffix}))]}))]}))]})),i(a,Object.assign({variant:"primary",className:"w-full mt-2 min-h-[32px] text-xs",onClick:()=>{y||N?e(void 0,void 0,void 0,(function*(){try{const e=yield u.post("/access_group_checkout",{data:{studioUserId:y||void 0,studioId:null==w?void 0:w.studioid,accessGroupId:b.accessGroupId,successUrl:document.URL,isEmbed:f(),studioSessionToken:N}});if(e.data.success){const t=e.data.url;if(t)if(f())try{window.open(t,"_blank")}catch(e){window.open(t,"_blank")}else window.location.href=t;else window.location.reload()}else{const t=e.data.error;alert(t)}}catch(e){alert(e)}})):window.open(j||(null==g?void 0:g.limitLink))}},{children:b.ctaButtonText}))]}))};export{b as default};
@@ -0,0 +1 @@
1
+ import{__rest as a}from"../../../_virtual/_tslib.js";import{jsx as e,jsxs as s}from"react/jsx-runtime";import*as r from"react";import l from"../../../common/cn.js";import*as t from"@radix-ui/react-avatar";const m=r.forwardRef(((s,r)=>{var{className:m}=s,c=a(s,["className"]);return e(t.Root,Object.assign({ref:r,className:l("relative flex h-6 w-6 shrink-0 overflow-hidden rounded-full",m)},c))}));m.displayName=t.Root.displayName;const c=r.forwardRef(((s,r)=>{var{className:m}=s,c=a(s,["className"]);return e(t.Image,Object.assign({ref:r,className:l("aspect-square h-full w-full",m)},c))}));c.displayName=t.Image.displayName;const n=r.forwardRef(((s,r)=>{var{className:m}=s,c=a(s,["className"]);return e(t.Fallback,Object.assign({ref:r,className:l("flex h-full w-full select-none items-center justify-center rounded-full bg-muted text-sm text-muted-foreground",m)},c))}));n.displayName=t.Fallback.displayName;const i=r.forwardRef(((r,t)=>{var{className:i,data:d,max:o=5,avatarClassName:f}=r,u=a(r,["className","data","max","avatarClassName"]);const N=o&&d.length>o,g=N?d.slice(0,o):d,p=N?d.length-o:0;return s("div",Object.assign({ref:t,className:l("flex items-center",i)},u,{children:[g.map((({src:a,initials:r},t)=>e("div",Object.assign({className:l(0!==t&&"-ml-2","rounded-full border-2 border-background"),style:{zIndex:g.length-t}},{children:s(m,Object.assign({},f&&{className:f},{children:[e(c,{src:a}),e(n,Object.assign({className:"text-xs"},{children:r}))]}))}),t))),N&&s("div",Object.assign({className:l("text-sm text-muted-foreground",0!==g.length&&"ml-1"),style:{zIndex:0}},{children:["+",p]}))]}))}));i.displayName="AvatarGroup";export{m as Avatar,n as AvatarFallback,i as AvatarGroup,c as AvatarImage};
@@ -0,0 +1 @@
1
+ const y=(y,e=!1)=>"day"===y?e?"/daily":"/day":"week"===y?e?"/weekly":"/wk":"month"===y?e?"/monthly":"/mo":"year"===y?e?"/yearly":"/yr":"",e=-1337;export{e as STUDIO_INFINITY_VALUE,y as intervalToSuffix};
@@ -0,0 +1 @@
1
+ const l=[{id:"usd",label:"US Dollar ($)",min:.5,symbol:"$",decimals:2},{id:"eur",label:"Euro (€)",min:.5,symbol:"€",decimals:2},{id:"gbp",label:"British Pound (£)",min:.3,symbol:"£",decimals:2},{id:"jpy",label:"Japanese Yen (¥)",min:50,symbol:"¥",decimals:0},{id:"aud",label:"Australian Dollar ($)",min:.5,symbol:"A$",decimals:2},{id:"cad",label:"Canadian Dollar ($)",min:.5,symbol:"C$",decimals:2},{id:"cny",label:"Chinese Yuan (¥)",min:3,symbol:"CN¥",decimals:2},{id:"chf",label:"Swiss Franc (Fr)",min:.5,symbol:"Fr",decimals:2},{id:"inr",label:"Indian Rupee (₹)",min:.5,symbol:"₹",decimals:2},{id:"sgd",label:"Singapore Dollar ($)",min:.5,symbol:"S$",decimals:2},{id:"hkd",label:"Hong Kong Dollar ($)",min:4,symbol:"HK$",decimals:2},{id:"krw",label:"South Korean Won (₩)",min:500,symbol:"₩",decimals:0},{id:"nzd",label:"New Zealand Dollar ($)",min:.5,symbol:"NZ$",decimals:2},{id:"zar",label:"South African Rand (R)",min:5,symbol:"R",decimals:2},{id:"brl",label:"Brazilian Real (R$)",min:.5,symbol:"R$",decimals:2},{id:"mxn",label:"Mexican Peso ($)",min:10,symbol:"MX$",decimals:2},{id:"sek",label:"Swedish Krona (kr)",min:3,symbol:"kr",decimals:2},{id:"nok",label:"Norwegian Krone (kr)",min:3,symbol:"kr",decimals:2},{id:"try",label:"Turkish Lira (₺)",min:.5,symbol:"₺",decimals:2},{id:"thb",label:"Thai Baht (฿)",min:10,symbol:"฿",decimals:2},{id:"pln",label:"Polish Złoty (zł)",min:2,symbol:"zł",decimals:2},{id:"myr",label:"Malaysian Ringgit (RM)",min:2,symbol:"RM",decimals:2},{id:"idr",label:"Indonesian Rupiah (Rp)",min:5e3,symbol:"Rp",decimals:2},{id:"czk",label:"Czech Koruna (Kč)",min:15,symbol:"Kč",decimals:2},{id:"bgn",label:"Bulgarian Lev (лв)",min:1,symbol:"лв",decimals:2},{id:"rub",label:"Russian Ruble (₽)",min:30,symbol:"₽",decimals:2}];export{l as currencyOptions};
@@ -1 +1 @@
1
- import{jsx as e,jsxs as o}from"react/jsx-runtime";import{AnimatePresence as s}from"framer-motion";import{usePickaxeContext as t}from"../../../hooks/pickaxe/usePickaxeContext.js";import{useResponseContext as r}from"../../../hooks/pickaxe/useResponseContext.js";import{useStyleFontSize as i}from"../../../hooks/studio/useStyleFontSize.js";import{isInIframe as m}from"../../../common/utils.js";import a from"../../Icons/circle-exclamation.svg.js";import c from"../../Core/SpringTransition.js";import n from"../../Core/HtmlRenderer.js";import l from"./PickaxeButton.js";import p from"../../../common/cn.js";const f=({className:f,iconClassName:h,htmlClassName:x})=>{const{colors:j}=t(),{limitData:d}=r(),g=i(),u=window.location.href.includes("_embed");return e(s,{children:!!d&&o(c,Object.assign({className:p("flex gap-3",f)},{children:[e(a,{className:p("h-5 w-5 shrink-0",h),style:{color:j.accent}}),o("div",Object.assign({className:"flex flex-col gap-4"},{children:[e(n,{className:p(g.b2,"font-semibold",x),style:{color:j.text},html:d.html}),!!d.cta&&e("a",Object.assign({href:d.ctaLink,target:m()&&!u?"_self":"_top",rel:"noreferrer"},{children:e(l,Object.assign({variant:"primary",className:"min-h-[38px]",style:{minHeight:"38px"}},{children:d.cta}))}))]}))]}))})};export{f as default};
1
+ import{__awaiter as e}from"../../../_virtual/_tslib.js";import{jsx as s,jsxs as o}from"react/jsx-runtime";import{useState as r,useEffect as t}from"react";import{AnimatePresence as a}from"framer-motion";import{usePickaxeContext as i}from"../../../hooks/pickaxe/usePickaxeContext.js";import{useResponseContext as l}from"../../../hooks/pickaxe/useResponseContext.js";import{useStyleFontSize as c}from"../../../hooks/studio/useStyleFontSize.js";import{isInIframe as n}from"../../../common/utils.js";import m from"../../Icons/circle-exclamation.svg.js";import d from"../../Core/SpringTransition.js";import p from"../../Core/HtmlRenderer.js";import u from"./PickaxeButton.js";import f from"../../../common/cn.js";import x from"../../../common/api/pickaxe.js";import{useAuthContext as b}from"../Addons/Auth/hooks/useAuthContext.js";import h from"./AccessGroupCardPreview.js";const g=({price:e,uses:s,isSelected:r,onClick:t,colors:a})=>o("button",Object.assign({onClick:t,className:f("flex items-center gap-2 rounded-xl border px-4 py-3 shadow-sm transition-all duration-200 shrink-0",r?"border-2":"border opacity-80 hover:opacity-100"),style:{backgroundColor:a.secondary,color:a.secondaryText,borderColor:r?a.secondaryText:"rgba(0,0,0,0.1)"}},{children:[o("span",Object.assign({className:"text-xl font-bold"},{children:["$",e]})),o("span",Object.assign({className:"text-sm opacity-70"},{children:["/ ",s.toLocaleString()," uses"]}))]})),y=({className:y,iconClassName:j,htmlClassName:v})=>{var w,k;const{colors:N,pickaxe:C,sender:O}=i(),{token:A}=b(),{limitData:_}=l(),U=c(),[S,G]=r(0),T=window.location.href.includes("_embed"),L=n()&&!T?"_self":"_top";if(t((()=>{var e;(null===(e=null==_?void 0:_.buyUses)||void 0===e?void 0:e.length)&&G(0)}),[_]),!_)return null;const P=_.limitLink,B=_.limitCTA,I=Array.isArray(_.upgradeGroups)&&_.upgradeGroups.length>0,R=Array.isArray(_.buyUses)&&_.buyUses.length>0,$=R&&Array.isArray(_.buyUses)&&_.buyUses[S];return s(a,{children:o(d,Object.assign({className:f("flex flex-col gap-5 w-full",y)},{children:[o("div",Object.assign({className:"flex flex-col sm:flex-row gap-4 items-start sm:items-center justify-between rounded-lg p-3 bg-opacity-5",style:{backgroundColor:N.secondary}},{children:[o("div",Object.assign({className:"flex gap-3 items-start"},{children:[s(m,{className:f("h-5 w-5 shrink-0 mt-0.5",j),style:{color:N.accent}}),s(p,{className:f(U.b2,"font-semibold leading-relaxed text-sm",v),style:{color:N.text},html:_.limitMessage||""})]})),B&&s("a",Object.assign({href:P,target:L,rel:"noreferrer",className:"shrink-0 w-full sm:w-auto"},{children:s(u,Object.assign({variant:"primary",className:"whitespace-nowrap min-h-[32px] w-full sm:w-auto text-sm"},{children:B}))}))]})),I&&o("div",Object.assign({className:"flex flex-col gap-2"},{children:[s("h3",Object.assign({className:"text-xs font-bold opacity-70 uppercase px-1",style:{color:N.text}},{children:"Available Plans"})),s("div",Object.assign({className:"flex flex-row gap-3 overflow-x-auto pb-4 pt-1 snap-x scrollbar-thin"},{children:null===(w=_.upgradeGroups)||void 0===w?void 0:w.map(((e,o)=>s(h,{data:e},e.accessGroupId||o)))}))]})),R&&$&&o("div",Object.assign({className:"flex flex-col gap-3"},{children:[s("h3",Object.assign({className:"text-xs font-bold opacity-70 uppercase px-1",style:{color:N.text}},{children:"Buy Credits"})),s("div",Object.assign({className:"flex flex-row gap-3 overflow-x-auto pb-2 pt-1 snap-x scrollbar-thin"},{children:null===(k=_.buyUses)||void 0===k?void 0:k.map(((e,o)=>s(g,{price:e.price,uses:e.uses,isSelected:o===S,onClick:()=>G(o),colors:N},o)))})),o(u,Object.assign({variant:"primary",className:"w-full py-3 text-sm font-bold shadow-md",onClick:()=>{return s=$.uses,o=$.price,e(void 0,void 0,void 0,(function*(){try{const e=yield x.post("/get_extra_usage_payment_link",{data:{sender:O||void 0,studioSessionToken:A,studioId:null==C?void 0:C.studioid,cost:o,extraUses:s,successUrl:document.URL}});if(e.data.success){const s=e.data.url;if(n())try{window.open(s,"_blank")}catch(e){window.open(s,"_blank")}else window.location.href=s}else{const s=e.data.error;alert(s)}}catch(e){alert(e)}}));var s,o}},{children:["Buy ",$.uses.toLocaleString()," Uses for $",$.price]}))]}))]}))})};export{y as default};
@@ -1 +1 @@
1
- import{jsx as t,Fragment as e,jsxs as o}from"react/jsx-runtime";import{usePickaxe as s}from"../../hooks/pickaxe/usePickaxe.js";import{useState as r,useEffect as a,useMemo as i}from"react";import{usePickaxeContext as n}from"../../hooks/pickaxe/usePickaxeContext.js";import{useAuthContext as l}from"./Addons/Auth/hooks/useAuthContext.js";import{useResponseContext as m}from"../../hooks/pickaxe/useResponseContext.js";import{useDocumentContext as c}from"./Addons/Document/hooks/useDocumentContext.js";import{useArtifactContext as p}from"./Addons/Artifact/hooks/useArtifactContext.js";import{v4 as x}from"uuid";import{ScrollProvider as d}from"./Addons/Scroll/Provider.js";import f from"./common/PickaxeSkeleton.js";import u from"./Chat/index.js";import h from"./Form/index.js";import k from"./Addons/Auth/index.js";import j from"../../common/cn.js";const w=({pickaxeId:w,className:g})=>{const{sessionId:y,styles:A,colors:C,responsiveBy:N,deploymentType:b,isNewChat:v,isEmailLogin:P,opacity:S,setContextId:I,setPickaxeId:O,setSessionId:D,setPickaxe:L}=n(),{isLoggedOut:E,isSent:R}=l(),{setMessages:F,setResponse:M,setError:T,setLimitData:$,setIsSwitchedToChat:B}=m(),{setDocumentError:H}=c(),{setCurrentArtifact:W}=p(),[q,z]=r(!1),G=s(),J="chat-input"===b&&v&&!R,K="chat-input"!==b||!R;a((()=>{O(w)}),[w]),a((()=>{if(!G.data)return;const t=G.data.chatflag;D(t?x():""),I(x()),t?F([]):M(null),T(""),H(""),$(null),W(null),B(!1),L(G.data),z(!0)}),[G.data]),a((()=>{T(""),H(""),$(null),F([]),M(null),W(null)}),[y]);const Q=i((()=>{const t=null!=S?S:1;if(!C.primary||!C.primary.startsWith("#")||t<0||t>1)return C.primary;const e=Math.round(255*t).toString(16).padStart(2,"0");return`${C.primary}${e}`}),[C.primary,S]);return G.data?t("div",Object.assign({className:j("relative @container/pickaxe-root flex flex-col flex-grow w-full h-full","dark"===A.theme&&"dark",g),style:Object.assign({backgroundColor:J?"transparent":Q,color:C.text},A.font&&"Real Head Pro"!==A.font&&{fontFamily:A.font})},{children:P&&E&&K?t(k,{}):t(e,{children:G.isLoading||!q?t("div",Object.assign({className:j("flex items-center flex-col w-full pt-12 px-4 pb-10","viewport"===N?"min-[767px]:pb-40":"@[767px]/pickaxe-root:pb-40")},{children:o("div",Object.assign({className:"flex w-full items-center max-w-[700px] flex-col"},{children:[t(f,{className:"w-[72px] h-[72px]"}),t(f,{className:"h-[20px] mt-6 w-full"}),t(f,{className:"h-[20px] mt-2 w-full"}),t(f,{className:"h-[20px] mt-2 w-full max-w-[400px]"}),t("div",Object.assign({className:"flex flex-col gap-y-8 w-full mt-6"},{children:t(f,{className:j("w-full min-h-[48px]","viewport"===N?"min-[767px]:max-w-[176px]":"@[767px]/pickaxe-root:max-w-[176px]")})}))]}))})):t(e,{children:t(d,y?{children:t(u,{})}:{children:t(h,{})})})})})):null};export{w as Pickaxe};
1
+ import{__awaiter as e}from"../../_virtual/_tslib.js";import{jsx as t,jsxs as s}from"react/jsx-runtime";import{usePickaxe as a}from"../../hooks/pickaxe/usePickaxe.js";import{useState as o,useEffect as i,useMemo as r}from"react";import{usePickaxeContext as l}from"../../hooks/pickaxe/usePickaxeContext.js";import{useAuthContext as c}from"./Addons/Auth/hooks/useAuthContext.js";import{useResponseContext as n}from"../../hooks/pickaxe/useResponseContext.js";import{useDocumentContext as d}from"./Addons/Document/hooks/useDocumentContext.js";import{useArtifactContext as m}from"./Addons/Artifact/hooks/useArtifactContext.js";import{v4 as p}from"uuid";import{ScrollProvider as u}from"./Addons/Scroll/Provider.js";import f from"./common/PickaxeSkeleton.js";import x from"./Chat/index.js";import h from"./Form/index.js";import g from"./Addons/Auth/index.js";import j from"../../common/cn.js";import b from"../../common/api/pickaxe.js";import v from"./common/AccessGroupCardPreview.js";const w=({pickaxeId:w,className:y})=>{const{sessionId:N,styles:k,colors:O,responsiveBy:A,deploymentType:C,isNewChat:_,isEmailLogin:q,isEmbed:I,opacity:P,deploymentId:S,sender:L,portalId:D,setContextId:E,setPickaxeId:R,setSessionId:T,setPickaxe:U}=l(),{isLoggedOut:F,isSent:G,token:M}=c(),{setMessages:$,setResponse:B,setError:H,setLimitData:W,setIsSwitchedToChat:z}=n(),{setDocumentError:J}=d(),{setCurrentArtifact:K}=m(),[Q,V]=o(!1),[X,Y]=o("loading"),[Z,ee]=o([]),[te,se]=o(null),ae=a(),oe="chat-input"===C&&_&&!G,ie="chat-input"!==C||!G;i((()=>{R(w)}),[w]),i((()=>{if(!S||!ae.data)return;e(void 0,void 0,void 0,(function*(){var e;Y("loading");try{const t=yield b.post("/validate_studio_deployment",{data:{deploymentId:S,sender:L||void 0,studioSessionToken:M,portalId:D,studioId:null===(e=ae.data)||void 0===e?void 0:e.studioid}});t.data.success?Y("success"):"Login required."===t.data.message?(Y("login_required"),V(!0)):"Access denied."===t.data.message?(Y("access_denied"),V(!0)):"Upgrade required."===t.data.message?(Y("upgrade_required"),ee(t.data.upgradeGroups||[]),se(t.data.upgradeUrl),V(!0)):Y("login_required")}catch(e){console.error("Failed to validate deployment:",e),Y("success")}}))}),[S,L,M,D,ae.data]),i((()=>{if(!ae.data)return;const e=ae.data.chatflag;T(e?p():""),E(p()),e?$([]):B(null),H(""),J(""),W(null),K(null),z(!1),U(ae.data),V(!0)}),[ae.data]),i((()=>{H(""),J(""),W(null),$([]),B(null),K(null)}),[N]);const re=r((()=>{const e=null!=P?P:1;if(!O.primary||!O.primary.startsWith("#")||e<0||e>1)return O.primary;const t=Math.round(255*e).toString(16).padStart(2,"0");return`${O.primary}${t}`}),[O.primary,P]);if(!ae.data)return null;return t("div",Object.assign({className:j("relative @container/pickaxe-root flex flex-col flex-grow w-full h-full","dark"===k.theme&&"dark",y),style:Object.assign({backgroundColor:oe?"transparent":re,color:O.text},k.font&&"Real Head Pro"!==k.font&&{fontFamily:k.font})},{children:ae.isLoading||!Q||"loading"===X?t("div",Object.assign({className:j("flex items-center flex-col w-full pt-12 px-4 pb-10","viewport"===A?"min-[767px]:pb-40":"@[767px]/pickaxe-root:pb-40")},{children:s("div",Object.assign({className:"flex w-full items-center max-w-[700px] flex-col"},{children:[t(f,{className:"w-[72px] h-[72px]"}),t(f,{className:"h-[20px] mt-6 w-full"}),t(f,{className:"h-[20px] mt-2 w-full"}),t(f,{className:"h-[20px] mt-2 w-full max-w-[400px]"}),t("div",Object.assign({className:"flex flex-col gap-y-8 w-full mt-6"},{children:t(f,{className:j("w-full min-h-[48px]","viewport"===A?"min-[767px]:max-w-[176px]":"@[767px]/pickaxe-root:max-w-[176px]")})}))]}))})):"upgrade_required"===X?t("div",Object.assign({className:"flex flex-col items-center justify-center w-full h-full p-4 overflow-y-auto"},{children:Z&&Z.length>0?s("div",Object.assign({className:"flex flex-col items-center gap-6 w-full max-w-4xl"},{children:[s("div",Object.assign({className:"text-center"},{children:[t("h2",Object.assign({className:"text-2xl font-bold mb-2"},{children:"Upgrade Required"})),t("p",Object.assign({className:"opacity-80"},{children:"Please upgrade to continue using this tool."}))]})),t("div",Object.assign({className:"flex flex-wrap justify-center gap-4 w-full"},{children:Z.map(((e,s)=>t(v,{data:e,upgradeUrl:te},e.id||s)))}))]})):s("div",Object.assign({className:"text-center mb-8"},{children:[t("h2",Object.assign({className:"text-2xl font-bold mb-2"},{children:"Access Locked"})),t("p",Object.assign({className:"opacity-80"},{children:"This tool is locked to use. Contact owner for more information."}))]}))})):"login_required"===X&&I||q&&F&&ie?t(g,{}):"login_required"!==X||I?"access_denied"===X?t("div",Object.assign({className:"flex flex-col items-center justify-center w-full h-full p-4 overflow-y-auto"},{children:s("div",Object.assign({className:"text-center mb-8"},{children:[t("h2",Object.assign({className:"text-2xl font-bold mb-2"},{children:"Access Denied"})),t("p",Object.assign({className:"opacity-80"},{children:"Contact tool owner to request access."}))]}))})):t(u,N?{children:t(x,{})}:{children:t(h,{})}):t("div",Object.assign({className:"flex flex-col items-center justify-center w-full h-full p-4 overflow-y-auto"},{children:s("div",Object.assign({className:"text-center mb-8"},{children:[t("h2",Object.assign({className:"text-2xl font-bold mb-2"},{children:"Access Denied"})),t("p",Object.assign({className:"opacity-80"},{children:"Login is required."}))]}))}))}))};export{w as Pickaxe};
@@ -65,6 +65,7 @@ type PickaxeContextType = {
65
65
  deploymentType?: PickaxeDeploymentEmbedType;
66
66
  deploymentDimensions?: PickaxeDeploymentDimensions;
67
67
  deploymentMisc?: PickaxeDeploymentMisc;
68
+ portalId?: string;
68
69
  pickaxe: LimitedPickaxe | null;
69
70
  styles: PickaxeProviderStyles;
70
71
  colors: PickaxeProviderColors;
@@ -107,6 +108,7 @@ export interface IPickaxeProviderProps {
107
108
  sender?: string;
108
109
  senderType: PickaxeHistorySenderType;
109
110
  deploymentId?: string;
111
+ portalId?: string;
110
112
  deploymentType?: PickaxeDeploymentEmbedType;
111
113
  deploymentDimensions?: PickaxeDeploymentDimensions;
112
114
  deploymentMisc?: PickaxeDeploymentMisc;
@@ -132,5 +134,5 @@ export interface IPickaxeProviderProps {
132
134
  onGenerateComplete?: (responseId: string) => void;
133
135
  }
134
136
  export declare const PickaxeContext: import("react").Context<PickaxeContextType>;
135
- export declare const PickaxeProvider: ({ children, origin, sender: _sender, senderType: _senderType, deploymentId, deploymentType, deploymentDimensions, deploymentMisc, styles, colors, limits, misc, translations, artifact, responsiveBy, locale, opacity, forceMobile, disableHtml, disableJs, disableCss, loadFont, isRtl, isEmbed, isDropShadow, isEmailLogin, allowGuestUsage, onGenerateComplete, }: IPickaxeProviderProps) => import("react/jsx-runtime").JSX.Element;
137
+ export declare const PickaxeProvider: ({ children, origin, sender: _sender, senderType: _senderType, portalId, deploymentId, deploymentType, deploymentDimensions, deploymentMisc, styles, colors, limits, misc, translations, artifact, responsiveBy, locale, opacity, forceMobile, disableHtml, disableJs, disableCss, loadFont, isRtl, isEmbed, isDropShadow, isEmailLogin, allowGuestUsage, onGenerateComplete, }: IPickaxeProviderProps) => import("react/jsx-runtime").JSX.Element;
136
138
  export {};
@@ -3,9 +3,12 @@ import type { MemoryStoredChatMessage, MemoryStoredFormResponse } from "../../ty
3
3
  import { type ReactNode } from "react";
4
4
  export type ResponseStatus = "fetching" | "streaming" | "idle";
5
5
  export type PickaxeLimitData = {
6
- html: string;
7
- cta: string;
8
- ctaLink: string;
6
+ limitMessage: string;
7
+ buyUses?: any[];
8
+ upgradeGroups?: any[];
9
+ limitLink?: string;
10
+ limitCTA: string;
11
+ accessGroupId: string;
9
12
  };
10
13
  type ResponseContextType = {
11
14
  messages: MemoryStoredChatMessage[];
@@ -0,0 +1,9 @@
1
+ import { ReactNode } from "react";
2
+ interface AccessGroupCardPreviewProps {
3
+ data: any;
4
+ accessGroupId?: string;
5
+ upgradeUrl?: string | null;
6
+ children?: ReactNode;
7
+ }
8
+ declare const AccessGroupCardPreview: ({ data, children, upgradeUrl, }: AccessGroupCardPreviewProps) => import("react/jsx-runtime").JSX.Element;
9
+ export default AccessGroupCardPreview;
@@ -0,0 +1,16 @@
1
+ import * as React from "react";
2
+ import * as AvatarPrimitive from "@radix-ui/react-avatar";
3
+ declare const Avatar: React.ForwardRefExoticComponent<Omit<AvatarPrimitive.AvatarProps & React.RefAttributes<HTMLSpanElement>, "ref"> & React.RefAttributes<HTMLSpanElement>>;
4
+ declare const AvatarImage: React.ForwardRefExoticComponent<Omit<AvatarPrimitive.AvatarImageProps & React.RefAttributes<HTMLImageElement>, "ref"> & React.RefAttributes<HTMLImageElement>>;
5
+ declare const AvatarFallback: React.ForwardRefExoticComponent<Omit<AvatarPrimitive.AvatarFallbackProps & React.RefAttributes<HTMLSpanElement>, "ref"> & React.RefAttributes<HTMLSpanElement>>;
6
+ export type AvatarGroupItem = {
7
+ src?: string;
8
+ initials: string;
9
+ };
10
+ export interface AvatarGroupProps extends React.HTMLAttributes<HTMLDivElement> {
11
+ data: AvatarGroupItem[];
12
+ max?: number;
13
+ avatarClassName?: string;
14
+ }
15
+ declare const AvatarGroup: React.ForwardRefExoticComponent<AvatarGroupProps & React.RefAttributes<HTMLDivElement>>;
16
+ export { Avatar, AvatarImage, AvatarFallback, AvatarGroup };
@@ -0,0 +1,2 @@
1
+ export declare const intervalToSuffix: (interval: string | null, isFullText?: boolean) => "/daily" | "/day" | "/weekly" | "/wk" | "/monthly" | "/mo" | "/yearly" | "/yr" | "";
2
+ export declare const STUDIO_INFINITY_VALUE = -1337;
@@ -0,0 +1,7 @@
1
+ export declare const currencyOptions: {
2
+ id: string;
3
+ label: string;
4
+ min: number;
5
+ symbol: string;
6
+ decimals: number;
7
+ }[];
@@ -3,5 +3,5 @@ interface PickaxeUpgradeCardProps {
3
3
  iconClassName?: string;
4
4
  htmlClassName?: string;
5
5
  }
6
- declare const PickaxeUpgradeCard: ({ className, iconClassName, htmlClassName, }: PickaxeUpgradeCardProps) => import("react/jsx-runtime").JSX.Element;
6
+ declare const PickaxeUpgradeCard: ({ className, iconClassName, htmlClassName, }: PickaxeUpgradeCardProps) => import("react/jsx-runtime").JSX.Element | null;
7
7
  export default PickaxeUpgradeCard;
@@ -10,6 +10,7 @@ export declare const usePickaxeContext: () => {
10
10
  deploymentType?: import("../../components/Pickaxe/Provider").PickaxeDeploymentEmbedType | undefined;
11
11
  deploymentDimensions?: import("../../components/Pickaxe/Provider").PickaxeDeploymentDimensions | undefined;
12
12
  deploymentMisc?: import("../../components/Pickaxe/Provider").PickaxeDeploymentMisc | undefined;
13
+ portalId?: string | undefined;
13
14
  pickaxe: import("../../types/pickaxe").LimitedPickaxe | null;
14
15
  styles: import("../../components/Pickaxe/Provider").PickaxeProviderStyles;
15
16
  colors: import("../../components/Pickaxe/Provider").PickaxeProviderColors;
@@ -9,3 +9,11 @@ export type MemoryStoredFormResponse = {
9
9
  messageCount: number;
10
10
  sentAt: Date;
11
11
  };
12
+ export interface LimitData {
13
+ limitMessage: string;
14
+ buyUses?: any[];
15
+ upgradeGroups?: any[];
16
+ limitLink?: string;
17
+ accessGroupId?: string;
18
+ limitCTA?: string;
19
+ }