@pickaxeproject/react 0.0.59 → 0.0.61
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/components/Icons/arrow-right.svg.js +1 -0
- package/dist/cjs/components/Icons/{send.svg.js → arrow-up-right.svg.js} +1 -1
- package/dist/cjs/components/Icons/eye.svg.js +1 -0
- package/dist/cjs/components/Pickaxe/Chat/History/Message.js +1 -1
- package/dist/cjs/components/Pickaxe/Chat/History/index.js +1 -1
- package/dist/cjs/components/Pickaxe/Chat/Input.js +1 -1
- package/dist/cjs/components/Pickaxe/Form/Questions/Submit.js +1 -1
- package/dist/cjs/components/Pickaxe/Form/index.js +1 -1
- package/dist/cjs/components/Pickaxe/common/PickaxeHead.js +1 -0
- package/dist/cjs/components/Pickaxe/common/PickaxeIcon.js +1 -1
- package/dist/cjs/components/Pickaxe/common/PickaxeInfoModal.js +1 -1
- package/dist/cjs/components/Pickaxe/common/PickaxeMarkdown/Custom/A/index.js +1 -1
- package/dist/cjs/components/Pickaxe/common/PickaxeMarkdown/Custom/Img/ImgModal.js +1 -1
- package/dist/cjs/components/Pickaxe/common/PickaxeMarkdown/Custom/P/index.js +1 -1
- package/dist/cjs/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Action.js +1 -1
- package/dist/cjs/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Audio.js +1 -0
- package/dist/cjs/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Html/HtmlModal.js +1 -0
- package/dist/cjs/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Html/index.js +1 -0
- package/dist/cjs/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Modal/Body.js +1 -0
- package/dist/cjs/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Modal/index.js +1 -0
- package/dist/cjs/src/common/api/streamer.d.ts +1 -0
- package/dist/cjs/src/components/Pickaxe/common/PickaxeHead.d.ts +7 -0
- package/dist/cjs/src/components/Pickaxe/common/PickaxeIcon.d.ts +2 -1
- package/dist/cjs/src/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Audio.d.ts +5 -0
- package/dist/cjs/src/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Html/HtmlModal.d.ts +7 -0
- package/dist/cjs/src/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Html/index.d.ts +5 -0
- package/dist/cjs/src/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Modal/Body.d.ts +6 -0
- package/dist/cjs/src/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Modal/CloseButton.d.ts +9 -0
- package/dist/cjs/src/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Modal/index.d.ts +15 -0
- package/dist/cjs/src/hooks/pickaxe/useSubmit.d.ts +1 -0
- package/dist/cjs/src/hooks/studio/useStyleFontSize.d.ts +2 -2
- package/dist/esm/components/Icons/arrow-right.svg.js +1 -0
- package/dist/esm/components/Icons/{send.svg.js → arrow-up-right.svg.js} +1 -1
- package/dist/esm/components/Icons/eye.svg.js +1 -0
- package/dist/esm/components/Pickaxe/Chat/History/Message.js +1 -1
- package/dist/esm/components/Pickaxe/Chat/History/index.js +1 -1
- package/dist/esm/components/Pickaxe/Chat/Input.js +1 -1
- package/dist/esm/components/Pickaxe/Form/Questions/Submit.js +1 -1
- package/dist/esm/components/Pickaxe/Form/index.js +1 -1
- package/dist/esm/components/Pickaxe/common/PickaxeHead.js +1 -0
- package/dist/esm/components/Pickaxe/common/PickaxeIcon.js +1 -1
- package/dist/esm/components/Pickaxe/common/PickaxeInfoModal.js +1 -1
- package/dist/esm/components/Pickaxe/common/PickaxeMarkdown/Custom/A/index.js +1 -1
- package/dist/esm/components/Pickaxe/common/PickaxeMarkdown/Custom/Img/ImgModal.js +1 -1
- package/dist/esm/components/Pickaxe/common/PickaxeMarkdown/Custom/P/index.js +1 -1
- package/dist/esm/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Action.js +1 -1
- package/dist/esm/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Audio.js +1 -0
- package/dist/esm/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Html/HtmlModal.js +1 -0
- package/dist/esm/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Html/index.js +1 -0
- package/dist/esm/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Modal/Body.js +1 -0
- package/dist/esm/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Modal/index.js +1 -0
- package/dist/esm/src/common/api/streamer.d.ts +1 -0
- package/dist/esm/src/components/Pickaxe/common/PickaxeHead.d.ts +7 -0
- package/dist/esm/src/components/Pickaxe/common/PickaxeIcon.d.ts +2 -1
- package/dist/esm/src/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Audio.d.ts +5 -0
- package/dist/esm/src/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Html/HtmlModal.d.ts +7 -0
- package/dist/esm/src/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Html/index.d.ts +5 -0
- package/dist/esm/src/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Modal/Body.d.ts +6 -0
- package/dist/esm/src/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Modal/CloseButton.d.ts +9 -0
- package/dist/esm/src/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Modal/index.d.ts +15 -0
- package/dist/esm/src/hooks/pickaxe/useSubmit.d.ts +1 -0
- package/dist/esm/src/hooks/studio/useStyleFontSize.d.ts +2 -2
- package/package.json +1 -1
- package/dist/cjs/components/Pickaxe/Form/Head.js +0 -1
- package/dist/cjs/src/components/Pickaxe/Form/Head.d.ts +0 -2
- package/dist/esm/components/Pickaxe/Form/Head.js +0 -1
- package/dist/esm/src/components/Pickaxe/Form/Head.d.ts +0 -2
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";function e(e){if(e&&e.__esModule)return e;var r=Object.create(null);return e&&Object.keys(e).forEach((function(t){if("default"!==t){var n=Object.getOwnPropertyDescriptor(e,t);Object.defineProperty(r,t,n.get?n:{enumerable:!0,get:function(){return e[t]}})}})),r.default=e,Object.freeze(r)}Object.defineProperty(exports,"__esModule",{value:!0});var r,t=e(require("react"));function n(){return n=Object.assign?Object.assign.bind():function(e){for(var r=1;r<arguments.length;r++){var t=arguments[r];for(var n in t)({}).hasOwnProperty.call(t,n)&&(e[n]=t[n])}return e},n.apply(null,arguments)}var l=e=>t.createElement("svg",n({xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24"},e),r||(r=t.createElement("path",{fill:"currentColor",d:"m16.175 11-5.6-5.6L12 4l8 8-8 8-1.425-1.4 5.6-5.6H4v-2z"})));exports.default=l;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";function e(e){if(e&&e.__esModule)return e;var r=Object.create(null);return e&&Object.keys(e).forEach((function(t){if("default"!==t){var n=Object.getOwnPropertyDescriptor(e,t);Object.defineProperty(r,t,n.get?n:{enumerable:!0,get:function(){return e[t]}})}})),r.default=e,Object.freeze(r)}Object.defineProperty(exports,"__esModule",{value:!0});var r,t=e(require("react"));function n(){return n=Object.assign?Object.assign.bind():function(e){for(var r=1;r<arguments.length;r++){var t=arguments[r];for(var n in t)({}).hasOwnProperty.call(t,n)&&(e[n]=t[n])}return e},n.apply(null,arguments)}var o=e=>t.createElement("svg",n({xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0
|
|
1
|
+
"use strict";function e(e){if(e&&e.__esModule)return e;var r=Object.create(null);return e&&Object.keys(e).forEach((function(t){if("default"!==t){var n=Object.getOwnPropertyDescriptor(e,t);Object.defineProperty(r,t,n.get?n:{enumerable:!0,get:function(){return e[t]}})}})),r.default=e,Object.freeze(r)}Object.defineProperty(exports,"__esModule",{value:!0});var r,t=e(require("react"));function n(){return n=Object.assign?Object.assign.bind():function(e){for(var r=1;r<arguments.length;r++){var t=arguments[r];for(var n in t)({}).hasOwnProperty.call(t,n)&&(e[n]=t[n])}return e},n.apply(null,arguments)}var o=e=>t.createElement("svg",n({xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24"},e),r||(r=t.createElement("path",{stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M7 17 17 7M7 7h10v10"})));exports.default=o;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";function e(e){if(e&&e.__esModule)return e;var r=Object.create(null);return e&&Object.keys(e).forEach((function(t){if("default"!==t){var n=Object.getOwnPropertyDescriptor(e,t);Object.defineProperty(r,t,n.get?n:{enumerable:!0,get:function(){return e[t]}})}})),r.default=e,Object.freeze(r)}Object.defineProperty(exports,"__esModule",{value:!0});var r,t,n=e(require("react"));function o(){return o=Object.assign?Object.assign.bind():function(e){for(var r=1;r<arguments.length;r++){var t=arguments[r];for(var n in t)({}).hasOwnProperty.call(t,n)&&(e[n]=t[n])}return e},o.apply(null,arguments)}var a=e=>n.createElement("svg",o({xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24"},e),r||(r=n.createElement("path",{stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M1 12.5s4-8 11-8 11 8 11 8-4 8-11 8-11-8-11-8"})),t||(t=n.createElement("path",{stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M12 15.5a3 3 0 1 0 0-6 3 3 0 0 0 0 6"})));exports.default=a;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),s=require("../../../../hooks/pickaxe/usePickaxeContext.js"),a=require("../../../../hooks/studio/useStyleFontSize.js"),t=require("../../common/PickaxeMarkdown/index.js"),o=require("../../common/PickaxeMarkdown/Renderer.js"),c=require("../../common/PickaxeIcon.js"),r=require("../../common/PickaxeCopyButton.js"),i=require("../../../../common/cn.js");exports.default=({message:n})=>{var l;const{formId:x,pickaxe:d,styles:m,colors:u,misc:j,responsiveBy:h}=s.usePickaxeContext(),p=a.useStyleFontSize(),k=null!==(l=null==d?void 0:d.chaticon)&&void 0!==l?l:`https://prod-pickaxe-assets.s3.us-west-2.amazonaws.com/chaticons/${x}.png`;return"assistant"===n.role?e.jsx("div",Object.assign({className:i.default("flex flex-col","viewport"===h?"min-[767px]:max-w-[80%]":"@[767px]/pickaxe-root:max-w-[80%]")},{children:e.jsxs("div",Object.assign({className:"flex gap-x-3"},{children:[j.isChatImage&&"NONE"!==k&&e.jsx(c.default,{src:k,alt:"Assistant",width:24,height:24,className:"my-3 h-6 w-6",textColor:u.text}),e.jsxs("div",Object.assign({className:"flex flex-col"},{children:[e.jsx("div",Object.assign({className:i.default(p.b2,"chat-message overflow-x-auto overflow-y-hidden rounded px-4 py-3 scrollbar-thin scrollbar-track-white scrollbar-thumb-[#4A4A4B]")
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),s=require("../../../../hooks/pickaxe/usePickaxeContext.js"),a=require("../../../../hooks/studio/useStyleFontSize.js"),t=require("../../common/PickaxeMarkdown/index.js"),o=require("../../common/PickaxeMarkdown/Renderer.js"),c=require("../../common/PickaxeIcon.js"),r=require("../../common/PickaxeCopyButton.js"),i=require("../../../../common/cn.js");exports.default=({message:n})=>{var l;const{formId:x,pickaxe:d,styles:m,colors:u,misc:j,responsiveBy:h}=s.usePickaxeContext(),p=a.useStyleFontSize(),k=null!==(l=null==d?void 0:d.chaticon)&&void 0!==l?l:`https://prod-pickaxe-assets.s3.us-west-2.amazonaws.com/chaticons/${x}.png`;return"assistant"===n.role?e.jsx("div",Object.assign({className:i.default("flex flex-col","viewport"===h?"min-[767px]:max-w-[80%]":"@[767px]/pickaxe-root:max-w-[80%]")},{children:e.jsxs("div",Object.assign({className:"flex gap-x-3"},{children:[j.isChatImage&&"NONE"!==k&&e.jsx(c.default,{src:k,alt:"Assistant",width:24,height:24,className:"my-3 h-6 w-6",textColor:u.text}),e.jsxs("div",Object.assign({className:"flex flex-col"},{children:[e.jsx("div",Object.assign({className:i.default(p.b2,"chat-message overflow-x-auto overflow-y-hidden rounded px-4 py-3 scrollbar-thin scrollbar-track-white scrollbar-thumb-[#4A4A4B]")},{children:e.jsx(t.PickaxeMarkdown,Object.assign({theme:m.theme,accentColor:u.accent,linkPreviews:!0,actions:!0},{children:e.jsx(o.PickaxeMarkdownRenderer,{value:n.content})}))})),e.jsx("div",Object.assign({className:"mb-2 ml-2 mt-4 flex gap-3"},{children:e.jsx(r.default,{color:u.accent,text:n.content})}))]}))]}))})):"user"===n.role?e.jsx("div",Object.assign({className:i.default("flex gap-x-3 justify-self-end pl-9","viewport"===h?"min-[767px]:max-w-[80%] min-[767px]:pl-0":"@[767px]/pickaxe-root:max-w-[80%] @[767px]/pickaxe-root:pl-0")},{children:e.jsx("div",Object.assign({className:i.default(p.b2,"overflow-x-auto overflow-y-hidden rounded px-4 py-3 scrollbar-thin scrollbar-track-white scrollbar-thumb-[#4A4A4B]"),style:{backgroundColor:u.secondary+"80",color:u.secondaryText}},{children:e.jsx(t.PickaxeMarkdown,Object.assign({theme:m.theme,accentColor:u.accent},{children:e.jsx(o.PickaxeMarkdownRenderer,{value:n.content})}))}))})):e.jsx("div",{})};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),s=require("react"),a=require("../../../../hooks/pickaxe/usePickaxeContext.js"),t=require("../../../../hooks/pickaxe/useResponseContext.js"),l=require("../../../../hooks/studio/useStyleFontSize.js"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),s=require("react"),a=require("../../../../hooks/pickaxe/usePickaxeContext.js"),t=require("../../../../hooks/pickaxe/useResponseContext.js"),l=require("../../../../hooks/studio/useStyleFontSize.js"),o=require("../../../../hooks/pickaxe/useConversation.js"),r=require("../../common/PickaxeIcon.js"),i=require("../../../Core/ErrorAlert.js"),c=require("../../Addons/Scroll/ScrollLockView.js"),n=require("../../common/PickaxeHead.js"),d=require("../../common/PickaxeInfoModal.js"),u=require("../../common/PickaxeUpgradeCard.js"),x=require("./Message.js"),m=require("../../../../common/cn.js");exports.default=()=>{var j;const{pickaxe:p,styles:f,colors:g,responsiveBy:h,isNewChat:E,setChatId:k}=a.usePickaxeContext(),{messages:v,status:b,limitData:w,error:y}=t.useResponseContext(),N=o.useConversation(),C=l.useStyleFontSize(),[O,q]=s.useState(!1),S=s.useMemo((()=>!!N.data&&!(N.data.messages.length<=1)),[N.data]),F=s.useMemo((()=>N.isSuccess&&E&&!S),[N.isSuccess,E,S]);return e.jsxs("div",Object.assign({className:"relative flex flex-grow flex-col justify-end"},{children:[O&&e.jsx(d.default,{isOpen:O,onChangeIsOpen:q}),e.jsx("div",Object.assign({className:m.default("absolute left-1/2 top-5 flex w-full max-w-[400px] -translate-x-1/2 -translate-y-1/3 transform flex-col items-center px-4 opacity-0 duration-300",F&&"top-1/3 opacity-100")},{children:e.jsx(n.default,{iconClassName:"duration-300 hover:opacity-90",onIconClick:()=>k("")})})),e.jsx("div",Object.assign({className:"flex w-full justify-center"},{children:N.isLoading?e.jsxs("div",Object.assign({className:"grid w-full max-w-[800px] grid-cols-1 gap-y-6 px-6 pt-10"},{children:[e.jsx("div",{className:"h-10 w-[70%] animate-pulse justify-self-end rounded bg-[#E5E7EB] dark:bg-[#1E1E1F]",style:{backgroundColor:"dark"===f.theme?"#1E1E1F":"#E5E7EB"}}),e.jsx("div",{className:"h-[150px] w-[70%] animate-pulse rounded bg-[#E5E7EB] dark:bg-[#1E1E1F]",style:{backgroundColor:"dark"===f.theme?"#1E1E1F":"#E5E7EB"}}),e.jsx("div",{className:"h-10 w-[50%] animate-pulse justify-self-end rounded bg-[#E5E7EB] dark:bg-[#1E1E1F]",style:{backgroundColor:"dark"===f.theme?"#1E1E1F":"#E5E7EB"}})]})):N.isError?e.jsx("div",Object.assign({className:"flex w-full max-w-[800px] justify-center pt-10"},{children:e.jsxs("p",Object.assign({className:m.default(C.b2,"text-center font-semibold")},{children:["Something went wrong. Please try again, or"," ",e.jsx("a",Object.assign({href:"mailto:info@pickaxeproject.com?subject=Help"},{children:"contact us"}))," ","for help."]}))})):e.jsxs("div",Object.assign({className:"flex flex-col w-full"},{children:[e.jsxs("div",Object.assign({className:m.default("relative grid w-full max-w-[800px] grid-cols-1 gap-y-6 px-4 pt-6","viewport"===h?"min-[767px]:pt-10":"@[767px]/pickaxe-root:pt-10")},{children:[N.data.messages.map(((s,a)=>e.jsx(x.default,{message:s},a))),v.map(((s,a)=>e.jsx(x.default,{message:s},a))),"fetching"===b?e.jsxs("div",Object.assign({className:"flex max-w-[80%] items-center gap-x-3"},{children:["NONE"!==(null==p?void 0:p.chaticon)&&e.jsx(r.default,{src:null!==(j=null==p?void 0:p.chaticon)&&void 0!==j?j:`https://prod-pickaxe-assets.s3.us-west-2.amazonaws.com/chaticons/${null==p?void 0:p.formid}.png`,alt:`${null==p?void 0:p.formtitle}'s Chat Icon`,width:24,height:24,className:"h-6 w-6",textColor:g.text}),e.jsxs("div",Object.assign({className:"flex items-center gap-x-2 rounded px-4 py-4",style:{backgroundColor:g.secondary+"80",color:g.secondaryText}},{children:[e.jsx("div",{className:"h-1.5 w-1.5 animate-dot rounded-full",style:{backgroundColor:g.secondaryText}}),e.jsx("div",{className:"h-1.5 w-1.5 animate-dot-down rounded-full",style:{backgroundColor:g.secondaryText}}),e.jsx("div",{className:"h-1.5 w-1.5 animate-dot rounded-full",style:{backgroundColor:g.secondaryText}})]}))]})):w?e.jsx("div",Object.assign({className:"flex max-w-[80%] items-center gap-x-3"},{children:e.jsx(u.default,{})})):y?e.jsx("div",Object.assign({className:"flex max-w-[80%] items-center gap-x-3"},{children:e.jsx(i.default,{error:y})})):null]})),e.jsx(c.default,{className:"w-full"})]}))}))]}))};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("../../../_virtual/_tslib.js"),s=require("react/jsx-runtime"),t=require("react"),o=require("../../../hooks/core/useMediaQuery.js"),r=require("../../../hooks/pickaxe/usePickaxeContext.js"),i=require("../../../hooks/pickaxe/useResponseContext.js"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("../../../_virtual/_tslib.js"),s=require("react/jsx-runtime"),t=require("react"),o=require("../../../hooks/core/useMediaQuery.js"),r=require("../../../hooks/pickaxe/usePickaxeContext.js"),i=require("../../../hooks/pickaxe/useResponseContext.js"),a=require("../../../hooks/studio/useStyleInput.js"),n=require("../../../hooks/studio/useStyleFontSize.js"),l=require("../../../hooks/pickaxe/useConversation.js"),d=require("../../../hooks/pickaxe/useSubmit.js"),u=require("../../../hooks/pickaxe/useSubmitResult.js"),c=require("../Addons/Document/hooks/useDocument.js"),m=require("../Addons/Scroll/hooks/useScroll.js"),p=require("../../../common/documents.js"),h=require("../../../common/api/streamer.js"),x=require("../../../node_modules/.pnpm/react-textarea-autosize@8.5.7_@types_react@18.3.18_react@18.3.1/node_modules/react-textarea-autosize/dist/react-textarea-autosize.esm.js"),f=require("../../Icons/attach.svg.js"),g=require("../../Icons/arrow-right.svg.js"),j=require("../common/PickaxeBranding.js"),b=require("../Addons/IceBreaker/index.js"),y=require("../../../common/error.js"),v=require("../../../common/cn.js");exports.default=()=>{var I;const{formId:k,chatId:w,userId:q,studioUserId:S,deploymentId:D,pickaxe:O,colors:C,misc:A,responsiveBy:N,isNewChat:_,forceMobile:M,setIsNewChat:E,setIsShowIceBreaker:R,onGenerateComplete:U}=r.usePickaxeContext(),{messages:z,status:B,limits:T,setMessages:F,setStatus:P,setLimitData:L,setError:W,setIsGenerating:G}=i.useResponseContext(),{documents:K,isUploading:Q,isImageUploadAllowed:H,upsertDocuments:J,onFileUpload:V,onEditDocumentByDocId:X}=c.useDocument(),{scrollStartSession:Y,scrollEndSession:Z,scrollToBottom:$}=m.useScroll({auto:!0}),ee=l.useConversation(),se=d.useSubmit(),te=u.useSubmitResult(),oe=n.useStyleFontSize(),[re,ie]=t.useState(""),ae=t.useRef(null),[ne]=o.useMediaQuery("(max-width: 767px)"),le=a.useStyleInput(),de=t.useMemo((()=>{var e,s,t;return!!_&&(!!O&&(!ee.isLoading&&(!((null!==(s=null===(e=ee.data)||void 0===e?void 0:e.messages.length)&&void 0!==s?s:0)>1)&&!!(null===(t=O.icebreakers)||void 0===t?void 0:t.length))))}),[O,_,ee.data,ee.isLoading]);t.useEffect((()=>{R(de)}),[de]);const ue=s=>e.__awaiter(void 0,void 0,void 0,(function*(){try{if(Q||"idle"!==B)return;const e=null!=s?s:re;if(!e)return;ie(""),W(""),L(null),G(!0),E(!1);const t=new Date,o="enduserupload"===(null==O?void 0:O.documentuploadtype),r=K.filter((e=>"finished"===e.status&&!e.isInsertedAsRaw)),i=r.length?r[r.length-1].documentId:"";P("fetching"),Y(),$();const a=[...z,{id:z.length+1,role:"user",content:e}];F(a),$();const{success:n,data:l,actionData:d,usedDocumentIds:u,newDocumentId:c,newDocumentName:m,rawUserInput:p,isInsertedFile:x,error:f}=yield se.mutateAsync(Object.assign(Object.assign(Object.assign({formId:k,responseId:w,value:e},o&&i&&{documentId:i}),S&&{studioUserId:S}),D&&{deploymentId:D}));if(!n)throw new Error(null!=f?f:"An error occurred, please try again.");$(),x&&i&&X({documentId:i,isInsertedAsRaw:!0}),c&&m&&J([{type:"website",id:m,name:m,status:"finished",documentId:c}]),$();const g=(yield h.streamer({formId:k,responseId:w,data:l,actionData:d})).body;if(!g)throw new Error("Streaming error");const j=g.getReader(),b=new TextDecoder,y=a.length;let v="",I=!0,C=!1;for(;I;){const{value:e,done:s}=yield j.read();I=!s;if(v+=b.decode(e),v)F([...a.slice(0,y),{id:z.length+1,role:"assistant",content:v}]),C||(P("streaming"),C=!0);else if(!I&&!v)throw new Error("Server error")}const A=new Date;v&&($(),P("idle"),yield te.mutateAsync(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({formId:k,responseId:w,documentIds:u},q&&{userId:q}),S&&{studioUserId:S}),S&&(null==O?void 0:O.studioid)&&{studioId:O.studioid}),D&&{deploymentId:D}),{messages:[{role:"user",message:p,sentAt:t},{role:"assistant",message:v,sentAt:A}]})),null==U||U(w))}catch(e){let s=y.default(e)||"";s&&!s.includes("Unexpected token 'A',")||(s="Oops! We're experiencing high traffic at the moment. Please try again later.");const t=Object.entries(T).find((([e])=>s.includes(e)));t?L(t[1]):W(s),$()}finally{P("idle"),G(!1),Z()}}));return s.jsxs("div",Object.assign({className:v.default("fixed flex w-full flex-col bottom-0 left-0","viewport"===N?"min-[767px]:relative min-[767px]:bottom-auto min-[767px]:left-auto":"absolute @[767px]/pickaxe-root:relative @[767px]/pickaxe-root:bottom-auto @[767px]/pickaxe-root:left-auto")},{children:[!A.isWhiteLabel&&s.jsx("div",Object.assign({className:"flex justify-end pr-3"},{children:s.jsx(j.default,{animateHover:!0})})),de&&s.jsx(b.default,{data:(null==O?void 0:O.icebreakers)||[],style:{backgroundColor:C.secondary,color:C.secondaryText},isMobile:M||ne,onSend:ue}),s.jsxs("div",Object.assign({style:le,className:"flex min-h-[56px] items-end gap-x-2 px-4 py-3 pb-[15px] shadow"},{children:["enduserupload"===(null==O?void 0:O.documentuploadtype)&&s.jsxs("div",Object.assign({className:"tooltip"},{children:[s.jsx("input",{id:"file-upload",ref:ae,type:"file",accept:[...p.allowedFileMimeTypes,...H?p.allowedImageMimeTypes:[]].join(", "),multiple:!0,hidden:!0,className:"hidden",onChange:s=>e.__awaiter(void 0,void 0,void 0,(function*(){yield V(Array.from(s.target.files||[])),s.target.value=""}))}),s.jsx("button",Object.assign({className:"flex items-center disabled:cursor-wait disabled:opacity-50",disabled:Q,onClick:()=>{var e;return null===(e=ae.current)||void 0===e?void 0:e.click()}},{children:s.jsx(f.default,{className:"h-6 w-6 shrink-0 stroke-2",style:{color:C.accent}})}))]})),s.jsx(x.default,{className:v.default(oe.b2,"max-h-60 w-full resize-none border-transparent bg-transparent outline-none ring-0 scrollbar scrollbar-thin placeholder:font-semilight",!re.length&&"max-h-6 overflow-hidden text-ellipsis whitespace-nowrap"),value:re,placeholder:null!==(I=null==O?void 0:O.placeholdertext)&&void 0!==I?I:"What do you want to talk about?",onChange:e=>ie(e.target.value),onKeyDown:e=>{"Enter"===e.key&&(e.shiftKey||(e.preventDefault(),Q||"idle"!==B||ue()))}}),s.jsx("button",Object.assign({className:"outline-none disabled:cursor-default disabled:opacity-50",disabled:Q||"idle"!==B,onClick:()=>ue()},{children:s.jsx(g.default,{className:"h-6 w-6 shrink-0 stroke-2",style:{color:Q||"idle"!==B?C.secondaryText+"70":C.accent}})}))]}))]}))};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("../../../../_virtual/_tslib.js"),s=require("react/jsx-runtime"),t=require("react"),o=require("../../../../hooks/pickaxe/usePickaxeContext.js"),i=require("../../../../hooks/pickaxe/useResponseContext.js"),r=require("../../../../hooks/pickaxe/useSubmit.js"),n=require("../../../../hooks/pickaxe/useSubmitResult.js"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("../../../../_virtual/_tslib.js"),s=require("react/jsx-runtime"),t=require("react"),o=require("../../../../hooks/pickaxe/usePickaxeContext.js"),i=require("../../../../hooks/pickaxe/useResponseContext.js"),r=require("../../../../hooks/pickaxe/useSubmit.js"),n=require("../../../../hooks/pickaxe/useSubmitResult.js"),a=require("../../Addons/Document/hooks/useDocument.js"),l=require("../../Addons/Scroll/hooks/useScroll.js"),u=require("../../../../common/api/streamer.js"),d=require("../../../../common/utils.js"),c=require("@nem035/gpt-3-encoder"),m=require("../../common/PickaxeBranding.js"),p=require("../../common/PickaxeButton.js"),x=require("../../../../common/error.js"),f=require("../../../../common/cn.js");exports.default=({questions:g})=>{const{formId:j,userId:h,studioUserId:w,deploymentId:b,pickaxe:q,misc:y,responsiveBy:I,isShowHistory:k,setIsShowHistory:v,onGenerateComplete:O}=o.usePickaxeContext(),{status:S,limits:D,setResponse:P,setStatus:R,setLimitData:U,setError:C,setIsGenerating:E}=i.useResponseContext(),{documents:A,websiteLink:T,isUploading:_,onWebsiteUpload:L,setDocumentError:N}=a.useDocument(),{scrollStartSession:B,scrollEndSession:W,scrollToTarget:G,scrollToBottom:H}=l.useScroll({auto:!0}),M=r.useSubmit(),F=n.useSubmitResult(),[K,Y]=t.useState(!1);return s.jsxs("div",Object.assign({className:f.default("mt-4 flex flex-wrap flex-col justify-between gap-2","viewport"===I?"min-[767px]:flex-row":"@[767px]/pickaxe-root:flex-row")},{children:[s.jsxs("div",Object.assign({className:"flex items-center flex-grow flex-wrap gap-2"},{children:[s.jsx(p.default,Object.assign({className:f.default("w-full","viewport"===I?"min-[767px]:max-w-[176px]":"@[767px]/pickaxe-root:max-w-[176px]"),isDisabled:_||K||"idle"!==S,onClick:()=>e.__awaiter(void 0,void 0,void 0,(function*(){var e;try{if(_||K||"idle"!==S)return;U(null),N(""),E(!0);const s="enduserupload"===(null==q?void 0:q.documentuploadtype),t=g.some((e=>"userinput:documentupload"===e.id&&e.isRequired)),o=A.filter((e=>"finished"===e.status)),i=d.extractUrlsFromText(T),r=A.map((e=>e.name)),n=i.filter((e=>!r.includes(e)));if(n.length){const e=n[n.length-1];Y(!0);const s=yield L(e);s&&(o.push(s),yield new Promise((e=>setTimeout(e,5e3)))),Y(!1)}else if(t&&s&&!o.length)return void N("Please paste a valid website/video link or drag a file to add to the knowledge base.");C("");const a=["Multiple Choice","Checkbox"];for(const e of g){if(c.encode(e.input).length>e.maxLength&&!a.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 l=o.length?o[o.length-1]:null;let m={};g.forEach((e=>m=Object.assign(Object.assign({},m),{[e.id]:"Knowledge Upload"===e.type||e.id.includes("documentupload")?(null==l?void 0:l.name)||"":e.input}))),R("fetching");const{success:p,responseId:x,data:f,actionData:y,usedDocumentIds:I,rawUserInput:k,error:v}=yield M.mutateAsync(Object.assign(Object.assign(Object.assign({formId:j,valueObj:m},s&&l&&{documentId:null!==(e=l.documentId)&&void 0!==e?e:""}),w&&{studioUserId:w}),b&&{deploymentId:b}));if(!p)throw new Error(null!=v?v:"An error occurred, please try again.");const D=(yield u.streamer({formId:j,responseId:x,data:f,actionData:y})).body;if(!D)throw new Error("Streaming error");const W=D.getReader(),G=new TextDecoder;let z="",J=!0,Q=!1;P(null);const V=g.map((e=>({id:e.id,question:e.main,answer:e.input})));for(;J;){const{value:e,done:s}=yield W.read();J=!s;const t=G.decode(e);if(z&&!Q&&(B(),H(),Q=!0),z+=t,z)R("streaming"),P({formId:j,responseId:x,documentIds:I,messages:[],questions:V,questionPrompt:k,questionResponse:z,createdAt:new Date});else if(!J&&!z)throw new Error("Server error")}z&&(H(),R("idle"),yield F.mutateAsync(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({formId:j,responseId:x,documentIds:I},h&&{userId:h}),w&&{studioUserId:w}),w&&(null==q?void 0:q.studioid)&&{studioId:q.studioid}),b&&{deploymentId:b}),{questions:V,questionPrompt:k,questionResponse:z})),null==O||O(x))}catch(e){let s=x.default(e)||"";s&&!s.includes("Unexpected token 'A',")||(s="Oops! We're experiencing high traffic at the moment. Please try again later.");const t=Object.entries(D).find((([e])=>s.includes(e)));t?U(t[1]):C(s),G(),H()}finally{R("idle"),E(!1),Y(!1),W()}}))},{children:K?"Processing...":_?"Uploading...":"fetching"===S||"streaming"===S?"Loading...":"Submit"})),!k&&s.jsx(p.default,Object.assign({variant:"transparent-text",className:f.default("w-full","viewport"===I?"min-[767px]:max-w-[176px]":"@[767px]/pickaxe-root:max-w-[176px]"),onClick:()=>v(!0)},{children:"See history"}))]})),!y.isWhiteLabel&&s.jsx("div",Object.assign({className:"flex justify-end pr-3"},{children:s.jsx(m.default,{})}))]}))};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),s=require("../../../hooks/pickaxe/usePickaxeContext.js"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),s=require("../../../hooks/pickaxe/usePickaxeContext.js"),i=require("../common/PickaxeHead.js"),t=require("./History/index.js"),r=require("./NewChat.js"),x=require("./Questions/index.js"),a=require("../../../common/cn.js");exports.default=()=>{const{pickaxe:l,responsiveBy:c}=s.usePickaxeContext();return e.jsx("div",Object.assign({className:a.default("flex w-full flex-col items-center pt-12 px-4 pb-10","viewport"===c?"min-[767px]:pb-40":"@[767px]/pickaxe-root:pb-40")},{children:e.jsxs("div",Object.assign({className:"flex w-full max-w-[700px] flex-col"},{children:[e.jsx(i.default,{}),e.jsxs("div",Object.assign({className:a.default("flex flex-col gap-y-8","viewport"===c?"min-[767px]:mt-4":"@[767px]/pickaxe-root:mt-4")},{children:[(null==l?void 0:l.chatflag)?e.jsx(r.default,{}):e.jsx(x.default,{}),e.jsx(t.default,{})]}))]}))}))};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),i=require("react"),t=require("../../../hooks/pickaxe/usePickaxeContext.js"),s=require("../../../hooks/studio/useStyleFontSize.js"),o=require("./PickaxeIcon.js"),c=require("./PickaxeInfoModal.js"),l=require("../../../common/cn.js");exports.default=({iconClassName:n,onIconClick:r,noClamp:a=!1})=>{const{pickaxe:u,colors:d,misc:p}=t.usePickaxeContext(),[m,x]=i.useState(!1),f=s.useStyleFontSize(),h=i.useMemo((()=>({title:(null==u?void 0:u.formtitle)||"",description:(null==u?void 0:u.formdescription)||""})),[u]);return e.jsxs("div",Object.assign({className:"flex flex-col items-center"},{children:[m&&e.jsx(c.default,{isOpen:m,onChangeIsOpen:x}),p.isProfileImage&&e.jsx(o.default,Object.assign({src:null==u?void 0:u.coverphoto,alt:`${null==u?void 0:u.formtitle}'s Profile Picture`,width:90,height:90,className:l.default("h-[90px] w-[90px] rounded-full",n)},r&&{onClick:r})),p.isTitle&&!!h.title&&e.jsx("h2",Object.assign({className:l.default(f.h2,"mt-6 text-center font-semilight opacity-70",!a&&"line-clamp-2")},{children:null==u?void 0:u.formtitle})),p.isDescription&&!!h.description&&e.jsxs("p",Object.assign({className:l.default(f.b1,"max-w-[600px] whitespace-pre-line text-center font-semilight opacity-70")},{children:[a?h.description:h.description.slice(0,80),!a&&h.description.length>80&&e.jsx("span",Object.assign({className:"inline ml-1 cursor-pointer hover:opacity-70 font-semibold transition-opacity duration-300 active:opacity-100",style:{color:d.accent},onClick:()=>x(!0)},{children:"..."}))]}))]}))};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),s=require("react"),t=require("../../Icons/spark.svg.js"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),s=require("react"),t=require("../../Icons/spark.svg.js"),i=require("../../../common/cn.js");exports.default=({src:r,alt:a,width:c=24,height:l=24,className:n,textColor:o,isLoading:d,onClick:h})=>{const[u,g]=s.useState(!1),j=r||"";return d?e.jsx("div",Object.assign({className:i.default("shrink-0 animate-pulse rounded bg-[#E5E7EB] dark:bg-[#1E1E1F]",n),style:{width:c,height:l}},h&&{onClick:h})):o&&j===`https://${process.env.NEXT_PUBLIC_PICKAXE_DOMAIN}/builder/assets/images/pickaxe-chaticons/chaticon2.png`?e.jsx(t.default,Object.assign({className:i.default("h-6 w-6 shrink-0",n),style:{color:o}},h&&{onClick:h})):"NONE"===j?null:!j||u?e.jsx("div",Object.assign({className:i.default("shrink-0 rounded bg-[#E5E7EB] dark:bg-[#1E1E1F]",n),style:{width:c,height:l}},h&&{onClick:h})):e.jsx("div",Object.assign({className:"relative shrink-0 rounded",style:{width:c,height:l}},h&&{onClick:h},{children:e.jsx("img",{src:j,alt:a||"Pickaxe's Profile Picture",width:c,height:l,className:i.default("select-none rounded object-cover",n),draggable:!1,onError:()=>g(!0)})}))};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),s=require("../../../hooks/pickaxe/usePickaxeContext.js"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),s=require("../../../hooks/pickaxe/usePickaxeContext.js"),r=require("../../Icons/x.svg.js"),t=require("../../Core/Modal/index.js"),l=require("../../Core/Modal/Body.js"),a=require("./PickaxeSimpleButton.js"),i=require("./PickaxeHead.js");exports.default=({isOpen:x,onChangeIsOpen:c})=>{const{colors:o}=s.usePickaxeContext();return e.jsx(t.default,Object.assign({isOpen:x,onChange:c},{children:e.jsxs(l.default,Object.assign({className:"relative flex flex-col px-8 pt-[26px] pb-8 w-full min-[767px]:max-w-[480px] max-[767px]:border-0",style:{backgroundColor:o.primary,color:o.text,borderColor:o.text+"4D"},avoidOverflow:!0},{children:[e.jsx("div",Object.assign({className:"flex items-start justify-end gap-4"},{children:e.jsx(a.default,Object.assign({color:o.text,onClick:()=>c(!1)},{children:e.jsx(r.default,{className:"h-6 w-6 shrink-0"})}))})),e.jsx("div",Object.assign({className:"mt-6 flex flex-col items-center"},{children:e.jsx("div",Object.assign({className:"flex w-full max-w-[360px] flex-col items-center text-center"},{children:e.jsx(i.default,{noClamp:!0})}))}))]}))}))};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("../../../../../../_virtual/_tslib.js"),t=require("react/jsx-runtime"),r=require("react"),s=require("@tanstack/react-query"),i=require("../../hooks/usePickaxeMarkdownContext.js"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("../../../../../../_virtual/_tslib.js"),t=require("react/jsx-runtime"),r=require("react"),s=require("@tanstack/react-query"),i=require("../../hooks/usePickaxeMarkdownContext.js"),a=require("../common/Action.js"),n=require("../Img/index.js"),o=require("../common/Audio.js"),u=require("../common/Html/index.js"),c=require("../../../../../../common/api/utils.js"),l=require("../../../../../../common/error.js");exports.default=({node:d,href:f="",children:p})=>{const{accentColor:m,websiteMetadatas:h,linkPreviews:w,actions:j,setWebsiteMetadatas:g}=i.usePickaxeMarkdownContext(),[x,b]=r.useState("");r.useEffect((()=>{if(!f)return;const e=f.startsWith("http://")?`https://${f.slice(7)}`:f.startsWith("www.")?`https://${f}`:f;e!==x&&b(e)}),[f,x]),s.useQuery({queryKey:["website-metadata",x],queryFn:()=>{return t=x,e.__awaiter(void 0,void 0,void 0,(function*(){try{if("development"===process.env.NODE_ENV&&console.log("[getWebsiteMetadata]",t),!t||!t.startsWith("https")||!t.includes("."))return null;if(["/api/fn/result","/api/function_call_results","https://prod-pickaxe-assets.s3.amazonaws.com"].some((e=>t.includes(e))))return null;const e=(yield c.default.get(`/metadata?url=${encodeURIComponent(t)}`)).data;if(e.error)throw new Error(e.error||"Failed to fetch metadata");return e}catch(e){if("development"===process.env.NODE_ENV){const t=l.default(e);console.error("[getJobResult]",t)}return null}}));var t},enabled:"undefined"!=typeof window&&w&&Boolean(x)&&!h.some((e=>e.href===x))&&x.includes(".")&&!x.includes("https://prod-pickaxe-assets")&&!x.includes("https://pickaxeproject--v2"),retry:2,onSuccess:t=>e.__awaiter(void 0,void 0,void 0,(function*(){t&&(h.some((e=>e.href===t.href))||g((e=>[...e,t])))}))});const v=x.match(/(?:https?:\/\/)?(?:www\.)?(?:youtube\.com\/watch\?v=|youtu\.be\/)([\w-]+)/i);if(v&&(null==v?void 0:v[1]))return t.jsx("div",Object.assign({style:{marginTop:"2rem",marginBottom:"2rem",display:"flex",width:"100%",justifyContent:"center"}},{children:t.jsx("iframe",Object.assign({title:"youtube-embed",src:`https://www.youtube.com/embed/${v[1]}`,style:{width:"100%",maxWidth:"560px",minHeight:"315px"},allowFullScreen:!0},{children:"Iframe not supported, use a different browser."}))}));if(x.match(/\.(jpeg|jpg|gif|bmp|webp|svg|tiff|avif|png|jfif|pjpeg|pjp)$/))return t.jsx(n.default,{src:x,alt:"string"==typeof p?p:"Markdown Image"});if(x.match(/\.(mp3|wav|ogg|flac|aac|wma|alac|m4a|aiff|ape|au|mid|midi|opus)$/))return t.jsx(o.default,{url:x});return x.includes("action_generated_files")&&x.match(/\.html$/)?t.jsx(u.default,{url:x}):j&&x.includes("pickaxe")&&(x.includes("/api/fn/result")||x.includes("/api/function_call_results"))?t.jsx(a.default,{jobUrl:x}):t.jsx("a",Object.assign({href:x,target:"_blank",rel:"noopener noreferrer",style:{color:m,fontWeight:600}},{children:p}))};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),t=require("react"),r=require("../common/Modal/index.js"),n=require("../common/Modal/Body.js");exports.default=({src:a,isOpen:o,onChangeIsOpen:i})=>{const[d,s]=t.useState({width:500,height:500});return t.useEffect((()=>{if(!a)return;const e=new Image;e.src=a,e.onload=()=>{s({width:Math.min(e.naturalWidth,750),height:Math.min(e.naturalHeight,600)})}}),[a]),e.jsx(r.default,Object.assign({isOpen:o,onChange:i},{children:e.jsx(n.default,{style:{border:"none",padding:"1rem",backgroundColor:"#000",backgroundImage:`url("${a}")`,backgroundSize:"contain",backgroundPosition:"center",backgroundRepeat:"no-repeat",width:d.width,height:d.height},avoidOverflow:!0})}))};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),t=require("../../hooks/usePickaxeMarkdownContext.js"),s=require("../common/Action.js")
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),t=require("../../hooks/usePickaxeMarkdownContext.js"),s=require("../common/Action.js");exports.default=({node:i,children:n})=>{const{actions:r}=t.usePickaxeMarkdownContext(),l="string"==typeof n&&n.match(/(?:https?:\/\/)?(?:www\.)?(?:youtube\.com\/watch\?v=|youtu\.be\/)([\w-]+)/i);if(l&&(null==l?void 0:l[1]))return e.jsx("div",Object.assign({style:{marginTop:"2rem",marginBottom:"2rem",display:"flex",width:"100%",justifyContent:"center"}},{children:e.jsx("iframe",Object.assign({title:"youtube-embed",src:`https://www.youtube.com/embed/${l[1]}`,style:{width:"100%",maxWidth:"560px",minHeight:"315px"},allowFullScreen:!0},{children:"Iframe not supported, use a different browser."}))}));if(r&&"string"==typeof n&&n.includes("pickaxe")&&(n.includes("/api/fn/result")||n.includes("/api/function_call_results"))){const t=n.replace(/https:\/\/\S*(\/api\/fn\/result|\/api\/function_call_results)\S*/g,""),i=n.match(/https:\/\/\S*(\/api\/fn\/result|\/api\/function_call_results)\S*/g);return e.jsxs("div",Object.assign({className:"flex flex-col"},{children:[e.jsx("p",Object.assign({style:{fontWeight:350}},{children:t})),e.jsx(s.default,{jobUrl:(null==i?void 0:i[0])||""})]}))}return e.jsx("p",Object.assign({style:{fontWeight:350}},{children:n}))};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("../../../../../../_virtual/_tslib.js"),t=require("react/jsx-runtime"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("../../../../../../_virtual/_tslib.js"),t=require("react/jsx-runtime"),i=require("react"),r=require("@tanstack/react-query"),o=require("../../hooks/usePickaxeMarkdownContext.js"),a=require("../../../../../../common/lotties/loader-black.js"),n=require("../../../../../../common/lotties/loader-white.js"),s=require("../../../../../../common/api/streamer.js"),d=require("../../../PickaxeLottie.js"),c=require("../../Renderer.js"),l=require("framer-motion"),u=require("../../../../../../common/api/utils.js"),m=require("../../../../../../common/error.js");exports.default=({jobUrl:j})=>{var v,p,x,y;const{theme:f}=o.usePickaxeMarkdownContext(),[b,h]=i.useState(""),[g,k]=i.useState(""),q=i.useRef(null),w=r.useQuery({queryKey:[j],queryFn:()=>(t=>e.__awaiter(void 0,void 0,void 0,(function*(){try{if(!t||t.includes("undefined"))throw new Error("Invalid action job URL");const e=yield fetch(t);return yield e.json()}catch(e){const t=m.default(e);return"development"===process.env.NODE_ENV&&console.error("[getJobResult]",t),{success:!1,error:t}}})))(j),enabled:"undefined"!=typeof window,retry:10,onSuccess:t=>e.__awaiter(void 0,void 0,void 0,(function*(){try{if(k(""),!t.success)return;if("text"in t)return void h(t.text||"");if(!("fcid"in t)){const e=(yield s.streamer(Object.assign({formId:t.formId,responseId:t.responseId,data:t.encodedData},t.actionData&&{actionData:t.actionData}))).body;if(!e)return;let i=!0,r="";const o=e.getReader(),a=new TextDecoder;for(;i;){const{value:e,done:t}=yield o.read();i=!t;r+=a.decode(e),h(r)}return h(r),yield u.default.post("/fn/update",{id:t.jobId,data:Object.assign(Object.assign({},t),{text:r})}),void console.log("[Action] streaming done")}yield new Promise((e=>setTimeout(e,3e3))),w.refetch(),"development"===process.env.NODE_ENV&&console.log(`[Action] refetching <${j}>`)}catch(e){k(m.default(e))}}))});return t.jsx("div",Object.assign({ref:q,className:"pxe-action"},{children:t.jsx(l.AnimatePresence,{children:g||w.error||(null===(v=w.data)||void 0===v?void 0:v.error)?t.jsxs(l.motion.div,Object.assign({initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.3},className:"mt-4"},{children:[t.jsx("blockquote",Object.assign({style:{lineHeight:"20px",borderLeft:"4px solid #FF0000",color:"#FF0000",paddingLeft:"1rem",marginBottom:"1rem"}},{children:g||(null===(p=w.data)||void 0===p?void 0:p.error)||"Failed to process, please try again."})),(null===(x=w.data)||void 0===x?void 0:x.traceback)&&t.jsxs(t.Fragment,{children:[t.jsxs("p",Object.assign({style:{color:"#FF0000"}},{children:["Traceback:"," "]})),t.jsx(c.PickaxeMarkdownRenderer,{value:`\`\`\`js\n${null===(y=w.data)||void 0===y?void 0:y.traceback}\n\`\`\``,recursion:!0})]})]})):b?t.jsx(l.motion.div,Object.assign({initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.3},className:"mt-4"},{children:t.jsx(c.PickaxeMarkdownRenderer,{value:b,recursion:!0})})):t.jsx(l.motion.div,Object.assign({initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.3}},{children:t.jsx(d.PickaxeLottie,{id:"dark"===f?"loader-white":"loader-black",getJson:()=>e.__awaiter(void 0,void 0,void 0,(function*(){return"dark"===f?n.loaderWhite:a.loaderBlack})),autoplay:!0,loop:!0,style:{cursor:"default",pointerEvents:"none",width:"100%",maxWidth:"150px",height:"150px"}})}))})}))};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime");exports.default=({url:r})=>e.jsx("audio",Object.assign({style:{marginTop:"1rem",marginBottom:"1rem",objectFit:"contain",maxWidth:"100%"},controls:!0},{children:e.jsx("source",{src:r,type:"audio/mpeg"})}));
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),r=require("../Modal/index.js"),s=require("../Modal/Body.js");exports.default=({src:i,isOpen:t,onChangeIsOpen:a})=>e.jsx(r.default,Object.assign({isOpen:t,onChange:a},{children:e.jsx(s.default,Object.assign({style:{width:"90vw",height:"90vh",border:"none"},avoidOverflow:!0},{children:e.jsx("iframe",{src:i,title:"Random HTML",className:"scrollbar scrollbar-thin",style:{width:"100%",height:"100%",flex:1,borderRadius:"8px"}})}))}));
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),r=require("react"),s=require("../../../hooks/usePickaxeMarkdownContext.js"),t=require("../../../../../../Icons/eye.svg.js"),i=require("../../../../../../Icons/arrow-up-right.svg.js"),l=require("./HtmlModal.js");exports.default=({url:n})=>{const{theme:a,accentColor:o}=s.usePickaxeMarkdownContext(),[c,d]=r.useState(!1);return e.jsxs(e.Fragment,{children:[c&&e.jsx(l.default,{src:n,isOpen:c,onChangeIsOpen:d}),e.jsxs("div",Object.assign({style:{display:"flex",alignItems:"flex-start",gap:"1rem",minHeight:"200px",overflow:"hidden",borderRadius:"8px"}},{children:[e.jsx("iframe",{src:n,title:"Random HTML",className:"scrollbar scrollbar-thin",style:{width:"100%",minHeight:"200px",border:"1px solid "+("dark"===a?"#30363D":"#D0D7DE")}}),e.jsxs("div",Object.assign({style:{display:"flex",flexDirection:"column",gap:".75rem"}},{children:[e.jsx("button",Object.assign({style:{outline:"none",color:o},onClick:()=>d(!0)},{children:e.jsx(t.default,{width:24,height:24,style:{flexShrink:0}})})),e.jsx("a",Object.assign({href:n,rel:"noreferrer",target:"_blank"},{children:e.jsx("button",Object.assign({style:{outline:"none",color:o}},{children:e.jsx(i.default,{width:24,height:24,style:{flexShrink:0}})}))}))]}))]}))]})};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("../../../../../../../_virtual/_tslib.js"),r=require("react/jsx-runtime"),t=require("react"),s=require("react-dom"),a=require("./index.js"),o=require("../../../../../../../hooks/core/useOutsideAlerter.js"),i=require("../../../../../../../common/utils.js"),l=require("framer-motion"),n=require("../../../../../../../common/cn.js");const c=t.forwardRef(((c,u)=>{var{children:d,className:m,avoidOverflow:f=!1}=c,b=e.__rest(c,["children","className","avoidOverflow"]);const p=document.createElement("div"),x=t.useRef(),v=t.useRef(p),{closeOnOutsideClick:y,setIsOpen:h}=t.useContext(a.MarkdownModalContext);return o.useOutsideAlerter({ref:x,callback:()=>{y&&h(!1)}}),t.useEffect((()=>{const e=document.querySelector("main"),r=null==e?void 0:e.getAttribute("class"),t=v.current;return t.setAttribute("id",i.randomStr(5)+"-modal"),t.setAttribute("class","fixed inset-0 z-50 flex items-center justify-center backdrop-blur-sm bg-black/20"+(r?` ${r}`:"")),document.body.appendChild(t),()=>{document.body.removeChild(t)}}),[]),v.current?s.createPortal(r.jsx(l.motion.div,Object.assign({initial:{y:300,opacity:0},animate:{y:0,opacity:1},exit:{y:300,opacity:0},transition:{type:"spring",stiffness:260,damping:20},className:n.default(f&&"max-h-[100vh] overflow-auto scrollbar scrollbar-thumb-black/50 scrollbar-thumb-rounded-full scrollbar-w-[4px] scrollbar-h-[4px]",m,"p-0")},{children:r.jsx("div",Object.assign({ref:e=>{e&&(x.current=e,"function"==typeof u?u(e):u&&(u.current=e))}},b,{className:n.default("animate-fade-in flex flex-col rounded border border-transparent shadow-md",m)},{children:d}))})),v.current):r.jsx(r.Fragment,{children:null})}));c.displayName="MarkdownModalBody",exports.default=c;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),r=require("react");const t=r.createContext({});exports.MarkdownModalContext=t,exports.default=({children:s,isOpen:n,closeOnOutsideClick:i=!0,onChange:l})=>{const[o,u]=r.useState(null!=n&&n);return r.useEffect((()=>{void 0!==n&&u(n)}),[n]),e.jsxs(t.Provider,Object.assign({value:{isOpen:o,closeOnOutsideClick:i,setIsOpen:e=>{u(e),!0!==e&&!1!==e||null==l||l(e)}}},{children:[Array.isArray(s)&&e.jsxs(e.Fragment,{children:[null==s?void 0:s[0],o&&(null==s?void 0:s[1])]}),o&&s]}))};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
interface PickaxeHeadProps {
|
|
2
|
+
iconClassName?: string;
|
|
3
|
+
onIconClick?: () => void;
|
|
4
|
+
noClamp?: boolean;
|
|
5
|
+
}
|
|
6
|
+
declare const PickaxeHead: ({ iconClassName, onIconClick, noClamp, }: PickaxeHeadProps) => import("react/jsx-runtime").JSX.Element;
|
|
7
|
+
export default PickaxeHead;
|
|
@@ -6,6 +6,7 @@ interface PickaxeIconProps {
|
|
|
6
6
|
className?: string;
|
|
7
7
|
textColor?: string;
|
|
8
8
|
isLoading?: boolean;
|
|
9
|
+
onClick?: () => void;
|
|
9
10
|
}
|
|
10
|
-
declare const PickaxeIcon: ({ src, alt, width, height, className, textColor, isLoading, }: PickaxeIconProps) => import("react/jsx-runtime").JSX.Element | null;
|
|
11
|
+
declare const PickaxeIcon: ({ src, alt, width, height, className, textColor, isLoading, onClick, }: PickaxeIconProps) => import("react/jsx-runtime").JSX.Element | null;
|
|
11
12
|
export default PickaxeIcon;
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { type DetailedHTMLProps, type HTMLAttributes } from "react";
|
|
2
|
+
interface MarkdownModalBodyProps extends DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLDivElement> {
|
|
3
|
+
avoidOverflow?: boolean;
|
|
4
|
+
}
|
|
5
|
+
declare const MarkdownModalBody: import("react").ForwardRefExoticComponent<Omit<MarkdownModalBodyProps, "ref"> & import("react").RefAttributes<HTMLDivElement>>;
|
|
6
|
+
export default MarkdownModalBody;
|
package/dist/cjs/src/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Modal/CloseButton.d.ts
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { type CSSProperties, type ReactNode } from "react";
|
|
2
|
+
interface MarkdownModalCloseButtonProps {
|
|
3
|
+
className?: string;
|
|
4
|
+
icon?: ReactNode;
|
|
5
|
+
style?: CSSProperties;
|
|
6
|
+
onClick?: () => void;
|
|
7
|
+
}
|
|
8
|
+
declare const MarkdownModalCloseButton: ({ className, icon, style, onClick, }: MarkdownModalCloseButtonProps) => import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
export default MarkdownModalCloseButton;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { type Dispatch, type ReactNode, type SetStateAction } from "react";
|
|
2
|
+
type MarkdownModalContextType = {
|
|
3
|
+
isOpen: boolean;
|
|
4
|
+
closeOnOutsideClick: boolean;
|
|
5
|
+
setIsOpen: Dispatch<SetStateAction<boolean>>;
|
|
6
|
+
};
|
|
7
|
+
interface MarkdownModalProviderProps {
|
|
8
|
+
children: ReactNode | ReactNode[];
|
|
9
|
+
isOpen?: boolean;
|
|
10
|
+
closeOnOutsideClick?: boolean;
|
|
11
|
+
onChange?: (isOpen: boolean) => void;
|
|
12
|
+
}
|
|
13
|
+
export declare const MarkdownModalContext: import("react").Context<MarkdownModalContextType>;
|
|
14
|
+
declare const MarkdownModal: ({ children, isOpen: _isOpen, closeOnOutsideClick, onChange, }: MarkdownModalProviderProps) => import("react/jsx-runtime").JSX.Element;
|
|
15
|
+
export default MarkdownModal;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
1
|
+
import type { StudioFontSize } from "../../types/studio";
|
|
2
|
+
import type { PickaxeResponsiveBy } from "../../components/Pickaxe/Provider";
|
|
3
3
|
export type FontSizeType = "h1" | "h2" | "h3" | "h4" | "b1" | "b2" | "b3" | "b4" | "l1" | "l2";
|
|
4
4
|
export type FontListType = Record<FontSizeType, string>;
|
|
5
5
|
export declare const fontSizeMap: Record<PickaxeResponsiveBy, Record<StudioFontSize, Record<FontSizeType, string>>>;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import*as r from"react";var e;function t(){return t=Object.assign?Object.assign.bind():function(r){for(var e=1;e<arguments.length;e++){var t=arguments[e];for(var n in t)({}).hasOwnProperty.call(t,n)&&(r[n]=t[n])}return r},t.apply(null,arguments)}var n=n=>r.createElement("svg",t({xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24"},n),e||(e=r.createElement("path",{fill:"currentColor",d:"m16.175 11-5.6-5.6L12 4l8 8-8 8-1.425-1.4 5.6-5.6H4v-2z"})));export{n as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import*as r from"react";var e;function t(){return t=Object.assign?Object.assign.bind():function(r){for(var e=1;e<arguments.length;e++){var t=arguments[e];for(var n in t)({}).hasOwnProperty.call(t,n)&&(r[n]=t[n])}return r},t.apply(null,arguments)}var n=n=>r.createElement("svg",t({xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0
|
|
1
|
+
import*as r from"react";var e;function t(){return t=Object.assign?Object.assign.bind():function(r){for(var e=1;e<arguments.length;e++){var t=arguments[e];for(var n in t)({}).hasOwnProperty.call(t,n)&&(r[n]=t[n])}return r},t.apply(null,arguments)}var n=n=>r.createElement("svg",t({xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24"},n),e||(e=r.createElement("path",{stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M7 17 17 7M7 7h10v10"})));export{n as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import*as r from"react";var e,t;function n(){return n=Object.assign?Object.assign.bind():function(r){for(var e=1;e<arguments.length;e++){var t=arguments[e];for(var n in t)({}).hasOwnProperty.call(t,n)&&(r[n]=t[n])}return r},n.apply(null,arguments)}var o=o=>r.createElement("svg",n({xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24"},o),e||(e=r.createElement("path",{stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M1 12.5s4-8 11-8 11 8 11 8-4 8-11 8-11-8-11-8"})),t||(t=r.createElement("path",{stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M12 15.5a3 3 0 1 0 0-6 3 3 0 0 0 0 6"})));export{o as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{jsx as e,jsxs as o}from"react/jsx-runtime";import{usePickaxeContext as s}from"../../../../hooks/pickaxe/usePickaxeContext.js";import{useStyleFontSize as t}from"../../../../hooks/studio/useStyleFontSize.js";import{PickaxeMarkdown as a}from"../../common/PickaxeMarkdown/index.js";import{PickaxeMarkdownRenderer as c}from"../../common/PickaxeMarkdown/Renderer.js";import r from"../../common/PickaxeIcon.js";import i from"../../common/PickaxeCopyButton.js";import n from"../../../../common/cn.js";const l=({message:l})=>{var m;const{formId:x,pickaxe:d,styles:p,colors:h,misc:f,responsiveBy:b}=s(),u=t(),v=null!==(m=null==d?void 0:d.chaticon)&&void 0!==m?m:`https://prod-pickaxe-assets.s3.us-west-2.amazonaws.com/chaticons/${x}.png`;return"assistant"===l.role?e("div",Object.assign({className:n("flex flex-col","viewport"===b?"min-[767px]:max-w-[80%]":"@[767px]/pickaxe-root:max-w-[80%]")},{children:o("div",Object.assign({className:"flex gap-x-3"},{children:[f.isChatImage&&"NONE"!==v&&e(r,{src:v,alt:"Assistant",width:24,height:24,className:"my-3 h-6 w-6",textColor:h.text}),o("div",Object.assign({className:"flex flex-col"},{children:[e("div",Object.assign({className:n(u.b2,"chat-message overflow-x-auto overflow-y-hidden rounded px-4 py-3 scrollbar-thin scrollbar-track-white scrollbar-thumb-[#4A4A4B]")
|
|
1
|
+
import{jsx as e,jsxs as o}from"react/jsx-runtime";import{usePickaxeContext as s}from"../../../../hooks/pickaxe/usePickaxeContext.js";import{useStyleFontSize as t}from"../../../../hooks/studio/useStyleFontSize.js";import{PickaxeMarkdown as a}from"../../common/PickaxeMarkdown/index.js";import{PickaxeMarkdownRenderer as c}from"../../common/PickaxeMarkdown/Renderer.js";import r from"../../common/PickaxeIcon.js";import i from"../../common/PickaxeCopyButton.js";import n from"../../../../common/cn.js";const l=({message:l})=>{var m;const{formId:x,pickaxe:d,styles:p,colors:h,misc:f,responsiveBy:b}=s(),u=t(),v=null!==(m=null==d?void 0:d.chaticon)&&void 0!==m?m:`https://prod-pickaxe-assets.s3.us-west-2.amazonaws.com/chaticons/${x}.png`;return"assistant"===l.role?e("div",Object.assign({className:n("flex flex-col","viewport"===b?"min-[767px]:max-w-[80%]":"@[767px]/pickaxe-root:max-w-[80%]")},{children:o("div",Object.assign({className:"flex gap-x-3"},{children:[f.isChatImage&&"NONE"!==v&&e(r,{src:v,alt:"Assistant",width:24,height:24,className:"my-3 h-6 w-6",textColor:h.text}),o("div",Object.assign({className:"flex flex-col"},{children:[e("div",Object.assign({className:n(u.b2,"chat-message overflow-x-auto overflow-y-hidden rounded px-4 py-3 scrollbar-thin scrollbar-track-white scrollbar-thumb-[#4A4A4B]")},{children:e(a,Object.assign({theme:p.theme,accentColor:h.accent,linkPreviews:!0,actions:!0},{children:e(c,{value:l.content})}))})),e("div",Object.assign({className:"mb-2 ml-2 mt-4 flex gap-3"},{children:e(i,{color:h.accent,text:l.content})}))]}))]}))})):"user"===l.role?e("div",Object.assign({className:n("flex gap-x-3 justify-self-end pl-9","viewport"===b?"min-[767px]:max-w-[80%] min-[767px]:pl-0":"@[767px]/pickaxe-root:max-w-[80%] @[767px]/pickaxe-root:pl-0")},{children:e("div",Object.assign({className:n(u.b2,"overflow-x-auto overflow-y-hidden rounded px-4 py-3 scrollbar-thin scrollbar-track-white scrollbar-thumb-[#4A4A4B]"),style:{backgroundColor:h.secondary+"80",color:h.secondaryText}},{children:e(a,Object.assign({theme:p.theme,accentColor:h.accent},{children:e(c,{value:l.content})}))}))})):e("div",{})};export{l as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{jsxs as e,jsx as s}from"react/jsx-runtime";import{useState as
|
|
1
|
+
import{jsxs as e,jsx as s}from"react/jsx-runtime";import{useState as a,useMemo as o}from"react";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{useConversation as l}from"../../../../hooks/pickaxe/useConversation.js";import c from"../../common/PickaxeIcon.js";import n from"../../../Core/ErrorAlert.js";import m from"../../Addons/Scroll/ScrollLockView.js";import d from"../../common/PickaxeHead.js";import p from"../../common/PickaxeInfoModal.js";import x from"../../common/PickaxeUpgradeCard.js";import f from"./Message.js";import u from"../../../../common/cn.js";const g=()=>{var g;const{pickaxe:h,styles:j,colors:E,responsiveBy:k,isNewChat:w,setChatId:b}=t(),{messages:v,status:y,limitData:N,error:C}=r(),O=l(),B=i(),[F,S]=a(!1),I=o((()=>!!O.data&&!(O.data.messages.length<=1)),[O.data]),P=o((()=>O.isSuccess&&w&&!I),[O.isSuccess,w,I]);return e("div",Object.assign({className:"relative flex flex-grow flex-col justify-end"},{children:[F&&s(p,{isOpen:F,onChangeIsOpen:S}),s("div",Object.assign({className:u("absolute left-1/2 top-5 flex w-full max-w-[400px] -translate-x-1/2 -translate-y-1/3 transform flex-col items-center px-4 opacity-0 duration-300",P&&"top-1/3 opacity-100")},{children:s(d,{iconClassName:"duration-300 hover:opacity-90",onIconClick:()=>b("")})})),s("div",Object.assign({className:"flex w-full justify-center"},{children:O.isLoading?e("div",Object.assign({className:"grid w-full max-w-[800px] grid-cols-1 gap-y-6 px-6 pt-10"},{children:[s("div",{className:"h-10 w-[70%] animate-pulse justify-self-end rounded bg-[#E5E7EB] dark:bg-[#1E1E1F]",style:{backgroundColor:"dark"===j.theme?"#1E1E1F":"#E5E7EB"}}),s("div",{className:"h-[150px] w-[70%] animate-pulse rounded bg-[#E5E7EB] dark:bg-[#1E1E1F]",style:{backgroundColor:"dark"===j.theme?"#1E1E1F":"#E5E7EB"}}),s("div",{className:"h-10 w-[50%] animate-pulse justify-self-end rounded bg-[#E5E7EB] dark:bg-[#1E1E1F]",style:{backgroundColor:"dark"===j.theme?"#1E1E1F":"#E5E7EB"}})]})):O.isError?s("div",Object.assign({className:"flex w-full max-w-[800px] justify-center pt-10"},{children:e("p",Object.assign({className:u(B.b2,"text-center font-semibold")},{children:["Something went wrong. Please try again, or"," ",s("a",Object.assign({href:"mailto:info@pickaxeproject.com?subject=Help"},{children:"contact us"}))," ","for help."]}))})):e("div",Object.assign({className:"flex flex-col w-full"},{children:[e("div",Object.assign({className:u("relative grid w-full max-w-[800px] grid-cols-1 gap-y-6 px-4 pt-6","viewport"===k?"min-[767px]:pt-10":"@[767px]/pickaxe-root:pt-10")},{children:[O.data.messages.map(((e,a)=>s(f,{message:e},a))),v.map(((e,a)=>s(f,{message:e},a))),"fetching"===y?e("div",Object.assign({className:"flex max-w-[80%] items-center gap-x-3"},{children:["NONE"!==(null==h?void 0:h.chaticon)&&s(c,{src:null!==(g=null==h?void 0:h.chaticon)&&void 0!==g?g:`https://prod-pickaxe-assets.s3.us-west-2.amazonaws.com/chaticons/${null==h?void 0:h.formid}.png`,alt:`${null==h?void 0:h.formtitle}'s Chat Icon`,width:24,height:24,className:"h-6 w-6",textColor:E.text}),e("div",Object.assign({className:"flex items-center gap-x-2 rounded px-4 py-4",style:{backgroundColor:E.secondary+"80",color:E.secondaryText}},{children:[s("div",{className:"h-1.5 w-1.5 animate-dot rounded-full",style:{backgroundColor:E.secondaryText}}),s("div",{className:"h-1.5 w-1.5 animate-dot-down rounded-full",style:{backgroundColor:E.secondaryText}}),s("div",{className:"h-1.5 w-1.5 animate-dot rounded-full",style:{backgroundColor:E.secondaryText}})]}))]})):N?s("div",Object.assign({className:"flex max-w-[80%] items-center gap-x-3"},{children:s(x,{})})):C?s("div",Object.assign({className:"flex max-w-[80%] items-center gap-x-3"},{children:s(n,{error:C})})):null]})),s(m,{className:"w-full"})]}))}))]}))};export{g as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{__awaiter as e}from"../../../_virtual/_tslib.js";import{jsxs as t,jsx as o}from"react/jsx-runtime";import{useState as s,useRef as r,useMemo as i,useEffect as n}from"react";import{useMediaQuery as a}from"../../../hooks/core/useMediaQuery.js";import{usePickaxeContext as l}from"../../../hooks/pickaxe/usePickaxeContext.js";import{useResponseContext as d}from"../../../hooks/pickaxe/useResponseContext.js";import{useStyleInput as c}from"../../../hooks/studio/useStyleInput.js";import{useStyleFontSize as m}from"../../../hooks/studio/useStyleFontSize.js";import{useConversation as u}from"../../../hooks/pickaxe/useConversation.js";import{useSubmit as p}from"../../../hooks/pickaxe/useSubmit.js";import{useSubmitResult as f}from"../../../hooks/pickaxe/useSubmitResult.js";import{useDocument as h}from"../Addons/Document/hooks/useDocument.js";import{useScroll as g}from"../Addons/Scroll/hooks/useScroll.js";import{allowedFileMimeTypes as
|
|
1
|
+
import{__awaiter as e}from"../../../_virtual/_tslib.js";import{jsxs as t,jsx as o}from"react/jsx-runtime";import{useState as s,useRef as r,useMemo as i,useEffect as n}from"react";import{useMediaQuery as a}from"../../../hooks/core/useMediaQuery.js";import{usePickaxeContext as l}from"../../../hooks/pickaxe/usePickaxeContext.js";import{useResponseContext as d}from"../../../hooks/pickaxe/useResponseContext.js";import{useStyleInput as c}from"../../../hooks/studio/useStyleInput.js";import{useStyleFontSize as m}from"../../../hooks/studio/useStyleFontSize.js";import{useConversation as u}from"../../../hooks/pickaxe/useConversation.js";import{useSubmit as p}from"../../../hooks/pickaxe/useSubmit.js";import{useSubmitResult as f}from"../../../hooks/pickaxe/useSubmitResult.js";import{useDocument as h}from"../Addons/Document/hooks/useDocument.js";import{useScroll as g}from"../Addons/Scroll/hooks/useScroll.js";import{allowedFileMimeTypes as x,allowedImageMimeTypes as b}from"../../../common/documents.js";import{streamer as v}from"../../../common/api/streamer.js";import y from"../../../node_modules/.pnpm/react-textarea-autosize@8.5.7_@types_react@18.3.18_react@18.3.1/node_modules/react-textarea-autosize/dist/react-textarea-autosize.esm.js";import j from"../../Icons/attach.svg.js";import I from"../../Icons/arrow-right.svg.js";import k from"../common/PickaxeBranding.js";import w from"../Addons/IceBreaker/index.js";import D from"../../../common/error.js";import O from"../../../common/cn.js";const S=()=>{var S;const{formId:A,chatId:N,userId:C,studioUserId:U,deploymentId:E,pickaxe:_,colors:B,misc:z,responsiveBy:R,isNewChat:L,forceMobile:M,setIsNewChat:T,setIsShowIceBreaker:F,onGenerateComplete:P}=l(),{messages:W,status:G,limits:K,setMessages:H,setStatus:Q,setLimitData:q,setError:J,setIsGenerating:V}=d(),{documents:X,isUploading:Y,isImageUploadAllowed:Z,upsertDocuments:$,onFileUpload:ee,onEditDocumentByDocId:te}=h(),{scrollStartSession:oe,scrollEndSession:se,scrollToBottom:re}=g({auto:!0}),ie=u(),ne=p(),ae=f(),le=m(),[de,ce]=s(""),me=r(null),[ue]=a("(max-width: 767px)"),pe=c(),fe=i((()=>{var e,t,o;return!!L&&(!!_&&(!ie.isLoading&&(!((null!==(t=null===(e=ie.data)||void 0===e?void 0:e.messages.length)&&void 0!==t?t:0)>1)&&!!(null===(o=_.icebreakers)||void 0===o?void 0:o.length))))}),[_,L,ie.data,ie.isLoading]);n((()=>{F(fe)}),[fe]);const he=t=>e(void 0,void 0,void 0,(function*(){try{if(Y||"idle"!==G)return;const e=null!=t?t:de;if(!e)return;ce(""),J(""),q(null),V(!0),T(!1);const o=new Date,s="enduserupload"===(null==_?void 0:_.documentuploadtype),r=X.filter((e=>"finished"===e.status&&!e.isInsertedAsRaw)),i=r.length?r[r.length-1].documentId:"";Q("fetching"),oe(),re();const n=[...W,{id:W.length+1,role:"user",content:e}];H(n),re();const{success:a,data:l,actionData:d,usedDocumentIds:c,newDocumentId:m,newDocumentName:u,rawUserInput:p,isInsertedFile:f,error:h}=yield ne.mutateAsync(Object.assign(Object.assign(Object.assign({formId:A,responseId:N,value:e},s&&i&&{documentId:i}),U&&{studioUserId:U}),E&&{deploymentId:E}));if(!a)throw new Error(null!=h?h:"An error occurred, please try again.");re(),f&&i&&te({documentId:i,isInsertedAsRaw:!0}),m&&u&&$([{type:"website",id:u,name:u,status:"finished",documentId:m}]),re();const g=(yield v({formId:A,responseId:N,data:l,actionData:d})).body;if(!g)throw new Error("Streaming error");const x=g.getReader(),b=new TextDecoder,y=n.length;let j="",I=!0,k=!1;for(;I;){const{value:e,done:t}=yield x.read();I=!t;if(j+=b.decode(e),j)H([...n.slice(0,y),{id:W.length+1,role:"assistant",content:j}]),k||(Q("streaming"),k=!0);else if(!I&&!j)throw new Error("Server error")}const w=new Date;j&&(re(),Q("idle"),yield ae.mutateAsync(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({formId:A,responseId:N,documentIds:c},C&&{userId:C}),U&&{studioUserId:U}),U&&(null==_?void 0:_.studioid)&&{studioId:_.studioid}),E&&{deploymentId:E}),{messages:[{role:"user",message:p,sentAt:o},{role:"assistant",message:j,sentAt:w}]})),null==P||P(N))}catch(e){let t=D(e)||"";t&&!t.includes("Unexpected token 'A',")||(t="Oops! We're experiencing high traffic at the moment. Please try again later.");const o=Object.entries(K).find((([e])=>t.includes(e)));o?q(o[1]):J(t),re()}finally{Q("idle"),V(!1),se()}}));return t("div",Object.assign({className:O("fixed flex w-full flex-col bottom-0 left-0","viewport"===R?"min-[767px]:relative min-[767px]:bottom-auto min-[767px]:left-auto":"absolute @[767px]/pickaxe-root:relative @[767px]/pickaxe-root:bottom-auto @[767px]/pickaxe-root:left-auto")},{children:[!z.isWhiteLabel&&o("div",Object.assign({className:"flex justify-end pr-3"},{children:o(k,{animateHover:!0})})),fe&&o(w,{data:(null==_?void 0:_.icebreakers)||[],style:{backgroundColor:B.secondary,color:B.secondaryText},isMobile:M||ue,onSend:he}),t("div",Object.assign({style:pe,className:"flex min-h-[56px] items-end gap-x-2 px-4 py-3 pb-[15px] shadow"},{children:["enduserupload"===(null==_?void 0:_.documentuploadtype)&&t("div",Object.assign({className:"tooltip"},{children:[o("input",{id:"file-upload",ref:me,type:"file",accept:[...x,...Z?b:[]].join(", "),multiple:!0,hidden:!0,className:"hidden",onChange:t=>e(void 0,void 0,void 0,(function*(){yield ee(Array.from(t.target.files||[])),t.target.value=""}))}),o("button",Object.assign({className:"flex items-center disabled:cursor-wait disabled:opacity-50",disabled:Y,onClick:()=>{var e;return null===(e=me.current)||void 0===e?void 0:e.click()}},{children:o(j,{className:"h-6 w-6 shrink-0 stroke-2",style:{color:B.accent}})}))]})),o(y,{className:O(le.b2,"max-h-60 w-full resize-none border-transparent bg-transparent outline-none ring-0 scrollbar scrollbar-thin placeholder:font-semilight",!de.length&&"max-h-6 overflow-hidden text-ellipsis whitespace-nowrap"),value:de,placeholder:null!==(S=null==_?void 0:_.placeholdertext)&&void 0!==S?S:"What do you want to talk about?",onChange:e=>ce(e.target.value),onKeyDown:e=>{"Enter"===e.key&&(e.shiftKey||(e.preventDefault(),Y||"idle"!==G||he()))}}),o("button",Object.assign({className:"outline-none disabled:cursor-default disabled:opacity-50",disabled:Y||"idle"!==G,onClick:()=>he()},{children:o(I,{className:"h-6 w-6 shrink-0 stroke-2",style:{color:Y||"idle"!==G?B.secondaryText+"70":B.accent}})}))]}))]}))};export{S as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{__awaiter as e}from"../../../../_virtual/_tslib.js";import{jsxs as o,jsx as t}from"react/jsx-runtime";import{useState as s}from"react";import{usePickaxeContext as i}from"../../../../hooks/pickaxe/usePickaxeContext.js";import{useResponseContext as
|
|
1
|
+
import{__awaiter as e}from"../../../../_virtual/_tslib.js";import{jsxs as o,jsx as t}from"react/jsx-runtime";import{useState as s}from"react";import{usePickaxeContext as i}from"../../../../hooks/pickaxe/usePickaxeContext.js";import{useResponseContext as n}from"../../../../hooks/pickaxe/useResponseContext.js";import{useSubmit as r}from"../../../../hooks/pickaxe/useSubmit.js";import{useSubmitResult as a}from"../../../../hooks/pickaxe/useSubmitResult.js";import{useDocument as d}from"../../Addons/Document/hooks/useDocument.js";import{useScroll as l}from"../../Addons/Scroll/hooks/useScroll.js";import{streamer as c}from"../../../../common/api/streamer.js";import{extractUrlsFromText as m}from"../../../../common/utils.js";import{encode as u}from"@nem035/gpt-3-encoder";import p from"../../common/PickaxeBranding.js";import f from"../../common/PickaxeButton.js";import g from"../../../../common/error.js";import x from"../../../../common/cn.js";const h=({questions:h})=>{const{formId:w,userId:j,studioUserId:b,deploymentId:y,pickaxe:I,misc:k,responsiveBy:v,isShowHistory:O,setIsShowHistory:S,onGenerateComplete:q}=i(),{status:D,limits:E,setResponse:P,setStatus:U,setLimitData:R,setError:A,setIsGenerating:C}=n(),{documents:L,websiteLink:N,isUploading:T,onWebsiteUpload:B,setDocumentError:W}=d(),{scrollStartSession:G,scrollEndSession:H,scrollToTarget:_,scrollToBottom:K}=l({auto:!0}),M=r(),Y=a(),[z,F]=s(!1);return o("div",Object.assign({className:x("mt-4 flex flex-wrap flex-col justify-between gap-2","viewport"===v?"min-[767px]:flex-row":"@[767px]/pickaxe-root:flex-row")},{children:[o("div",Object.assign({className:"flex items-center flex-grow flex-wrap gap-2"},{children:[t(f,Object.assign({className:x("w-full","viewport"===v?"min-[767px]:max-w-[176px]":"@[767px]/pickaxe-root:max-w-[176px]"),isDisabled:T||z||"idle"!==D,onClick:()=>e(void 0,void 0,void 0,(function*(){var e;try{if(T||z||"idle"!==D)return;R(null),W(""),C(!0);const o="enduserupload"===(null==I?void 0:I.documentuploadtype),t=h.some((e=>"userinput:documentupload"===e.id&&e.isRequired)),s=L.filter((e=>"finished"===e.status)),i=m(N),n=L.map((e=>e.name)),r=i.filter((e=>!n.includes(e)));if(r.length){const e=r[r.length-1];F(!0);const o=yield B(e);o&&(s.push(o),yield new Promise((e=>setTimeout(e,5e3)))),F(!1)}else if(t&&o&&!s.length)return void W("Please paste a valid website/video link or drag a file to add to the knowledge base.");A("");const a=["Multiple Choice","Checkbox"];for(const e of h){if(u(e.input).length>e.maxLength&&!a.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 d=s.length?s[s.length-1]:null;let l={};h.forEach((e=>l=Object.assign(Object.assign({},l),{[e.id]:"Knowledge Upload"===e.type||e.id.includes("documentupload")?(null==d?void 0:d.name)||"":e.input}))),U("fetching");const{success:p,responseId:f,data:g,actionData:x,usedDocumentIds:k,rawUserInput:v,error:O}=yield M.mutateAsync(Object.assign(Object.assign(Object.assign({formId:w,valueObj:l},o&&d&&{documentId:null!==(e=d.documentId)&&void 0!==e?e:""}),b&&{studioUserId:b}),y&&{deploymentId:y}));if(!p)throw new Error(null!=O?O:"An error occurred, please try again.");const S=(yield c({formId:w,responseId:f,data:g,actionData:x})).body;if(!S)throw new Error("Streaming error");const E=S.getReader(),H=new TextDecoder;let _="",J=!0,Q=!1;P(null);const V=h.map((e=>({id:e.id,question:e.main,answer:e.input})));for(;J;){const{value:e,done:o}=yield E.read();J=!o;const t=H.decode(e);if(_&&!Q&&(G(),K(),Q=!0),_+=t,_)U("streaming"),P({formId:w,responseId:f,documentIds:k,messages:[],questions:V,questionPrompt:v,questionResponse:_,createdAt:new Date});else if(!J&&!_)throw new Error("Server error")}_&&(K(),U("idle"),yield Y.mutateAsync(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({formId:w,responseId:f,documentIds:k},j&&{userId:j}),b&&{studioUserId:b}),b&&(null==I?void 0:I.studioid)&&{studioId:I.studioid}),y&&{deploymentId:y}),{questions:V,questionPrompt:v,questionResponse:_})),null==q||q(f))}catch(e){let o=g(e)||"";o&&!o.includes("Unexpected token 'A',")||(o="Oops! We're experiencing high traffic at the moment. Please try again later.");const t=Object.entries(E).find((([e])=>o.includes(e)));t?R(t[1]):A(o),_(),K()}finally{U("idle"),C(!1),F(!1),H()}}))},{children:z?"Processing...":T?"Uploading...":"fetching"===D||"streaming"===D?"Loading...":"Submit"})),!O&&t(f,Object.assign({variant:"transparent-text",className:x("w-full","viewport"===v?"min-[767px]:max-w-[176px]":"@[767px]/pickaxe-root:max-w-[176px]"),onClick:()=>S(!0)},{children:"See history"}))]})),!k.isWhiteLabel&&t("div",Object.assign({className:"flex justify-end pr-3"},{children:t(p,{})}))]}))};export{h as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{jsx as e,jsxs as o}from"react/jsx-runtime";import{usePickaxeContext as i}from"../../../hooks/pickaxe/usePickaxeContext.js";import t from"
|
|
1
|
+
import{jsx as e,jsxs as o}from"react/jsx-runtime";import{usePickaxeContext as i}from"../../../hooks/pickaxe/usePickaxeContext.js";import t from"../common/PickaxeHead.js";import s from"./History/index.js";import r from"./NewChat.js";import m from"./Questions/index.js";import c from"../../../common/cn.js";const p=()=>{const{pickaxe:p,responsiveBy:a}=i();return e("div",Object.assign({className:c("flex w-full flex-col items-center pt-12 px-4 pb-10","viewport"===a?"min-[767px]:pb-40":"@[767px]/pickaxe-root:pb-40")},{children:o("div",Object.assign({className:"flex w-full max-w-[700px] flex-col"},{children:[e(t,{}),o("div",Object.assign({className:c("flex flex-col gap-y-8","viewport"===a?"min-[767px]:mt-4":"@[767px]/pickaxe-root:mt-4")},{children:[(null==p?void 0:p.chatflag)?e(r,{}):e(m,{}),e(s,{})]}))]}))}))};export{p as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{jsxs as i,jsx as e}from"react/jsx-runtime";import{useState as o,useMemo as t}from"react";import{usePickaxeContext as s}from"../../../hooks/pickaxe/usePickaxeContext.js";import{useStyleFontSize as c}from"../../../hooks/studio/useStyleFontSize.js";import n from"./PickaxeIcon.js";import l from"./PickaxeInfoModal.js";import r from"../../../common/cn.js";const a=({iconClassName:a,onIconClick:m,noClamp:p=!1})=>{const{pickaxe:d,colors:f,misc:h}=s(),[u,x]=o(!1),g=c(),j=t((()=>({title:(null==d?void 0:d.formtitle)||"",description:(null==d?void 0:d.formdescription)||""})),[d]);return i("div",Object.assign({className:"flex flex-col items-center"},{children:[u&&e(l,{isOpen:u,onChangeIsOpen:x}),h.isProfileImage&&e(n,Object.assign({src:null==d?void 0:d.coverphoto,alt:`${null==d?void 0:d.formtitle}'s Profile Picture`,width:90,height:90,className:r("h-[90px] w-[90px] rounded-full",a)},m&&{onClick:m})),h.isTitle&&!!j.title&&e("h2",Object.assign({className:r(g.h2,"mt-6 text-center font-semilight opacity-70",!p&&"line-clamp-2")},{children:null==d?void 0:d.formtitle})),h.isDescription&&!!j.description&&i("p",Object.assign({className:r(g.b1,"max-w-[600px] whitespace-pre-line text-center font-semilight opacity-70")},{children:[p?j.description:j.description.slice(0,80),!p&&j.description.length>80&&e("span",Object.assign({className:"inline ml-1 cursor-pointer hover:opacity-70 font-semibold transition-opacity duration-300 active:opacity-100",style:{color:f.accent},onClick:()=>x(!0)},{children:"..."}))]}))]}))};export{a as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{jsx as
|
|
1
|
+
import{jsx as s}from"react/jsx-runtime";import{useState as e}from"react";import i from"../../Icons/spark.svg.js";import t from"../../../common/cn.js";const r=({src:r,alt:a,width:c=24,height:o=24,className:n,textColor:l,isLoading:h,onClick:d})=>{const[g,m]=e(!1),k=r||"";return h?s("div",Object.assign({className:t("shrink-0 animate-pulse rounded bg-[#E5E7EB] dark:bg-[#1E1E1F]",n),style:{width:c,height:o}},d&&{onClick:d})):l&&k===`https://${process.env.NEXT_PUBLIC_PICKAXE_DOMAIN}/builder/assets/images/pickaxe-chaticons/chaticon2.png`?s(i,Object.assign({className:t("h-6 w-6 shrink-0",n),style:{color:l}},d&&{onClick:d})):"NONE"===k?null:s("div",!k||g?Object.assign({className:t("shrink-0 rounded bg-[#E5E7EB] dark:bg-[#1E1E1F]",n),style:{width:c,height:o}},d&&{onClick:d}):Object.assign({className:"relative shrink-0 rounded",style:{width:c,height:o}},d&&{onClick:d},{children:s("img",{src:k,alt:a||"Pickaxe's Profile Picture",width:c,height:o,className:t("select-none rounded object-cover",n),draggable:!1,onError:()=>m(!0)})}))};export{r as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{jsx as e,jsxs as o}from"react/jsx-runtime";import{usePickaxeContext as
|
|
1
|
+
import{jsx as e,jsxs as o}from"react/jsx-runtime";import{usePickaxeContext as s}from"../../../hooks/pickaxe/usePickaxeContext.js";import r from"../../Icons/x.svg.js";import t from"../../Core/Modal/index.js";import i from"../../Core/Modal/Body.js";import l from"./PickaxeSimpleButton.js";import a from"./PickaxeHead.js";const c=({isOpen:c,onChangeIsOpen:n})=>{const{colors:m}=s();return e(t,Object.assign({isOpen:c,onChange:n},{children:o(i,Object.assign({className:"relative flex flex-col px-8 pt-[26px] pb-8 w-full min-[767px]:max-w-[480px] max-[767px]:border-0",style:{backgroundColor:m.primary,color:m.text,borderColor:m.text+"4D"},avoidOverflow:!0},{children:[e("div",Object.assign({className:"flex items-start justify-end gap-4"},{children:e(l,Object.assign({color:m.text,onClick:()=>n(!1)},{children:e(r,{className:"h-6 w-6 shrink-0"})}))})),e("div",Object.assign({className:"mt-6 flex flex-col items-center"},{children:e("div",Object.assign({className:"flex w-full max-w-[360px] flex-col items-center text-center"},{children:e(a,{noClamp:!0})}))}))]}))}))};export{c as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{__awaiter as e}from"../../../../../../_virtual/_tslib.js";import{jsx as t}from"react/jsx-runtime";import{useState as r,useEffect as o}from"react";import{useQuery as
|
|
1
|
+
import{__awaiter as e}from"../../../../../../_virtual/_tslib.js";import{jsx as t}from"react/jsx-runtime";import{useState as r,useEffect as o}from"react";import{useQuery as i}from"@tanstack/react-query";import{usePickaxeMarkdownContext as s}from"../../hooks/usePickaxeMarkdownContext.js";import n from"../common/Action.js";import a from"../Img/index.js";import c from"../common/Audio.js";import m from"../common/Html/index.js";import l from"../../../../../../common/api/utils.js";import u from"../../../../../../common/error.js";const p=({node:p,href:d="",children:f})=>{const{accentColor:h,websiteMetadatas:w,linkPreviews:g,actions:b,setWebsiteMetadatas:j}=s(),[v,y]=r("");o((()=>{if(!d)return;const e=d.startsWith("http://")?`https://${d.slice(7)}`:d.startsWith("www.")?`https://${d}`:d;e!==v&&y(e)}),[d,v]),i({queryKey:["website-metadata",v],queryFn:()=>{return t=v,e(void 0,void 0,void 0,(function*(){try{if("development"===process.env.NODE_ENV&&console.log("[getWebsiteMetadata]",t),!t||!t.startsWith("https")||!t.includes("."))return null;if(["/api/fn/result","/api/function_call_results","https://prod-pickaxe-assets.s3.amazonaws.com"].some((e=>t.includes(e))))return null;const e=(yield l.get(`/metadata?url=${encodeURIComponent(t)}`)).data;if(e.error)throw new Error(e.error||"Failed to fetch metadata");return e}catch(e){if("development"===process.env.NODE_ENV){const t=u(e);console.error("[getJobResult]",t)}return null}}));var t},enabled:"undefined"!=typeof window&&g&&Boolean(v)&&!w.some((e=>e.href===v))&&v.includes(".")&&!v.includes("https://prod-pickaxe-assets")&&!v.includes("https://pickaxeproject--v2"),retry:2,onSuccess:t=>e(void 0,void 0,void 0,(function*(){t&&(w.some((e=>e.href===t.href))||j((e=>[...e,t])))}))});const x=v.match(/(?:https?:\/\/)?(?:www\.)?(?:youtube\.com\/watch\?v=|youtu\.be\/)([\w-]+)/i);if(x&&(null==x?void 0:x[1]))return t("div",Object.assign({style:{marginTop:"2rem",marginBottom:"2rem",display:"flex",width:"100%",justifyContent:"center"}},{children:t("iframe",Object.assign({title:"youtube-embed",src:`https://www.youtube.com/embed/${x[1]}`,style:{width:"100%",maxWidth:"560px",minHeight:"315px"},allowFullScreen:!0},{children:"Iframe not supported, use a different browser."}))}));if(v.match(/\.(jpeg|jpg|gif|bmp|webp|svg|tiff|avif|png|jfif|pjpeg|pjp)$/))return t(a,{src:v,alt:"string"==typeof f?f:"Markdown Image"});if(v.match(/\.(mp3|wav|ogg|flac|aac|wma|alac|m4a|aiff|ape|au|mid|midi|opus)$/))return t(c,{url:v});return v.includes("action_generated_files")&&v.match(/\.html$/)?t(m,{url:v}):b&&v.includes("pickaxe")&&(v.includes("/api/fn/result")||v.includes("/api/function_call_results"))?t(n,{jobUrl:v}):t("a",Object.assign({href:v,target:"_blank",rel:"noopener noreferrer",style:{color:h,fontWeight:600}},{children:f}))};export{p as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{jsx as
|
|
1
|
+
import{jsx as o}from"react/jsx-runtime";import{useState as n,useEffect as e}from"react";import t from"../common/Modal/index.js";import r from"../common/Modal/Body.js";const i=({src:i,isOpen:a,onChangeIsOpen:d})=>{const[h,c]=n({width:500,height:500});return e((()=>{if(!i)return;const o=new Image;o.src=i,o.onload=()=>{c({width:Math.min(o.naturalWidth,750),height:Math.min(o.naturalHeight,600)})}}),[i]),o(t,Object.assign({isOpen:a,onChange:d},{children:o(r,{style:{border:"none",padding:"1rem",backgroundColor:"#000",backgroundImage:`url("${i}")`,backgroundSize:"contain",backgroundPosition:"center",backgroundRepeat:"no-repeat",width:h.width,height:h.height},avoidOverflow:!0})}))};export{i as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{jsx as t,jsxs as e}from"react/jsx-runtime";import{usePickaxeMarkdownContext as i}from"../../hooks/usePickaxeMarkdownContext.js";import n from"../common/Action.js";
|
|
1
|
+
import{jsx as t,jsxs as e}from"react/jsx-runtime";import{usePickaxeMarkdownContext as i}from"../../hooks/usePickaxeMarkdownContext.js";import n from"../common/Action.js";const s=({node:s,children:r})=>{const{actions:o}=i(),l="string"==typeof r&&r.match(/(?:https?:\/\/)?(?:www\.)?(?:youtube\.com\/watch\?v=|youtu\.be\/)([\w-]+)/i);if(l&&(null==l?void 0:l[1]))return t("div",Object.assign({style:{marginTop:"2rem",marginBottom:"2rem",display:"flex",width:"100%",justifyContent:"center"}},{children:t("iframe",Object.assign({title:"youtube-embed",src:`https://www.youtube.com/embed/${l[1]}`,style:{width:"100%",maxWidth:"560px",minHeight:"315px"},allowFullScreen:!0},{children:"Iframe not supported, use a different browser."}))}));if(o&&"string"==typeof r&&r.includes("pickaxe")&&(r.includes("/api/fn/result")||r.includes("/api/function_call_results"))){const i=r.replace(/https:\/\/\S*(\/api\/fn\/result|\/api\/function_call_results)\S*/g,""),s=r.match(/https:\/\/\S*(\/api\/fn\/result|\/api\/function_call_results)\S*/g);return e("div",Object.assign({className:"flex flex-col"},{children:[t("p",Object.assign({style:{fontWeight:350}},{children:i})),t(n,{jobUrl:(null==s?void 0:s[0])||""})]}))}return t("p",Object.assign({style:{fontWeight:350}},{children:r}))};export{s as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{__awaiter as e}from"../../../../../../_virtual/_tslib.js";import{jsx as o,jsxs as t,Fragment as i}from"react/jsx-runtime";import{useState as r,useRef as n}from"react";import{useQuery as a}from"@tanstack/react-query";import{usePickaxeMarkdownContext as c}from"../../hooks/usePickaxeMarkdownContext.js";import{loaderBlack as
|
|
1
|
+
import{__awaiter as e}from"../../../../../../_virtual/_tslib.js";import{jsx as o,jsxs as t,Fragment as i}from"react/jsx-runtime";import{useState as r,useRef as n}from"react";import{useQuery as a}from"@tanstack/react-query";import{usePickaxeMarkdownContext as c}from"../../hooks/usePickaxeMarkdownContext.js";import{loaderBlack as s}from"../../../../../../common/lotties/loader-black.js";import{loaderWhite as d}from"../../../../../../common/lotties/loader-white.js";import{streamer as l}from"../../../../../../common/api/streamer.js";import{PickaxeLottie as m}from"../../../PickaxeLottie.js";import{PickaxeMarkdownRenderer as p}from"../../Renderer.js";import{AnimatePresence as u,motion as f}from"framer-motion";import v from"../../../../../../common/api/utils.js";import y from"../../../../../../common/error.js";const j=({jobUrl:j})=>{var b,h,g,x;const{theme:k}=c(),[O,w]=r(""),[F,D]=r(""),N=n(null),E=a({queryKey:[j],queryFn:()=>(o=>e(void 0,void 0,void 0,(function*(){try{if(!o||o.includes("undefined"))throw new Error("Invalid action job URL");const e=yield fetch(o);return yield e.json()}catch(e){const o=y(e);return"development"===process.env.NODE_ENV&&console.error("[getJobResult]",o),{success:!1,error:o}}})))(j),enabled:"undefined"!=typeof window,retry:10,onSuccess:o=>e(void 0,void 0,void 0,(function*(){try{if(D(""),!o.success)return;if("text"in o)return void w(o.text||"");if(!("fcid"in o)){const e=(yield l(Object.assign({formId:o.formId,responseId:o.responseId,data:o.encodedData},o.actionData&&{actionData:o.actionData}))).body;if(!e)return;let t=!0,i="";const r=e.getReader(),n=new TextDecoder;for(;t;){const{value:e,done:o}=yield r.read();t=!o;i+=n.decode(e),w(i)}return w(i),yield v.post("/fn/update",{id:o.jobId,data:Object.assign(Object.assign({},o),{text:i})}),void console.log("[Action] streaming done")}yield new Promise((e=>setTimeout(e,3e3))),E.refetch(),"development"===process.env.NODE_ENV&&console.log(`[Action] refetching <${j}>`)}catch(e){D(y(e))}}))});return o("div",Object.assign({ref:N,className:"pxe-action"},{children:o(u,{children:F||E.error||(null===(b=E.data)||void 0===b?void 0:b.error)?t(f.div,Object.assign({initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.3},className:"mt-4"},{children:[o("blockquote",Object.assign({style:{lineHeight:"20px",borderLeft:"4px solid #FF0000",color:"#FF0000",paddingLeft:"1rem",marginBottom:"1rem"}},{children:F||(null===(h=E.data)||void 0===h?void 0:h.error)||"Failed to process, please try again."})),(null===(g=E.data)||void 0===g?void 0:g.traceback)&&t(i,{children:[t("p",Object.assign({style:{color:"#FF0000"}},{children:["Traceback:"," "]})),o(p,{value:`\`\`\`js\n${null===(x=E.data)||void 0===x?void 0:x.traceback}\n\`\`\``,recursion:!0})]})]})):o(f.div,O?Object.assign({initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.3},className:"mt-4"},{children:o(p,{value:O,recursion:!0})}):Object.assign({initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.3}},{children:o(m,{id:"dark"===k?"loader-white":"loader-black",getJson:()=>e(void 0,void 0,void 0,(function*(){return"dark"===k?d:s})),autoplay:!0,loop:!0,style:{cursor:"default",pointerEvents:"none",width:"100%",maxWidth:"150px",height:"150px"}})}))})}))};export{j as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{jsx as t}from"react/jsx-runtime";const o=({url:o})=>t("audio",Object.assign({style:{marginTop:"1rem",marginBottom:"1rem",objectFit:"contain",maxWidth:"100%"},controls:!0},{children:t("source",{src:o,type:"audio/mpeg"})}));export{o as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{jsx as e}from"react/jsx-runtime";import r from"../Modal/index.js";import o from"../Modal/Body.js";const s=({src:s,isOpen:i,onChangeIsOpen:t})=>e(r,Object.assign({isOpen:i,onChange:t},{children:e(o,Object.assign({style:{width:"90vw",height:"90vh",border:"none"},avoidOverflow:!0},{children:e("iframe",{src:s,title:"Random HTML",className:"scrollbar scrollbar-thin",style:{width:"100%",height:"100%",flex:1,borderRadius:"8px"}})}))}));export{s as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{jsxs as e,Fragment as r,jsx as t}from"react/jsx-runtime";import{useState as i}from"react";import{usePickaxeMarkdownContext as o}from"../../../hooks/usePickaxeMarkdownContext.js";import n from"../../../../../../Icons/eye.svg.js";import s from"../../../../../../Icons/arrow-up-right.svg.js";import l from"./HtmlModal.js";const a=({url:a})=>{const{theme:c,accentColor:d}=o(),[h,m]=i(!1);return e(r,{children:[h&&t(l,{src:a,isOpen:h,onChangeIsOpen:m}),e("div",Object.assign({style:{display:"flex",alignItems:"flex-start",gap:"1rem",minHeight:"200px",overflow:"hidden",borderRadius:"8px"}},{children:[t("iframe",{src:a,title:"Random HTML",className:"scrollbar scrollbar-thin",style:{width:"100%",minHeight:"200px",border:"1px solid "+("dark"===c?"#30363D":"#D0D7DE")}}),e("div",Object.assign({style:{display:"flex",flexDirection:"column",gap:".75rem"}},{children:[t("button",Object.assign({style:{outline:"none",color:d},onClick:()=>m(!0)},{children:t(n,{width:24,height:24,style:{flexShrink:0}})})),t("a",Object.assign({href:a,rel:"noreferrer",target:"_blank"},{children:t("button",Object.assign({style:{outline:"none",color:d}},{children:t(s,{width:24,height:24,style:{flexShrink:0}})}))}))]}))]}))]})};export{a as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{__rest as r}from"../../../../../../../_virtual/_tslib.js";import{jsx as e,Fragment as t}from"react/jsx-runtime";import{forwardRef as o,useRef as i,useContext as a,useEffect as l}from"react";import{createPortal as s}from"react-dom";import{MarkdownModalContext as c}from"./index.js";import{useOutsideAlerter as n}from"../../../../../../../hooks/core/useOutsideAlerter.js";import{randomStr as m}from"../../../../../../../common/utils.js";import{motion as d}from"framer-motion";import u from"../../../../../../../common/cn.js";const f=o(((o,f)=>{var{children:p,className:b,avoidOverflow:h=!1}=o,y=r(o,["children","className","avoidOverflow"]);const v=document.createElement("div"),x=i(),j=i(v),{closeOnOutsideClick:O,setIsOpen:k}=a(c);return n({ref:x,callback:()=>{O&&k(!1)}}),l((()=>{const r=document.querySelector("main"),e=null==r?void 0:r.getAttribute("class"),t=j.current;return t.setAttribute("id",m(5)+"-modal"),t.setAttribute("class","fixed inset-0 z-50 flex items-center justify-center backdrop-blur-sm bg-black/20"+(e?` ${e}`:"")),document.body.appendChild(t),()=>{document.body.removeChild(t)}}),[]),j.current?s(e(d.div,Object.assign({initial:{y:300,opacity:0},animate:{y:0,opacity:1},exit:{y:300,opacity:0},transition:{type:"spring",stiffness:260,damping:20},className:u(h&&"max-h-[100vh] overflow-auto scrollbar scrollbar-thumb-black/50 scrollbar-thumb-rounded-full scrollbar-w-[4px] scrollbar-h-[4px]",b,"p-0")},{children:e("div",Object.assign({ref:r=>{r&&(x.current=r,"function"==typeof f?f(r):f&&(f.current=r))}},y,{className:u("animate-fade-in flex flex-col rounded border border-transparent shadow-md",b)},{children:p}))})),j.current):e(t,{children:null})}));f.displayName="MarkdownModalBody";export{f as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{jsxs as e,Fragment as n}from"react/jsx-runtime";import{createContext as r,useState as i,useEffect as l}from"react";const s=r({}),o=({children:r,isOpen:o,closeOnOutsideClick:t=!0,onChange:c})=>{const[d,u]=i(null!=o&&o);return l((()=>{void 0!==o&&u(o)}),[o]),e(s.Provider,Object.assign({value:{isOpen:d,closeOnOutsideClick:t,setIsOpen:e=>{u(e),!0!==e&&!1!==e||null==c||c(e)}}},{children:[Array.isArray(r)&&e(n,{children:[null==r?void 0:r[0],d&&(null==r?void 0:r[1])]}),d&&r]}))};export{s as MarkdownModalContext,o as default};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
interface PickaxeHeadProps {
|
|
2
|
+
iconClassName?: string;
|
|
3
|
+
onIconClick?: () => void;
|
|
4
|
+
noClamp?: boolean;
|
|
5
|
+
}
|
|
6
|
+
declare const PickaxeHead: ({ iconClassName, onIconClick, noClamp, }: PickaxeHeadProps) => import("react/jsx-runtime").JSX.Element;
|
|
7
|
+
export default PickaxeHead;
|
|
@@ -6,6 +6,7 @@ interface PickaxeIconProps {
|
|
|
6
6
|
className?: string;
|
|
7
7
|
textColor?: string;
|
|
8
8
|
isLoading?: boolean;
|
|
9
|
+
onClick?: () => void;
|
|
9
10
|
}
|
|
10
|
-
declare const PickaxeIcon: ({ src, alt, width, height, className, textColor, isLoading, }: PickaxeIconProps) => import("react/jsx-runtime").JSX.Element | null;
|
|
11
|
+
declare const PickaxeIcon: ({ src, alt, width, height, className, textColor, isLoading, onClick, }: PickaxeIconProps) => import("react/jsx-runtime").JSX.Element | null;
|
|
11
12
|
export default PickaxeIcon;
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { type DetailedHTMLProps, type HTMLAttributes } from "react";
|
|
2
|
+
interface MarkdownModalBodyProps extends DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLDivElement> {
|
|
3
|
+
avoidOverflow?: boolean;
|
|
4
|
+
}
|
|
5
|
+
declare const MarkdownModalBody: import("react").ForwardRefExoticComponent<Omit<MarkdownModalBodyProps, "ref"> & import("react").RefAttributes<HTMLDivElement>>;
|
|
6
|
+
export default MarkdownModalBody;
|
package/dist/esm/src/components/Pickaxe/common/PickaxeMarkdown/Custom/common/Modal/CloseButton.d.ts
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { type CSSProperties, type ReactNode } from "react";
|
|
2
|
+
interface MarkdownModalCloseButtonProps {
|
|
3
|
+
className?: string;
|
|
4
|
+
icon?: ReactNode;
|
|
5
|
+
style?: CSSProperties;
|
|
6
|
+
onClick?: () => void;
|
|
7
|
+
}
|
|
8
|
+
declare const MarkdownModalCloseButton: ({ className, icon, style, onClick, }: MarkdownModalCloseButtonProps) => import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
export default MarkdownModalCloseButton;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { type Dispatch, type ReactNode, type SetStateAction } from "react";
|
|
2
|
+
type MarkdownModalContextType = {
|
|
3
|
+
isOpen: boolean;
|
|
4
|
+
closeOnOutsideClick: boolean;
|
|
5
|
+
setIsOpen: Dispatch<SetStateAction<boolean>>;
|
|
6
|
+
};
|
|
7
|
+
interface MarkdownModalProviderProps {
|
|
8
|
+
children: ReactNode | ReactNode[];
|
|
9
|
+
isOpen?: boolean;
|
|
10
|
+
closeOnOutsideClick?: boolean;
|
|
11
|
+
onChange?: (isOpen: boolean) => void;
|
|
12
|
+
}
|
|
13
|
+
export declare const MarkdownModalContext: import("react").Context<MarkdownModalContextType>;
|
|
14
|
+
declare const MarkdownModal: ({ children, isOpen: _isOpen, closeOnOutsideClick, onChange, }: MarkdownModalProviderProps) => import("react/jsx-runtime").JSX.Element;
|
|
15
|
+
export default MarkdownModal;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
1
|
+
import type { StudioFontSize } from "../../types/studio";
|
|
2
|
+
import type { PickaxeResponsiveBy } from "../../components/Pickaxe/Provider";
|
|
3
3
|
export type FontSizeType = "h1" | "h2" | "h3" | "h4" | "b1" | "b2" | "b3" | "b4" | "l1" | "l2";
|
|
4
4
|
export type FontListType = Record<FontSizeType, string>;
|
|
5
5
|
export declare const fontSizeMap: Record<PickaxeResponsiveBy, Record<StudioFontSize, Record<FontSizeType, string>>>;
|
package/package.json
CHANGED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),i=require("react"),t=require("../../../hooks/pickaxe/usePickaxeContext.js"),s=require("../../../hooks/studio/useStyleFontSize.js"),o=require("../../Icons/circle-info.svg.js"),l=require("../common/PickaxeIcon.js"),c=require("../common/PickaxeInfoModal.js"),n=require("../../../common/cn.js");exports.default=()=>{var r;const{pickaxe:a,colors:u,misc:m}=t.usePickaxeContext(),d=s.useStyleFontSize(),[x,h]=i.useState(!1);return e.jsxs("div",Object.assign({className:"flex flex-col items-center"},{children:[x&&e.jsx(c.default,{isOpen:x,onChangeIsOpen:h}),m.isProfileImage&&e.jsx(l.default,{src:null==a?void 0:a.coverphoto,alt:`${null==a?void 0:a.formtitle}'s Profile Picture`,width:90,height:90,className:"h-[90px] w-[90px] rounded-full"}),m.isTitle&&e.jsxs("h2",Object.assign({className:n.default(d.h2,"mt-6 text-center font-semilight opacity-70")},{children:[`${null==a?void 0:a.formtitle.slice(0,130)}${(null!==(r=null==a?void 0:a.formtitle)&&void 0!==r?r:"").length>130?"...":""}`,e.jsx("button",Object.assign({className:"ml-2 inline-block outline-none hover:opacity-70 hover:duration-300 active:opacity-100",onClick:()=>h(!0)},{children:e.jsx(o.default,{className:"h-5 w-5 shrink-0",style:{color:u.accent}})}))]})),m.isDescription&&e.jsx("p",Object.assign({className:n.default(d.b1,"mt-2 max-w-[600px] line-clamp-3 whitespace-pre-line text-center font-semilight opacity-70")},{children:null==a?void 0:a.formdescription}))]}))};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{jsxs as e,jsx as o}from"react/jsx-runtime";import{useState as i}from"react";import{usePickaxeContext as t}from"../../../hooks/pickaxe/usePickaxeContext.js";import{useStyleFontSize as c}from"../../../hooks/studio/useStyleFontSize.js";import s from"../../Icons/circle-info.svg.js";import l from"../common/PickaxeIcon.js";import n from"../common/PickaxeInfoModal.js";import r from"../../../common/cn.js";const m=()=>{var m;const{pickaxe:a,colors:p,misc:f}=t(),h=c(),[d,u]=i(!1);return e("div",Object.assign({className:"flex flex-col items-center"},{children:[d&&o(n,{isOpen:d,onChangeIsOpen:u}),f.isProfileImage&&o(l,{src:null==a?void 0:a.coverphoto,alt:`${null==a?void 0:a.formtitle}'s Profile Picture`,width:90,height:90,className:"h-[90px] w-[90px] rounded-full"}),f.isTitle&&e("h2",Object.assign({className:r(h.h2,"mt-6 text-center font-semilight opacity-70")},{children:[`${null==a?void 0:a.formtitle.slice(0,130)}${(null!==(m=null==a?void 0:a.formtitle)&&void 0!==m?m:"").length>130?"...":""}`,o("button",Object.assign({className:"ml-2 inline-block outline-none hover:opacity-70 hover:duration-300 active:opacity-100",onClick:()=>u(!0)},{children:o(s,{className:"h-5 w-5 shrink-0",style:{color:p.accent}})}))]})),f.isDescription&&o("p",Object.assign({className:r(h.b1,"mt-2 max-w-[600px] line-clamp-3 whitespace-pre-line text-center font-semilight opacity-70")},{children:null==a?void 0:a.formdescription}))]}))};export{m as default};
|