@pickaxeproject/react 0.0.52 → 0.0.54
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/Pickaxe/Addons/Scroll/Provider.js +1 -1
- package/dist/cjs/components/Pickaxe/Addons/Scroll/ScrollLockView.js +1 -1
- package/dist/cjs/components/Pickaxe/Addons/Scroll/hooks/useScroll.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/common/PickaxeMarkdown/Renderer.js +1 -1
- package/dist/cjs/src/components/Pickaxe/Addons/Scroll/Provider.d.ts +4 -0
- package/dist/cjs/src/components/Pickaxe/Addons/Scroll/hooks/useScroll.d.ts +2 -0
- package/dist/cjs/src/components/Pickaxe/Addons/Scroll/hooks/useScrollContext.d.ts +4 -0
- package/dist/esm/components/Pickaxe/Addons/Scroll/Provider.js +1 -1
- package/dist/esm/components/Pickaxe/Addons/Scroll/ScrollLockView.js +1 -1
- package/dist/esm/components/Pickaxe/Addons/Scroll/hooks/useScroll.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/common/PickaxeMarkdown/Renderer.js +1 -1
- package/dist/esm/src/components/Pickaxe/Addons/Scroll/Provider.d.ts +4 -0
- package/dist/esm/src/components/Pickaxe/Addons/Scroll/hooks/useScroll.d.ts +2 -0
- package/dist/esm/src/components/Pickaxe/Addons/Scroll/hooks/useScrollContext.d.ts +4 -0
- package/package.json +1 -1
|
@@ -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"),s=require("react");const r=s.createContext({});exports.ScrollContext=r,exports.default=({children:t})=>{const[l,o]=s.useState(!0),[c,i]=s.useState(!0),[n,a]=s.useState(!1),[u,S]=s.useState(!0),d=s.useRef(),f=s.useRef(),x=s.useRef(!1);return e.jsx(r.Provider,Object.assign({value:{scrollContainerRef:d,scrollTargetRef:f,hasScrolledRef:x,isLocked:l,isScrollSession:c,isScrolling:n,isScrollIncreasing:u,setIsLocked:o,setIsScrollSession:i,setIsScrolling:a,setIsScrollIncreasing:S}},{children:t}))};
|
|
@@ -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"),s=require("react-intersection-observer"),r=require("./hooks/useScrollContext.js");exports.default=({className:t})=>{const{setIsLocked:o}=r.useScrollContext(),{ref:c}=s.useInView({onChange(e){e&&o(!0)}});return e.jsx("div",Object.assign({ref:c,className:"scroll-lock-view"},t&&{className:t}))};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),r=require("./useScrollContext.js");exports.useScroll=({auto:o})=>{const{scrollContainerRef:l,scrollTargetRef:t,
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),r=require("./useScrollContext.js");exports.useScroll=({auto:o})=>{const{scrollContainerRef:l,scrollTargetRef:t,isLocked:n,isScrollSession:s,isScrollIncreasing:c,setIsLocked:u,setIsScrollSession:i,setIsScrolling:d,setIsScrollIncreasing:v}=r.useScrollContext(),[a,f]=e.useState(0),E=e.useRef(!1),S=e.useMemo((()=>l&&l.current?l.current:"undefined"==typeof window?null:window),[l]);e.useEffect((()=>{if(!S)return;const e=e=>{s&&n&&("mousedown"===e.type||"wheel"===e.type||"DOMMouseScroll"===e.type||"mousewheel"===e.type)&&u(!1)};return null==S||S.addEventListener("scroll",e),null==S||S.addEventListener("mousedown",e),null==S||S.addEventListener("wheel",e),null==S||S.addEventListener("DOMMouseScroll",e),null==S||S.addEventListener("mousewheel",e),()=>{null==S||S.removeEventListener("scroll",e),null==S||S.removeEventListener("mousedown",e),null==S||S.removeEventListener("wheel",e),null==S||S.removeEventListener("DOMMouseScroll",e),null==S||S.removeEventListener("mousewheel",e)}}),[S,s,n]),e.useEffect((()=>{E.current=!n}),[n]),e.useEffect((()=>{const e=setInterval((()=>{if(l.current){const e=l.current.scrollHeight;if(e===a)return;const r=e>a;v(r),f(e),r&&o&&m()}}),100);return()=>clearInterval(e)}),[l,a]);const m=()=>{try{if(d(!0),!l.current)return void("development"===process.env.NODE_ENV&&console.log("[useScroll] scrollContainerRef not detected"));if(E.current)return;const e=l.current.scrollHeight;l.current.scrollTo({top:e,behavior:"smooth"}),"development"===process.env.NODE_ENV&&console.log("[useScroll] scrolled scrollContainerRef")}finally{d(!1)}};return{isScrollIncreasing:c,scrollStartSession:()=>{i(!0),u(!0),E.current=!1},scrollEndSession:()=>{i(!1)},scrollToBottom:m,scrollToTarget:()=>{try{d(!0);const e=l.current||window;if(!t.current)return void("development"===process.env.NODE_ENV&&console.log("[useScroll] scrollTargetRef not detected"));const r=e.scrollHeight;e.scrollTo({top:r,behavior:"smooth"}),"development"===process.env.NODE_ENV&&console.log("[useScroll] scrolled scrollTargetRef")}finally{d(!1)}}}};
|
|
@@ -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"),n=require("../../../hooks/studio/useStyleInput.js"),a=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/send.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:O,pickaxe:D,colors:C,misc:A,responsiveBy:N,isNewChat:_,forceMobile:M,setIsNewChat:
|
|
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"),n=require("../../../hooks/studio/useStyleInput.js"),a=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/send.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:O,pickaxe:D,colors:C,misc:A,responsiveBy:N,isNewChat:_,forceMobile:M,setIsNewChat:E,setIsShowIceBreaker:R,onGenerateComplete:U}=r.usePickaxeContext(),{messages:z,status:B,limits:F,setMessages:P,setStatus:T,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,re]=t.useState(""),ie=t.useRef(null),[ne]=o.useMediaQuery("(max-width: 767px)"),ae=n.useStyleInput(),le=a.useStyleFontSize({type:"body"}),de=t.useMemo((()=>{var e,s,t;return!!_&&(!!D&&(!ee.isLoading&&(!((null!==(s=null===(e=ee.data)||void 0===e?void 0:e.messages.length)&&void 0!==s?s:0)>1)&&!!(null===(t=D.icebreakers)||void 0===t?void 0:t.length))))}),[D,_,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:oe;if(!e)return;re(""),W(""),L(null),G(!0),E(!1);const t=new Date,o="enduserupload"===(null==D?void 0:D.documentuploadtype),r=K.filter((e=>"finished"===e.status&&!e.isInsertedAsRaw)),i=r.length?r[r.length-1].documentId:"";T("fetching"),Y(),$();const n=[...z,{id:z.length+1,role:"user",content:e}];P(n),$();const{success:a,data:l,usedDocumentIds:d,newDocumentId:u,newDocumentName:c,rawUserInput:m,isInsertedFile:p,error:x}=yield se.mutateAsync(Object.assign(Object.assign(Object.assign({formId:k,responseId:w,value:e},o&&i&&{documentId:i}),S&&{studioUserId:S}),O&&{deploymentId:O}));if(!a)throw new Error(null!=x?x:"An error occurred, please try again.");$(),p&&i&&X({documentId:i,isInsertedAsRaw:!0}),u&&c&&J([{type:"website",id:c,name:c,status:"finished",documentId:u}]),$();const f=(yield h.streamer({formId:k,responseId:w,data:l})).body;if(!f)throw new Error("Streaming error");const g=f.getReader(),j=new TextDecoder,b=n.length;let y="",v=!0;for(T("streaming");v;){const{value:e,done:s}=yield g.read();v=!s;if(y+=j.decode(e),y)P([...n.slice(0,b),{id:z.length+1,role:"assistant",content:y}]);else if(!v&&!y)throw new Error("Server error")}const I=new Date;y&&($(),T("idle"),yield te.mutateAsync(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({formId:k,responseId:w,documentIds:d},q&&{userId:q}),S&&{studioUserId:S}),S&&(null==D?void 0:D.studioid)&&{studioId:D.studioid}),O&&{deploymentId:O}),{messages:[{role:"user",message:m,sentAt:t},{role:"assistant",message:y,sentAt:I}]})),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(F).find((([e])=>s.includes(e)));t?L(t[1]):W(s),$()}finally{T("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==D?void 0:D.icebreakers)||[],style:{backgroundColor:C.secondary,color:C.secondaryText},isMobile:M||ne,onSend:ue}),s.jsxs("div",Object.assign({style:ae,className:"flex min-h-[56px] items-end gap-x-2 px-4 py-3 pb-[15px] shadow"},{children:["enduserupload"===(null==D?void 0:D.documentuploadtype)&&s.jsxs("div",Object.assign({className:"tooltip"},{children:[s.jsx("input",{id:"file-upload",ref:ie,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=ie.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(le("max-h-60 w-full resize-none border-transparent bg-transparent outline-none ring-0 scrollbar scrollbar-thin placeholder:font-semilight"),!oe.length&&"max-h-6 overflow-hidden text-ellipsis whitespace-nowrap"),value:oe,placeholder:null!==(I=null==D?void 0:D.placeholdertext)&&void 0!==I?I:"What do you want to talk about?",onChange:e=>re(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: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"),l=require("../../Addons/Document/hooks/useDocument.js"),u=require("../../Addons/Scroll/hooks/useScroll.js"),a=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:P,setResponse:R,setStatus:U,setLimitData:C,setError:D,setIsGenerating:E}=i.useResponseContext(),{documents:A,websiteLink:T,isUploading:_,onWebsiteUpload:L,setDocumentError:N}=l.useDocument(),{scrollStartSession:B,scrollEndSession:W,scrollToTarget:G,scrollToBottom:H}=u.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;C(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.");D("");const l=["Multiple Choice","Checkbox"];for(const e of g){if(c.encode(e.input).length>e.maxLength&&!l.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 u=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==u?void 0:u.name)||"":e.input}))),U("fetching");const{success:p,responseId:x,data:f,usedDocumentIds:y,rawUserInput:I,error:k}=yield M.mutateAsync(Object.assign(Object.assign(Object.assign({formId:j,valueObj:m},s&&u&&{documentId:null!==(e=u.documentId)&&void 0!==e?e:""}),w&&{studioUserId:w}),b&&{deploymentId:b}));if(!p)throw new Error(null!=k?k:"An error occurred, please try again.");const v=(yield a.streamer({formId:j,responseId:x,data:f})).body;if(!v)throw new Error("Streaming error");const P=v.getReader(),W=new TextDecoder;let G="",z=!0,J=!1;R(null);const Q=g.map((e=>({id:e.id,question:e.main,answer:e.input})));for(;z;){const{value:e,done:s}=yield P.read();z=!s;const t=W.decode(e);if(G&&!J&&(B(),H(),J=!0),G+=t,G)U("streaming"),R({formId:j,responseId:x,documentIds:y,messages:[],questions:Q,questionPrompt:I,questionResponse:G,createdAt:new Date});else if(!z&&!G)throw new Error("Server error")}G&&(H(),U("idle"),yield F.mutateAsync(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({formId:j,responseId:x,documentIds:y},h&&{userId:h}),w&&{studioUserId:w}),w&&(null==q?void 0:q.studioid)&&{studioId:q.studioid}),b&&{deploymentId:b}),{questions:Q,questionPrompt:I,questionResponse:G})),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(P).find((([e])=>s.includes(e)));t?C(t[1]):D(s),G(),H()}finally{U("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"),i=require("react"),t=require("./hooks/usePickaxeMarkdownContext.js"),r=require("react-markdown"),s=require("remark-gfm"),n=require("remark-math"),l=require("rehype-katex"),d=require("./Custom/A/index.js"),a=require("./Custom/P/index.js"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),i=require("react"),t=require("./hooks/usePickaxeMarkdownContext.js"),r=require("react-markdown"),s=require("remark-gfm"),n=require("remark-math"),l=require("rehype-katex"),d=require("./Custom/A/index.js"),a=require("./Custom/P/index.js"),c=require("./Custom/Img/index.js"),o=require("./Custom/Iframe/index.js"),h=require("./Custom/Code/index.js"),m=require("./Custom/common/LinkPreview.js");function u(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var j=u(r),x=u(s),g=u(n),f=u(l);exports.PickaxeMarkdownRenderer=({className:r,style:s,value:n,recursion:l=!1})=>{const{theme:u,websiteMetadatas:p}=t.usePickaxeMarkdownContext(),b=i.useRef(null),y=i.useMemo((()=>{if(!n)return"";let e=n;return e=n.replace(/<!--[\s\S]*?-->/g,""),e=n.replace(/\u200B/g,""),e}),[n]),k={h1:({node:i,children:t})=>e.jsx("h1",Object.assign({style:{fontSize:"2.25rem",lineHeight:"2.5rem"}},{children:t})),h2:({node:i,children:t})=>e.jsx("h2",Object.assign({style:{fontSize:"1.875rem",lineHeight:"2.25rem"}},{children:t})),h3:({node:i,children:t})=>e.jsx("h3",Object.assign({style:{fontSize:"1.5rem",lineHeight:"2rem"}},{children:t})),h4:({node:i,children:t})=>e.jsx("h4",Object.assign({className:"mt-2 text-xl",style:{fontSize:"1.25rem",lineHeight:"1.75rem"}},{children:t})),h5:({node:i,children:t})=>e.jsx("h5",Object.assign({style:{fontSize:"1.125rem",lineHeight:"1.75rem"}},{children:t})),p:a.default,a:d.default,ol:({node:i,children:t})=>e.jsx("ol",Object.assign({style:{listStyleType:"decimal",listStylePosition:"inside",paddingLeft:"1.5rem",whiteSpace:"normal"}},{children:t})),ul:({node:i,children:t})=>e.jsx("ul",Object.assign({style:{listStyleType:"disc",listStylePosition:"inside",paddingLeft:"1.5rem",whiteSpace:"normal"}},{children:t})),li:({node:i,children:t})=>e.jsx("li",Object.assign({style:{whiteSpace:"normal"}},{children:t})),table:({children:i})=>e.jsx("div",Object.assign({className:"overflow-auto"},{children:e.jsx("table",Object.assign({style:{tableLayout:"fixed",fontSize:"0.875rem",lineHeight:"1.24rem"}},{children:i}))})),th:({node:i,children:t})=>e.jsx("th",Object.assign({style:{padding:"0.75em 1em",fontWeight:600,textAlign:"left"}},{children:t})),tr:({node:i,children:t})=>e.jsx("tr",Object.assign({style:{border:"dark"===u?"1px solid #30363D":"1px solid #D0D7DE"}},{children:t})),td:({node:i,children:t})=>e.jsx("td",Object.assign({style:{padding:"0.75em 1em"}},{children:t})),code:h.default,blockquote:({node:i,children:t})=>e.jsx("blockquote",Object.assign({style:{lineHeight:"15px",borderLeft:"dark"===u?"4px solid #30363D":"4px solid #D0D7DE",color:"dark"===u?"#8B8B8B":"#656D76",paddingLeft:"1rem",marginBottom:"1rem"}},{children:t})),img:c.default,iframe:o.default};return e.jsxs("div",Object.assign({className:"pxe-markdown",ref:b,style:Object.assign({position:"relative",whiteSpace:"pre-wrap"},s)},{children:[e.jsx(j.default,Object.assign({},r&&{className:r},{components:k,remarkPlugins:[x.default,g.default],rehypePlugins:[f.default]},{children:y})),!l&&p.length>0&&e.jsx("div",Object.assign({style:{display:"flex",flexDirection:"column",gap:"2rem"}},{children:p.map(((i,t)=>e.jsx(m.default,{data:i},t)))}))]}))};
|
|
@@ -5,8 +5,12 @@ type ScrollContextType = {
|
|
|
5
5
|
scrollContainerRef: MutableRefObject<HTMLDivElement>;
|
|
6
6
|
scrollTargetRef: MutableRefObject<HTMLDivElement>;
|
|
7
7
|
hasScrolledRef: MutableRefObject<boolean>;
|
|
8
|
+
isLocked: boolean;
|
|
9
|
+
isScrollSession: boolean;
|
|
8
10
|
isScrolling: boolean;
|
|
9
11
|
isScrollIncreasing: boolean;
|
|
12
|
+
setIsLocked: SetState<boolean>;
|
|
13
|
+
setIsScrollSession: SetState<boolean>;
|
|
10
14
|
setIsScrolling: SetState<boolean>;
|
|
11
15
|
setIsScrollIncreasing: SetState<boolean>;
|
|
12
16
|
};
|
|
@@ -3,8 +3,12 @@ export declare const useScrollContext: () => {
|
|
|
3
3
|
scrollContainerRef: import("react").MutableRefObject<HTMLDivElement>;
|
|
4
4
|
scrollTargetRef: import("react").MutableRefObject<HTMLDivElement>;
|
|
5
5
|
hasScrolledRef: import("react").MutableRefObject<boolean>;
|
|
6
|
+
isLocked: boolean;
|
|
7
|
+
isScrollSession: boolean;
|
|
6
8
|
isScrolling: boolean;
|
|
7
9
|
isScrollIncreasing: boolean;
|
|
10
|
+
setIsLocked: import("../../../../../types/common").SetState<boolean>;
|
|
11
|
+
setIsScrollSession: import("../../../../../types/common").SetState<boolean>;
|
|
8
12
|
setIsScrolling: import("../../../../../types/common").SetState<boolean>;
|
|
9
13
|
setIsScrollIncreasing: import("../../../../../types/common").SetState<boolean>;
|
|
10
14
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{jsx as
|
|
1
|
+
import{jsx as e}from"react/jsx-runtime";import{useState as r,useRef as s,createContext as l}from"react";const o=l({}),c=({children:l})=>{const[c,i]=r(!0),[n,t]=r(!0),[a,S]=r(!1),[d,f]=r(!0),g=s(),I=s(),m=s(!1);return e(o.Provider,Object.assign({value:{scrollContainerRef:g,scrollTargetRef:I,hasScrolledRef:m,isLocked:c,isScrollSession:n,isScrolling:a,isScrollIncreasing:d,setIsLocked:i,setIsScrollSession:t,setIsScrolling:S,setIsScrollIncreasing:f}},{children:l}))};export{o as ScrollContext,c as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{jsx as e}from"react/jsx-runtime";import{useInView as
|
|
1
|
+
import{jsx as e}from"react/jsx-runtime";import{useInView as s}from"react-intersection-observer";import{useScrollContext as o}from"./hooks/useScrollContext.js";const r=({className:r})=>{const{setIsLocked:t}=o(),{ref:c}=s({onChange(e){e&&t(!0)}});return e("div",Object.assign({ref:c,className:"scroll-lock-view"},r&&{className:r}))};export{r as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{useState as e,useEffect as
|
|
1
|
+
import{useState as e,useRef as o,useMemo as r,useEffect as l}from"react";import{useScrollContext as n}from"./useScrollContext.js";const t=({auto:t})=>{const{scrollContainerRef:s,scrollTargetRef:c,isLocked:u,isScrollSession:i,isScrollIncreasing:d,setIsLocked:v,setIsScrollSession:a,setIsScrolling:m,setIsScrollIncreasing:E}=n(),[S,f]=e(0),p=o(!1),g=r((()=>s&&s.current?s.current:"undefined"==typeof window?null:window),[s]);l((()=>{if(!g)return;const e=e=>{i&&u&&("mousedown"===e.type||"wheel"===e.type||"DOMMouseScroll"===e.type||"mousewheel"===e.type)&&v(!1)};return null==g||g.addEventListener("scroll",e),null==g||g.addEventListener("mousedown",e),null==g||g.addEventListener("wheel",e),null==g||g.addEventListener("DOMMouseScroll",e),null==g||g.addEventListener("mousewheel",e),()=>{null==g||g.removeEventListener("scroll",e),null==g||g.removeEventListener("mousedown",e),null==g||g.removeEventListener("wheel",e),null==g||g.removeEventListener("DOMMouseScroll",e),null==g||g.removeEventListener("mousewheel",e)}}),[g,i,u]),l((()=>{p.current=!u}),[u]),l((()=>{const e=setInterval((()=>{if(s.current){const e=s.current.scrollHeight;if(e===S)return;const o=e>S;E(o),f(e),o&&t&&w()}}),100);return()=>clearInterval(e)}),[s,S]);const w=()=>{try{if(m(!0),!s.current)return void("development"===process.env.NODE_ENV&&console.log("[useScroll] scrollContainerRef not detected"));if(p.current)return;const e=s.current.scrollHeight;s.current.scrollTo({top:e,behavior:"smooth"}),"development"===process.env.NODE_ENV&&console.log("[useScroll] scrolled scrollContainerRef")}finally{m(!1)}};return{isScrollIncreasing:d,scrollStartSession:()=>{a(!0),v(!0),p.current=!1},scrollEndSession:()=>{a(!1)},scrollToBottom:w,scrollToTarget:()=>{try{m(!0);const e=s.current||window;if(!c.current)return void("development"===process.env.NODE_ENV&&console.log("[useScroll] scrollTargetRef not detected"));const o=e.scrollHeight;e.scrollTo({top:o,behavior:"smooth"}),"development"===process.env.NODE_ENV&&console.log("[useScroll] scrolled scrollTargetRef")}finally{m(!1)}}}};export{t as useScroll};
|
|
@@ -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 b,allowedImageMimeTypes as x}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/send.svg.js";import k from"../common/PickaxeBranding.js";import w from"../Addons/IceBreaker/index.js";import O from"../../../common/error.js";import
|
|
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 b,allowedImageMimeTypes as x}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/send.svg.js";import k from"../common/PickaxeBranding.js";import w from"../Addons/IceBreaker/index.js";import O from"../../../common/error.js";import S from"../../../common/cn.js";const D=()=>{var D;const{formId:A,chatId:N,userId:C,studioUserId:U,deploymentId:E,pickaxe:_,colors:B,misc:z,responsiveBy:R,isNewChat:L,forceMobile:M,setIsNewChat:F,setIsShowIceBreaker:P,onGenerateComplete:T}=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,de]=s(""),ce=r(null),[me]=a("(max-width: 767px)"),ue=c(),pe=m({type:"body"}),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((()=>{P(fe)}),[fe]);const he=t=>e(void 0,void 0,void 0,(function*(){try{if(Y||"idle"!==G)return;const e=null!=t?t:le;if(!e)return;de(""),J(""),q(null),V(!0),F(!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,usedDocumentIds:d,newDocumentId:c,newDocumentName:m,rawUserInput:u,isInsertedFile:p,error:f}=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!=f?f:"An error occurred, please try again.");re(),p&&i&&te({documentId:i,isInsertedAsRaw:!0}),c&&m&&$([{type:"website",id:m,name:m,status:"finished",documentId:c}]),re();const h=(yield v({formId:A,responseId:N,data:l})).body;if(!h)throw new Error("Streaming error");const g=h.getReader(),b=new TextDecoder,x=n.length;let y="",j=!0;for(Q("streaming");j;){const{value:e,done:t}=yield g.read();j=!t;if(y+=b.decode(e),y)H([...n.slice(0,x),{id:W.length+1,role:"assistant",content:y}]);else if(!j&&!y)throw new Error("Server error")}const I=new Date;y&&(re(),Q("idle"),yield ae.mutateAsync(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({formId:A,responseId:N,documentIds:d},C&&{userId:C}),U&&{studioUserId:U}),U&&(null==_?void 0:_.studioid)&&{studioId:_.studioid}),E&&{deploymentId:E}),{messages:[{role:"user",message:u,sentAt:o},{role:"assistant",message:y,sentAt:I}]})),null==T||T(N))}catch(e){let t=O(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:S("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||me,onSend:he}),t("div",Object.assign({style:ue,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:ce,type:"file",accept:[...b,...Z?x:[]].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=ce.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:S(pe("max-h-60 w-full resize-none border-transparent bg-transparent outline-none ring-0 scrollbar scrollbar-thin placeholder:font-semilight"),!le.length&&"max-h-6 overflow-hidden text-ellipsis whitespace-nowrap"),value:le,placeholder:null!==(D=null==_?void 0:_.placeholdertext)&&void 0!==D?D:"What do you want to talk about?",onChange:e=>de(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:B.accent}})}))]}))]}))};export{D 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 r}from"../../../../hooks/pickaxe/useResponseContext.js";import{useSubmit as n}from"../../../../hooks/pickaxe/useSubmit.js";import{useSubmitResult as d}from"../../../../hooks/pickaxe/useSubmitResult.js";import{useDocument 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 r}from"../../../../hooks/pickaxe/useResponseContext.js";import{useSubmit as n}from"../../../../hooks/pickaxe/useSubmit.js";import{useSubmitResult as d}from"../../../../hooks/pickaxe/useSubmitResult.js";import{useDocument as l}from"../../Addons/Document/hooks/useDocument.js";import{useScroll as a}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:E,limits:P,setResponse:U,setStatus:D,setLimitData:R,setError:A,setIsGenerating:C}=r(),{documents:L,websiteLink:N,isUploading:T,onWebsiteUpload:B,setDocumentError:W}=l(),{scrollStartSession:G,scrollEndSession:H,scrollToTarget:_,scrollToBottom:K}=a({auto:!0}),M=n(),Y=d(),[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"!==E,onClick:()=>e(void 0,void 0,void 0,(function*(){var e;try{if(T||z||"idle"!==E)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),r=L.map((e=>e.name)),n=i.filter((e=>!r.includes(e)));if(n.length){const e=n[n.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 d=["Multiple Choice","Checkbox"];for(const e of h){if(u(e.input).length>e.maxLength&&!d.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=s.length?s[s.length-1]:null;let a={};h.forEach((e=>a=Object.assign(Object.assign({},a),{[e.id]:"Knowledge Upload"===e.type||e.id.includes("documentupload")?(null==l?void 0:l.name)||"":e.input}))),D("fetching");const{success:p,responseId:f,data:g,usedDocumentIds:x,rawUserInput:k,error:v}=yield M.mutateAsync(Object.assign(Object.assign(Object.assign({formId:w,valueObj:a},o&&l&&{documentId:null!==(e=l.documentId)&&void 0!==e?e:""}),b&&{studioUserId:b}),y&&{deploymentId:y}));if(!p)throw new Error(null!=v?v:"An error occurred, please try again.");const O=(yield c({formId:w,responseId:f,data:g})).body;if(!O)throw new Error("Streaming error");const S=O.getReader(),P=new TextDecoder;let H="",_=!0,J=!1;U(null);const Q=h.map((e=>({id:e.id,question:e.main,answer:e.input})));for(;_;){const{value:e,done:o}=yield S.read();_=!o;const t=P.decode(e);if(H&&!J&&(G(),K(),J=!0),H+=t,H)D("streaming"),U({formId:w,responseId:f,documentIds:x,messages:[],questions:Q,questionPrompt:k,questionResponse:H,createdAt:new Date});else if(!_&&!H)throw new Error("Server error")}H&&(K(),D("idle"),yield Y.mutateAsync(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({formId:w,responseId:f,documentIds:x},j&&{userId:j}),b&&{studioUserId:b}),b&&(null==I?void 0:I.studioid)&&{studioId:I.studioid}),y&&{deploymentId:y}),{questions:Q,questionPrompt:k,questionResponse:H})),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(P).find((([e])=>o.includes(e)));t?R(t[1]):A(o),_(),K()}finally{D("idle"),C(!1),F(!1),H()}}))},{children:z?"Processing...":T?"Uploading...":"fetching"===E||"streaming"===E?"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{jsxs as e,jsx as i}from"react/jsx-runtime";import{useRef as t,useMemo as r}from"react";import{usePickaxeMarkdownContext as n}from"./hooks/usePickaxeMarkdownContext.js";import l from"react-markdown";import s from"remark-gfm";import o from"remark-math";import d from"rehype-katex";import m from"./Custom/A/index.js";import a from"./Custom/P/index.js";import c from"./Custom/Img/index.js";import h from"./Custom/Iframe/index.js";import p from"./Custom/Code/index.js";import g from"./Custom/common/LinkPreview.js";const f=({className:f,style:b,value:j,recursion:y=!1})=>{const{theme:u,websiteMetadatas:x}=n(),O=t(null),k=r((()=>{if(!j)return"";let e=j;return e=j.replace(/<!--[\s\S]*?-->/g,""),e=j.replace(/\u200B/g,""),e}),[j]),S={h1:({node:e,children:t})=>i("h1",Object.assign({style:{fontSize:"2.25rem",lineHeight:"2.5rem"}},{children:t})),h2:({node:e,children:t})=>i("h2",Object.assign({style:{fontSize:"1.875rem",lineHeight:"2.25rem"}},{children:t})),h3:({node:e,children:t})=>i("h3",Object.assign({style:{fontSize:"1.5rem",lineHeight:"2rem"}},{children:t})),h4:({node:e,children:t})=>i("h4",Object.assign({className:"mt-2 text-xl",style:{fontSize:"1.25rem",lineHeight:"1.75rem"}},{children:t})),h5:({node:e,children:t})=>i("h5",Object.assign({style:{fontSize:"1.125rem",lineHeight:"1.75rem"}},{children:t})),p:a,a:m,ol:({node:e,children:t})=>i("ol",Object.assign({style:{listStyleType:"decimal",listStylePosition:"inside",paddingLeft:"1.5rem",whiteSpace:"normal"}},{children:t})),ul:({node:e,children:t})=>i("ul",Object.assign({style:{listStyleType:"disc",listStylePosition:"inside",paddingLeft:"1.5rem",whiteSpace:"normal"}},{children:t})),li:({node:e,children:t})=>i("li",{children:t}),table:({children:e})=>i("div",Object.assign({className:"overflow-auto"},{children:i("table",Object.assign({style:{tableLayout:"fixed",fontSize:"0.875rem",lineHeight:"1.24rem"}},{children:e}))})),th:({node:e,children:t})=>i("th",Object.assign({style:{padding:"0.75em 1em",fontWeight:600,textAlign:"left"}},{children:t})),tr:({node:e,children:t})=>i("tr",Object.assign({style:{border:"dark"===u?"1px solid #30363D":"1px solid #D0D7DE"}},{children:t})),td:({node:e,children:t})=>i("td",Object.assign({style:{padding:"0.75em 1em"}},{children:t})),code:p,blockquote:({node:e,children:t})=>i("blockquote",Object.assign({style:{lineHeight:"15px",borderLeft:"dark"===u?"4px solid #30363D":"4px solid #D0D7DE",color:"dark"===u?"#8B8B8B":"#656D76",paddingLeft:"1rem",marginBottom:"1rem"}},{children:t})),img:c,iframe:h};return e("div",Object.assign({className:"pxe-markdown",ref:O,style:Object.assign({position:"relative",whiteSpace:"pre-wrap"},b)},{children:[i(l,Object.assign({},f&&{className:f},{components:S,remarkPlugins:[s,o],rehypePlugins:[d]},{children:k})),!y&&x.length>0&&i("div",Object.assign({style:{display:"flex",flexDirection:"column",gap:"2rem"}},{children:x.map(((e,t)=>i(g,{data:e},t)))}))]}))};export{f as PickaxeMarkdownRenderer};
|
|
1
|
+
import{jsxs as e,jsx as i}from"react/jsx-runtime";import{useRef as t,useMemo as r}from"react";import{usePickaxeMarkdownContext as n}from"./hooks/usePickaxeMarkdownContext.js";import l from"react-markdown";import s from"remark-gfm";import o from"remark-math";import d from"rehype-katex";import m from"./Custom/A/index.js";import a from"./Custom/P/index.js";import c from"./Custom/Img/index.js";import h from"./Custom/Iframe/index.js";import p from"./Custom/Code/index.js";import g from"./Custom/common/LinkPreview.js";const f=({className:f,style:b,value:j,recursion:y=!1})=>{const{theme:u,websiteMetadatas:x}=n(),O=t(null),k=r((()=>{if(!j)return"";let e=j;return e=j.replace(/<!--[\s\S]*?-->/g,""),e=j.replace(/\u200B/g,""),e}),[j]),S={h1:({node:e,children:t})=>i("h1",Object.assign({style:{fontSize:"2.25rem",lineHeight:"2.5rem"}},{children:t})),h2:({node:e,children:t})=>i("h2",Object.assign({style:{fontSize:"1.875rem",lineHeight:"2.25rem"}},{children:t})),h3:({node:e,children:t})=>i("h3",Object.assign({style:{fontSize:"1.5rem",lineHeight:"2rem"}},{children:t})),h4:({node:e,children:t})=>i("h4",Object.assign({className:"mt-2 text-xl",style:{fontSize:"1.25rem",lineHeight:"1.75rem"}},{children:t})),h5:({node:e,children:t})=>i("h5",Object.assign({style:{fontSize:"1.125rem",lineHeight:"1.75rem"}},{children:t})),p:a,a:m,ol:({node:e,children:t})=>i("ol",Object.assign({style:{listStyleType:"decimal",listStylePosition:"inside",paddingLeft:"1.5rem",whiteSpace:"normal"}},{children:t})),ul:({node:e,children:t})=>i("ul",Object.assign({style:{listStyleType:"disc",listStylePosition:"inside",paddingLeft:"1.5rem",whiteSpace:"normal"}},{children:t})),li:({node:e,children:t})=>i("li",Object.assign({style:{whiteSpace:"normal"}},{children:t})),table:({children:e})=>i("div",Object.assign({className:"overflow-auto"},{children:i("table",Object.assign({style:{tableLayout:"fixed",fontSize:"0.875rem",lineHeight:"1.24rem"}},{children:e}))})),th:({node:e,children:t})=>i("th",Object.assign({style:{padding:"0.75em 1em",fontWeight:600,textAlign:"left"}},{children:t})),tr:({node:e,children:t})=>i("tr",Object.assign({style:{border:"dark"===u?"1px solid #30363D":"1px solid #D0D7DE"}},{children:t})),td:({node:e,children:t})=>i("td",Object.assign({style:{padding:"0.75em 1em"}},{children:t})),code:p,blockquote:({node:e,children:t})=>i("blockquote",Object.assign({style:{lineHeight:"15px",borderLeft:"dark"===u?"4px solid #30363D":"4px solid #D0D7DE",color:"dark"===u?"#8B8B8B":"#656D76",paddingLeft:"1rem",marginBottom:"1rem"}},{children:t})),img:c,iframe:h};return e("div",Object.assign({className:"pxe-markdown",ref:O,style:Object.assign({position:"relative",whiteSpace:"pre-wrap"},b)},{children:[i(l,Object.assign({},f&&{className:f},{components:S,remarkPlugins:[s,o],rehypePlugins:[d]},{children:k})),!y&&x.length>0&&i("div",Object.assign({style:{display:"flex",flexDirection:"column",gap:"2rem"}},{children:x.map(((e,t)=>i(g,{data:e},t)))}))]}))};export{f as PickaxeMarkdownRenderer};
|
|
@@ -5,8 +5,12 @@ type ScrollContextType = {
|
|
|
5
5
|
scrollContainerRef: MutableRefObject<HTMLDivElement>;
|
|
6
6
|
scrollTargetRef: MutableRefObject<HTMLDivElement>;
|
|
7
7
|
hasScrolledRef: MutableRefObject<boolean>;
|
|
8
|
+
isLocked: boolean;
|
|
9
|
+
isScrollSession: boolean;
|
|
8
10
|
isScrolling: boolean;
|
|
9
11
|
isScrollIncreasing: boolean;
|
|
12
|
+
setIsLocked: SetState<boolean>;
|
|
13
|
+
setIsScrollSession: SetState<boolean>;
|
|
10
14
|
setIsScrolling: SetState<boolean>;
|
|
11
15
|
setIsScrollIncreasing: SetState<boolean>;
|
|
12
16
|
};
|
|
@@ -3,8 +3,12 @@ export declare const useScrollContext: () => {
|
|
|
3
3
|
scrollContainerRef: import("react").MutableRefObject<HTMLDivElement>;
|
|
4
4
|
scrollTargetRef: import("react").MutableRefObject<HTMLDivElement>;
|
|
5
5
|
hasScrolledRef: import("react").MutableRefObject<boolean>;
|
|
6
|
+
isLocked: boolean;
|
|
7
|
+
isScrollSession: boolean;
|
|
6
8
|
isScrolling: boolean;
|
|
7
9
|
isScrollIncreasing: boolean;
|
|
10
|
+
setIsLocked: import("../../../../../types/common").SetState<boolean>;
|
|
11
|
+
setIsScrollSession: import("../../../../../types/common").SetState<boolean>;
|
|
8
12
|
setIsScrolling: import("../../../../../types/common").SetState<boolean>;
|
|
9
13
|
setIsScrollIncreasing: import("../../../../../types/common").SetState<boolean>;
|
|
10
14
|
};
|