streamdown 1.1.1 → 1.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -34,7 +34,7 @@ Then, update your Tailwind `globals.css` to include the following:
34
34
  @source "../node_modules/streamdown/dist/index.js";
35
35
  ```
36
36
 
37
- This will ensure that the Streamdown styles are applied to your project.
37
+ Make sure the path matches the location of the `node_modules` folder in your project. This will ensure that the Streamdown styles are applied to your project.
38
38
 
39
39
  ## Usage
40
40
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "streamdown",
3
- "version": "1.1.1",
3
+ "version": "1.1.2",
4
4
  "type": "module",
5
5
  "main": "./dist/index.js",
6
6
  "module": "./dist/index.js",
package/dist/index.cjs DELETED
@@ -1,3 +0,0 @@
1
- "use strict";"use client";var Z=Object.create;var T=Object.defineProperty;var j=Object.getOwnPropertyDescriptor;var ee=Object.getOwnPropertyNames;var te=Object.getPrototypeOf,re=Object.prototype.hasOwnProperty;var oe=(e,t)=>{for(var r in t)T(e,r,{get:t[r],enumerable:!0})},x=(e,t,r,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of ee(t))!re.call(e,s)&&s!==r&&T(e,s,{get:()=>t[s],enumerable:!(o=j(t,s))||o.enumerable});return e};var M=(e,t,r)=>(r=e!=null?Z(te(e)):{},x(t||!e||!e.__esModule?T(r,"default",{value:e,enumerable:!0}):r,e)),ne=e=>x(T({},"__esModule",{value:!0}),e);var Ee={};oe(Ee,{CodeBlock:()=>w,CodeBlockCopyButton:()=>I,CodeBlockRenderButton:()=>K,Mermaid:()=>P,ShikiThemeContext:()=>N,Streamdown:()=>H,default:()=>De});module.exports=ne(Ee);var g=require("react"),F=M(require("react-markdown"),1),G=M(require("rehype-katex"),1),J=M(require("remark-gfm"),1),Q=M(require("remark-math"),1),Ze=require("katex/dist/katex.min.css"),L=M(require("harden-react-markdown"),1);var U=require("react");var B=require("lucide-react"),p=require("react"),E=require("shiki");var R=require("clsx"),D=require("tailwind-merge"),n=(...e)=>(0,D.twMerge)((0,R.clsx)(e));var h=require("react/jsx-runtime"),S=(0,p.createContext)({code:""});async function se(e,t,r){return await(0,E.codeToHtml)(e,{lang:t,theme:r})}var w=({code:e,language:t,className:r,children:o,...s})=>{let[a,l]=(0,p.useState)(""),c=(0,p.useContext)(N);return(0,p.useEffect)(()=>{let d=!0;return se(e,t,c).then(m=>{d&&l(m)}).catch(m=>{console.error("Failed to highlight code:",m),d&&l(`<pre><code>${e}</code></pre>`)}),()=>{d=!1}},[e,t,c]),(0,h.jsx)(S.Provider,{value:{code:e},children:(0,h.jsxs)("div",{className:"group relative",children:[(0,h.jsx)("div",{className:n("overflow-x-auto",r),dangerouslySetInnerHTML:{__html:a},...s}),o]})})},I=({onCopy:e,onError:t,timeout:r=2e3,children:o,className:s,code:a,...l})=>{let[c,d]=(0,p.useState)(!1),m=(0,p.useContext)(S).code,f=a!=null?a:m,y=async()=>{var k;if(typeof window=="undefined"||!((k=navigator==null?void 0:navigator.clipboard)!=null&&k.writeText)){t==null||t(new Error("Clipboard API not available"));return}try{await navigator.clipboard.writeText(f),d(!0),e==null||e(),setTimeout(()=>d(!1),r)}catch(v){t==null||t(v)}},b=c?B.CheckIcon:B.CopyIcon;return(0,h.jsx)("button",{className:n("absolute top-2 right-2 shrink-0 rounded-md p-3 opacity-0 transition-all","hover:bg-secondary group-hover:opacity-100",s),onClick:y,type:"button",...l,children:o!=null?o:(0,h.jsx)(b,{size:14})})},K=({onRender:e,children:t,className:r,...o})=>{let{code:s}=(0,p.useContext)(S),a=()=>{e==null||e(s)};return(0,h.jsx)("button",{className:n("absolute top-2 right-12 shrink-0 rounded-md p-3 opacity-0 transition-all hover:bg-secondary group-hover:opacity-100",r),onClick:a,type:"button",...o,children:t||(0,h.jsx)(B.RouteIcon,{size:14})})};var C=require("react");var u=require("react/jsx-runtime"),O=!1,ie=async()=>{if(!O){let r=(await import("mermaid")).default;return r.initialize({startOnLoad:!1,theme:"default",securityLevel:"strict",fontFamily:"monospace",suppressErrorRendering:!0}),O=!0,r}return(await import("mermaid")).default},P=({chart:e,className:t})=>{let[r,o]=(0,C.useState)(null),[s,a]=(0,C.useState)(!0),[l,c]=(0,C.useState)(""),[d,m]=(0,C.useState)("");if((0,C.useEffect)(()=>{(async()=>{try{o(null),a(!0);let b=await ie(),k=e.split("").reduce((_,Y)=>(_<<5)-_+Y.charCodeAt(0)|0,0),v=`mermaid-${Math.abs(k)}`,{svg:A}=await b.render(v,e);c(A),m(A)}catch(b){if(!(d||l)){let k=b instanceof Error?b.message:"Failed to render Mermaid chart";o(k)}}finally{a(!1)}})()},[e]),s&&!l&&!d)return(0,u.jsx)("div",{className:n("my-4 flex justify-center p-4",t),children:(0,u.jsxs)("div",{className:"flex items-center space-x-2 text-muted-foreground",children:[(0,u.jsx)("div",{className:"h-4 w-4 animate-spin rounded-full border-current border-b-2"}),(0,u.jsx)("span",{className:"text-sm",children:"Loading diagram..."})]})});if(r&&!l&&!d)return(0,u.jsxs)("div",{className:n("rounded-lg border border-red-200 bg-red-50 p-4",t),children:[(0,u.jsxs)("p",{className:"font-mono text-red-700 text-sm",children:["Mermaid Error: ",r]}),(0,u.jsxs)("details",{className:"mt-2",children:[(0,u.jsx)("summary",{className:"cursor-pointer text-red-600 text-xs",children:"Show Code"}),(0,u.jsx)("pre",{className:"mt-2 overflow-x-auto rounded bg-red-100 p-2 text-red-800 text-xs",children:e})]})]});let f=l||d;return(0,u.jsx)("div",{"aria-label":"Mermaid chart",className:n("my-4 flex justify-center",t),dangerouslySetInnerHTML:{__html:f},role:"img"})};var i=require("react/jsx-runtime"),ae=/language-([^\s]+)/,ce=({node:e,className:t,children:r,...o})=>{var m,f,y;if(((m=e==null?void 0:e.position)==null?void 0:m.start.line)===((f=e==null?void 0:e.position)==null?void 0:f.end.line))return(0,i.jsx)("code",{className:n("rounded bg-muted px-1.5 py-0.5 font-mono text-sm",t),...o,children:r});let a=t==null?void 0:t.match(ae),l=(y=a==null?void 0:a.at(1))!=null?y:"plaintext",c="";return(0,U.isValidElement)(r)&&r.props&&typeof r.props=="object"&&"children"in r.props&&typeof r.props.children=="string"?c=r.props.children:typeof r=="string"&&(c=r),l==="mermaid"||c.includes("graph")||c.includes("flowchart")||c.includes("sequenceDiagram")||c.includes("classDiagram")||c.includes("gantt")?(0,i.jsxs)("div",{className:n("group relative my-4 h-auto rounded-lg border p-4",t),children:[(0,i.jsx)(P,{chart:c}),(0,i.jsx)(I,{code:c})]}):(0,i.jsx)(w,{className:n("my-4 h-auto rounded-lg border p-4",t),code:c,language:l,children:(0,i.jsx)(I,{})})},q={ol:({node:e,children:t,className:r,...o})=>(0,i.jsx)("ol",{className:n("ml-4 list-outside list-decimal",r),...o,children:t}),li:({node:e,children:t,className:r,...o})=>(0,i.jsx)("li",{className:n("py-1",r),...o,children:t}),ul:({node:e,children:t,className:r,...o})=>(0,i.jsx)("ul",{className:n("ml-4 list-outside list-disc",r),...o,children:t}),hr:({node:e,className:t,...r})=>(0,i.jsx)("hr",{className:n("my-6 border-border",t),...r}),strong:({node:e,children:t,className:r,...o})=>(0,i.jsx)("span",{className:n("font-semibold",r),...o,children:t}),a:({node:e,children:t,className:r,href:o,...s})=>(0,i.jsx)("a",{className:n("font-medium text-primary underline",r),href:o,rel:"noreferrer",target:"_blank",...s,children:t}),h1:({node:e,children:t,className:r,...o})=>(0,i.jsx)("h1",{className:n("mt-6 mb-2 font-semibold text-3xl",r),...o,children:t}),h2:({node:e,children:t,className:r,...o})=>(0,i.jsx)("h2",{className:n("mt-6 mb-2 font-semibold text-2xl",r),...o,children:t}),h3:({node:e,children:t,className:r,...o})=>(0,i.jsx)("h3",{className:n("mt-6 mb-2 font-semibold text-xl",r),...o,children:t}),h4:({node:e,children:t,className:r,...o})=>(0,i.jsx)("h4",{className:n("mt-6 mb-2 font-semibold text-lg",r),...o,children:t}),h5:({node:e,children:t,className:r,...o})=>(0,i.jsx)("h5",{className:n("mt-6 mb-2 font-semibold text-base",r),...o,children:t}),h6:({node:e,children:t,className:r,...o})=>(0,i.jsx)("h6",{className:n("mt-6 mb-2 font-semibold text-sm",r),...o,children:t}),table:({node:e,children:t,className:r,...o})=>(0,i.jsx)("div",{className:"my-4 overflow-x-auto",children:(0,i.jsx)("table",{className:n("w-full border-collapse border border-border",r),...o,children:t})}),thead:({node:e,children:t,className:r,...o})=>(0,i.jsx)("thead",{className:n("bg-muted/50",r),...o,children:t}),tbody:({node:e,children:t,className:r,...o})=>(0,i.jsx)("tbody",{className:n("divide-y divide-border",r),...o,children:t}),tr:({node:e,children:t,className:r,...o})=>(0,i.jsx)("tr",{className:n("border-border border-b",r),...o,children:t}),th:({node:e,children:t,className:r,...o})=>(0,i.jsx)("th",{className:n("px-4 py-2 text-left font-semibold text-sm",r),...o,children:t}),td:({node:e,children:t,className:r,...o})=>(0,i.jsx)("td",{className:n("px-4 py-2 text-sm",r),...o,children:t}),blockquote:({node:e,children:t,className:r,...o})=>(0,i.jsx)("blockquote",{className:n("my-4 border-muted-foreground/30 border-l-4 pl-4 text-muted-foreground italic",r),...o,children:t}),code:ce,pre:({children:e})=>e,sup:({node:e,children:t,className:r,...o})=>(0,i.jsx)("sup",{className:n("text-sm",r),...o,children:t}),sub:({node:e,children:t,className:r,...o})=>(0,i.jsx)("sub",{className:n("text-sm",r),...o,children:t})};var z=require("marked"),V=e=>z.marked.lexer(e).map(r=>r.raw);var le=/(!?\[)([^\]]*?)$/,de=/(\*\*)([^*]*?)$/,me=/(__)([^_]*?)$/,ue=/(\*\*\*)([^*]*?)$/,pe=/(\*)([^*]*?)$/,ge=/(_)([^_]*?)$/,he=/(`)([^`]*?)$/,fe=/(~~)([^~]*?)$/,be=/(\$)([^$]*?)$/,ke=/(\$\$)([^$]*?)$/,ye=e=>{let t=e.match(le);if(t){let r=e.lastIndexOf(t[1]);return e.substring(0,r)}return e},Me=e=>e.match(de)&&(e.match(/\*\*/g)||[]).length%2===1?`${e}**`:e,Ce=e=>e.match(me)&&(e.match(/__/g)||[]).length%2===1?`${e}__`:e,Be=e=>e.split("").reduce((t,r,o)=>{if(r==="*"){let s=e[o-1],a=e[o+1];if(s==="\\")return t;if(s!=="*"&&a!=="*")return t+1}return t},0),ve=e=>e.match(pe)&&Be(e)%2===1?`${e}*`:e,Ie=e=>e.split("").reduce((t,r,o)=>{if(r==="_"){let s=e[o-1],a=e[o+1];if(s==="\\")return t;if(s!=="_"&&a!=="_")return t+1}return t},0),$e=e=>e.match(ge)&&Ie(e)%2===1?`${e}_`:e,Te=(e,t)=>{let r=e.substring(t,t+3)==="```",o=t>0&&e.substring(t-1,t+2)==="```",s=t>1&&e.substring(t-2,t+1)==="```";return r||o||s},we=e=>{let t=0;for(let r=0;r<e.length;r++)e[r]==="`"&&!Te(e,r)&&t++;return t},Ne=e=>{if(e.match(/^```[^`\n]*```?$/)&&!e.includes(`
2
- `))return e.endsWith("``")&&!e.endsWith("```")?`${e}\``:e;let r=(e.match(/```/g)||[]).length,o=r%2===1;return(e.endsWith("```\n")||e.endsWith("```"))&&r%2===0||r>0&&r%2===0&&e.includes(`
3
- `)?e:e.match(he)&&!o&&we(e)%2===1?`${e}\``:e},Pe=e=>e.match(fe)&&(e.match(/~~/g)||[]).length%2===1?`${e}~~`:e,Se=e=>e.split("").reduce((t,r,o)=>{if(r==="$"){let s=e[o-1],a=e[o+1];if(s==="\\")return t;if(s!=="$"&&a!=="$")return t+1}return t},0),Le=e=>e.match(ke)&&(e.match(/\$\$/g)||[]).length%2===1?`${e}$$`:e,He=e=>e.match(be)&&Se(e)%2===1?`${e}$`:e,Ae=e=>{let t=0,r=e.match(/\*+/g)||[];for(let o of r){let s=o.length;s>=3&&(t+=Math.floor(s/3))}return t},_e=e=>/^\*{4,}$/.test(e)?e:e.match(ue)&&Ae(e)%2===1?`${e}***`:e,W=e=>{if(!e||typeof e!="string")return e;let t=e;return t=ye(t),t=_e(t),t=Me(t),t=Ce(t),t=ve(t),t=$e(t),t=Ne(t),t=Pe(t),t=Le(t),t=He(t),t};var $=require("react/jsx-runtime"),xe=L.default.default||L.default,Re=xe(F.default),N=(0,g.createContext)("github-light"),X=(0,g.memo)(({content:e,shouldParseIncompleteMarkdown:t,...r})=>{let o=(0,g.useMemo)(()=>typeof e=="string"&&t?W(e.trim()):e,[e,t]);return(0,$.jsx)(Re,{...r,children:o})},(e,t)=>e.content===t.content);X.displayName="Block";var H=(0,g.memo)(({children:e,allowedImagePrefixes:t,allowedLinkPrefixes:r,defaultOrigin:o,parseIncompleteMarkdown:s=!0,components:a,rehypePlugins:l,remarkPlugins:c,className:d,shikiTheme:m="github-light",...f})=>{let y=(0,g.useId)(),b=(0,g.useMemo)(()=>V(typeof e=="string"?e:""),[e]);return(0,$.jsx)(N.Provider,{value:m,children:(0,$.jsx)("div",{className:n("space-y-4",d),...f,children:b.map((k,v)=>(0,$.jsx)(X,{allowedImagePrefixes:t!=null?t:["*"],allowedLinkPrefixes:r!=null?r:["*"],components:{...q,...a},content:k,defaultOrigin:o,rehypePlugins:[G.default,...l!=null?l:[]],remarkPlugins:[J.default,Q.default,...c!=null?c:[]],shouldParseIncompleteMarkdown:s},`${y}-block_${v}`))})})},(e,t)=>e.children===t.children&&e.shikiTheme===t.shikiTheme);H.displayName="Streamdown";var De=H;0&&(module.exports={CodeBlock,CodeBlockCopyButton,CodeBlockRenderButton,Mermaid,ShikiThemeContext,Streamdown});
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../index.tsx","../lib/components.tsx","../lib/code-block.tsx","../lib/utils.ts","../lib/parse-blocks.tsx","../lib/parse-incomplete-markdown.ts"],"sourcesContent":["'use client';\n\nimport type { ComponentProps } from 'react';\nimport { memo, useId, useMemo } from 'react';\nimport ReactMarkdown from 'react-markdown';\nimport rehypeKatex from 'rehype-katex';\nimport remarkGfm from 'remark-gfm';\nimport remarkMath from 'remark-math';\nimport 'katex/dist/katex.min.css';\nimport hardenReactMarkdownImport from 'harden-react-markdown';\nimport { components as defaultComponents } from './lib/components';\nimport { parseMarkdownIntoBlocks } from './lib/parse-blocks';\nimport { parseIncompleteMarkdown } from './lib/parse-incomplete-markdown';\nimport { cn } from './lib/utils';\n\n// Handle both ESM and CJS imports\nconst hardenReactMarkdown = (hardenReactMarkdownImport as any).default || hardenReactMarkdownImport;\n\n// Create a hardened version of ReactMarkdown\nconst HardenedMarkdown: ReturnType<typeof hardenReactMarkdown> =\n hardenReactMarkdown(ReactMarkdown);\n\nexport type StreamdownProps = ComponentProps<typeof HardenedMarkdown> & {\n parseIncompleteMarkdown?: boolean;\n className?: string;\n};\n\ntype BlockProps = ComponentProps<typeof HardenedMarkdown> & {\n content: string;\n shouldParseIncompleteMarkdown: boolean;\n};\n\nconst Block = memo(\n ({ content, shouldParseIncompleteMarkdown, ...props }: BlockProps) => {\n const parsedContent = useMemo(\n () =>\n typeof content === 'string' && shouldParseIncompleteMarkdown\n ? parseIncompleteMarkdown(content.trim())\n : content,\n [content, shouldParseIncompleteMarkdown]\n );\n\n return <HardenedMarkdown {...props}>{parsedContent}</HardenedMarkdown>;\n },\n (prevProps, nextProps) => prevProps.content === nextProps.content\n);\n\nexport const Streamdown = memo(\n ({\n children,\n allowedImagePrefixes,\n allowedLinkPrefixes,\n defaultOrigin,\n parseIncompleteMarkdown: shouldParseIncompleteMarkdown = true,\n components,\n rehypePlugins,\n remarkPlugins,\n className,\n ...props\n }: StreamdownProps) => {\n // Parse the children to remove incomplete markdown tokens if enabled\n const generatedId = useId();\n const blocks = useMemo(\n () =>\n parseMarkdownIntoBlocks(typeof children === 'string' ? children : ''),\n [children]\n );\n\n return (\n <div className={cn('space-y-4', className)} {...props}>\n {blocks.map((block, index) => (\n <Block\n allowedImagePrefixes={allowedImagePrefixes ?? ['*']}\n allowedLinkPrefixes={allowedLinkPrefixes ?? ['*']}\n components={{\n ...defaultComponents,\n ...components,\n }}\n content={block}\n defaultOrigin={defaultOrigin}\n // biome-ignore lint/suspicious/noArrayIndexKey: \"required\"\n key={`${generatedId}-block_${index}`}\n rehypePlugins={[rehypeKatex, ...(rehypePlugins ?? [])]}\n remarkPlugins={[remarkGfm, remarkMath, ...(remarkPlugins ?? [])]}\n shouldParseIncompleteMarkdown={shouldParseIncompleteMarkdown}\n />\n ))}\n </div>\n );\n },\n (prevProps, nextProps) => prevProps.children === nextProps.children\n);\nStreamdown.displayName = 'Streamdown';\n\nexport default Streamdown;\n","import { isValidElement } from 'react';\nimport type { Options } from 'react-markdown';\nimport type { BundledLanguage } from 'shiki';\nimport { CodeBlock, CodeBlockCopyButton } from './code-block';\nimport { cn } from './utils';\n\nexport const components: Options['components'] = {\n ol: ({ node, children, className, ...props }) => (\n <ol className={cn('ml-4 list-outside list-decimal', className)} {...props}>\n {children}\n </ol>\n ),\n li: ({ node, children, className, ...props }) => (\n <li className={cn('py-1', className)} {...props}>\n {children}\n </li>\n ),\n ul: ({ node, children, className, ...props }) => (\n <ul className={cn('ml-4 list-outside list-disc', className)} {...props}>\n {children}\n </ul>\n ),\n hr: ({ node, className, ...props }) => (\n <hr className={cn('my-6 border-border', className)} {...props} />\n ),\n strong: ({ node, children, className, ...props }) => (\n <span className={cn('font-semibold', className)} {...props}>\n {children}\n </span>\n ),\n a: ({ node, children, className, href, ...props }) => (\n <a\n className={cn('font-medium text-primary underline', className)}\n href={href}\n rel=\"noreferrer\"\n target=\"_blank\"\n {...props}\n >\n {children}\n </a>\n ),\n h1: ({ node, children, className, ...props }) => (\n <h1\n className={cn('mt-6 mb-2 font-semibold text-3xl', className)}\n {...props}\n >\n {children}\n </h1>\n ),\n h2: ({ node, children, className, ...props }) => (\n <h2\n className={cn('mt-6 mb-2 font-semibold text-2xl', className)}\n {...props}\n >\n {children}\n </h2>\n ),\n h3: ({ node, children, className, ...props }) => (\n <h3 className={cn('mt-6 mb-2 font-semibold text-xl', className)} {...props}>\n {children}\n </h3>\n ),\n h4: ({ node, children, className, ...props }) => (\n <h4 className={cn('mt-6 mb-2 font-semibold text-lg', className)} {...props}>\n {children}\n </h4>\n ),\n h5: ({ node, children, className, ...props }) => (\n <h5\n className={cn('mt-6 mb-2 font-semibold text-base', className)}\n {...props}\n >\n {children}\n </h5>\n ),\n h6: ({ node, children, className, ...props }) => (\n <h6 className={cn('mt-6 mb-2 font-semibold text-sm', className)} {...props}>\n {children}\n </h6>\n ),\n table: ({ node, children, className, ...props }) => (\n <div className=\"my-4 overflow-x-auto\">\n <table\n className={cn('w-full border-collapse border border-border', className)}\n {...props}\n >\n {children}\n </table>\n </div>\n ),\n thead: ({ node, children, className, ...props }) => (\n <thead className={cn('bg-muted/50', className)} {...props}>\n {children}\n </thead>\n ),\n tbody: ({ node, children, className, ...props }) => (\n <tbody className={cn('divide-y divide-border', className)} {...props}>\n {children}\n </tbody>\n ),\n tr: ({ node, children, className, ...props }) => (\n <tr className={cn('border-border border-b', className)} {...props}>\n {children}\n </tr>\n ),\n th: ({ node, children, className, ...props }) => (\n <th\n className={cn('px-4 py-2 text-left font-semibold text-sm', className)}\n {...props}\n >\n {children}\n </th>\n ),\n td: ({ node, children, className, ...props }) => (\n <td className={cn('px-4 py-2 text-sm', className)} {...props}>\n {children}\n </td>\n ),\n blockquote: ({ node, children, className, ...props }) => (\n <blockquote\n className={cn(\n 'my-4 border-muted-foreground/30 border-l-4 pl-4 text-muted-foreground italic',\n className\n )}\n {...props}\n >\n {children}\n </blockquote>\n ),\n code: ({ node, className, ...props }) => {\n const inline = node?.position?.start.line === node?.position?.end.line;\n\n if (!inline) {\n return <code className={className} {...props} />;\n }\n\n return (\n <code\n className={cn(\n 'rounded bg-muted px-1.5 py-0.5 font-mono text-sm',\n className\n )}\n {...props}\n />\n );\n },\n pre: ({ node, className, children }) => {\n let language: BundledLanguage = 'javascript';\n\n if (typeof node?.properties?.className === 'string') {\n language = node.properties.className.replace(\n 'language-',\n ''\n ) as BundledLanguage;\n }\n\n // Extract code content from children safely\n let code = '';\n if (\n isValidElement(children) &&\n children.props &&\n typeof children.props === 'object' &&\n 'children' in children.props &&\n typeof children.props.children === 'string'\n ) {\n code = children.props.children;\n } else if (typeof children === 'string') {\n code = children;\n }\n\n return (\n <CodeBlock\n className={cn('my-4 h-auto rounded-lg border p-4', className)}\n code={code}\n language={language}\n >\n <CodeBlockCopyButton />\n </CodeBlock>\n );\n },\n sup: ({ node, children, className, ...props }) => (\n <sup className={cn('text-sm', className)} {...props}>\n {children}\n </sup>\n ),\n sub: ({ node, children, className, ...props }) => (\n <sub className={cn('text-sm', className)} {...props}>\n {children}\n </sub>\n ),\n};\n","'use client';\n\nimport { CheckIcon, CopyIcon } from 'lucide-react';\nimport {\n type ComponentProps,\n createContext,\n type HTMLAttributes,\n useContext,\n useEffect,\n useState,\n} from 'react';\nimport { type BundledLanguage, codeToHtml } from 'shiki';\nimport { cn } from './utils';\n\ntype CodeBlockProps = HTMLAttributes<HTMLDivElement> & {\n code: string;\n language: BundledLanguage;\n};\n\ntype CodeBlockContextType = {\n code: string;\n};\n\nconst CodeBlockContext = createContext<CodeBlockContextType>({\n code: '',\n});\n\nexport async function highlightCode(code: string, language: BundledLanguage) {\n return await codeToHtml(code, {\n lang: language,\n theme: 'github-light',\n });\n}\n\nexport const CodeBlock = ({\n code,\n language,\n className,\n children,\n ...props\n}: CodeBlockProps) => {\n const [html, setHtml] = useState<string>('');\n\n useEffect(() => {\n let isMounted = true;\n\n highlightCode(code, language).then((result) => {\n if (isMounted) {\n setHtml(result);\n }\n });\n\n return () => {\n isMounted = false;\n };\n }, [code, language]);\n\n return (\n <CodeBlockContext.Provider value={{ code }}>\n <div className=\"group relative\">\n <div\n className={cn('overflow-x-auto', className)}\n // biome-ignore lint/security/noDangerouslySetInnerHtml: \"this is needed.\"\n dangerouslySetInnerHTML={{ __html: html }}\n {...props}\n />\n {children}\n </div>\n </CodeBlockContext.Provider>\n );\n};\n\nexport type CodeBlockCopyButtonProps = ComponentProps<'button'> & {\n onCopy?: () => void;\n onError?: (error: Error) => void;\n timeout?: number;\n};\n\nexport const CodeBlockCopyButton = ({\n onCopy,\n onError,\n timeout = 2000,\n children,\n className,\n ...props\n}: CodeBlockCopyButtonProps) => {\n const [isCopied, setIsCopied] = useState(false);\n const { code } = useContext(CodeBlockContext);\n\n const copyToClipboard = async () => {\n if (typeof window === 'undefined' || !navigator?.clipboard?.writeText) {\n onError?.(new Error('Clipboard API not available'));\n return;\n }\n\n try {\n await navigator.clipboard.writeText(code);\n setIsCopied(true);\n onCopy?.();\n setTimeout(() => setIsCopied(false), timeout);\n } catch (error) {\n onError?.(error as Error);\n }\n };\n\n const Icon = isCopied ? CheckIcon : CopyIcon;\n\n return (\n <button\n className={cn(\n 'absolute top-2 right-2 shrink-0 rounded-md p-3 opacity-0 transition-all',\n 'hover:bg-secondary group-hover:opacity-100',\n className\n )}\n onClick={copyToClipboard}\n type=\"button\"\n {...props}\n >\n {children ?? <Icon size={14} />}\n </button>\n );\n};\n","import { type ClassValue, clsx } from 'clsx';\nimport { twMerge } from 'tailwind-merge';\n\nexport const cn = (...inputs: ClassValue[]) => twMerge(clsx(inputs));\n","import { marked } from 'marked';\n\nexport const parseMarkdownIntoBlocks = (markdown: string): string[] => {\n const tokens = marked.lexer(markdown);\n return tokens.map((token) => token.raw);\n};\n","const linkImagePattern = /(!?\\[)([^\\]]*?)$/;\nconst boldPattern = /(\\*\\*)([^*]*?)$/;\nconst italicPattern = /(__)([^_]*?)$/;\nconst singleAsteriskPattern = /(\\*)([^*]*?)$/;\nconst singleUnderscorePattern = /(_)([^_]*?)$/;\nconst inlineCodePattern = /(`)([^`]*?)$/;\nconst strikethroughPattern = /(~~)([^~]*?)$/;\nconst inlineKatexPattern = /(\\$)([^$]*?)$/;\nconst blockKatexPattern = /(\\$\\$)([^$]*?)$/;\n\n// Handles incomplete links and images by removing them if not closed\nconst handleIncompleteLinksAndImages = (text: string): string => {\n const linkMatch = text.match(linkImagePattern);\n\n if (linkMatch) {\n const startIndex = text.lastIndexOf(linkMatch[1]);\n return text.substring(0, startIndex);\n }\n\n return text;\n};\n\n// Completes incomplete bold formatting (**)\nconst handleIncompleteBold = (text: string): string => {\n const boldMatch = text.match(boldPattern);\n\n if (boldMatch) {\n const asteriskPairs = (text.match(/\\*\\*/g) || []).length;\n if (asteriskPairs % 2 === 1) {\n return `${text}**`;\n }\n }\n\n return text;\n};\n\n// Completes incomplete italic formatting with double underscores (__)\nconst handleIncompleteDoubleUnderscoreItalic = (text: string): string => {\n const italicMatch = text.match(italicPattern);\n\n if (italicMatch) {\n const underscorePairs = (text.match(/__/g) || []).length;\n if (underscorePairs % 2 === 1) {\n return `${text}__`;\n }\n }\n\n return text;\n};\n\n// Counts single asterisks that are not part of double asterisks and not escaped\nconst countSingleAsterisks = (text: string): number => {\n return text.split('').reduce((acc, char, index) => {\n if (char === '*') {\n const prevChar = text[index - 1];\n const nextChar = text[index + 1];\n // Skip if escaped with backslash\n if (prevChar === '\\\\') {\n return acc;\n }\n if (prevChar !== '*' && nextChar !== '*') {\n return acc + 1;\n }\n }\n return acc;\n }, 0);\n};\n\n// Completes incomplete italic formatting with single asterisks (*)\nconst handleIncompleteSingleAsteriskItalic = (text: string): string => {\n const singleAsteriskMatch = text.match(singleAsteriskPattern);\n\n if (singleAsteriskMatch) {\n const singleAsterisks = countSingleAsterisks(text);\n if (singleAsterisks % 2 === 1) {\n return `${text}*`;\n }\n }\n\n return text;\n};\n\n// Counts single underscores that are not part of double underscores and not escaped\nconst countSingleUnderscores = (text: string): number => {\n return text.split('').reduce((acc, char, index) => {\n if (char === '_') {\n const prevChar = text[index - 1];\n const nextChar = text[index + 1];\n // Skip if escaped with backslash\n if (prevChar === '\\\\') {\n return acc;\n }\n if (prevChar !== '_' && nextChar !== '_') {\n return acc + 1;\n }\n }\n return acc;\n }, 0);\n};\n\n// Completes incomplete italic formatting with single underscores (_)\nconst handleIncompleteSingleUnderscoreItalic = (text: string): string => {\n const singleUnderscoreMatch = text.match(singleUnderscorePattern);\n\n if (singleUnderscoreMatch) {\n const singleUnderscores = countSingleUnderscores(text);\n if (singleUnderscores % 2 === 1) {\n return `${text}_`;\n }\n }\n\n return text;\n};\n\n// Checks if a backtick at position i is part of a triple backtick sequence\nconst isPartOfTripleBacktick = (text: string, i: number): boolean => {\n const isTripleStart = text.substring(i, i + 3) === '```';\n const isTripleMiddle = i > 0 && text.substring(i - 1, i + 2) === '```';\n const isTripleEnd = i > 1 && text.substring(i - 2, i + 1) === '```';\n\n return isTripleStart || isTripleMiddle || isTripleEnd;\n};\n\n// Counts single backticks that are not part of triple backticks\nconst countSingleBackticks = (text: string): number => {\n let count = 0;\n for (let i = 0; i < text.length; i++) {\n if (text[i] === '`' && !isPartOfTripleBacktick(text, i)) {\n count++;\n }\n }\n return count;\n};\n\n// Completes incomplete inline code formatting (`)\n// Avoids completing if inside an incomplete code block\nconst handleIncompleteInlineCode = (text: string): string => {\n // Check if we're inside a code block (complete or incomplete)\n const allTripleBackticks = (text.match(/```/g) || []).length;\n const insideIncompleteCodeBlock = allTripleBackticks % 2 === 1;\n \n // Don't modify text if we have complete code blocks (even pairs of ```)\n if (allTripleBackticks > 0 && allTripleBackticks % 2 === 0) {\n // We have complete code blocks, don't add any backticks\n return text;\n }\n\n const inlineCodeMatch = text.match(inlineCodePattern);\n\n if (inlineCodeMatch && !insideIncompleteCodeBlock) {\n const singleBacktickCount = countSingleBackticks(text);\n if (singleBacktickCount % 2 === 1) {\n return `${text}\\``;\n }\n }\n\n return text;\n};\n\n// Completes incomplete strikethrough formatting (~~)\nconst handleIncompleteStrikethrough = (text: string): string => {\n const strikethroughMatch = text.match(strikethroughPattern);\n\n if (strikethroughMatch) {\n const tildePairs = (text.match(/~~/g) || []).length;\n if (tildePairs % 2 === 1) {\n return `${text}~~`;\n }\n }\n\n return text;\n};\n\n// Counts single dollar signs that are not part of double dollar signs and not escaped\nconst countSingleDollarSigns = (text: string): number => {\n return text.split('').reduce((acc, char, index) => {\n if (char === '$') {\n const prevChar = text[index - 1];\n const nextChar = text[index + 1];\n // Skip if escaped with backslash\n if (prevChar === '\\\\') {\n return acc;\n }\n if (prevChar !== '$' && nextChar !== '$') {\n return acc + 1;\n }\n }\n return acc;\n }, 0);\n};\n\n// Completes incomplete block KaTeX formatting ($$)\nconst handleIncompleteBlockKatex = (text: string): string => {\n const blockKatexMatch = text.match(blockKatexPattern);\n\n if (blockKatexMatch) {\n const dollarPairs = (text.match(/\\$\\$/g) || []).length;\n if (dollarPairs % 2 === 1) {\n return `${text}$$`;\n }\n }\n\n return text;\n};\n\n// Completes incomplete inline KaTeX formatting ($)\nconst handleIncompleteInlineKatex = (text: string): string => {\n const inlineKatexMatch = text.match(inlineKatexPattern);\n\n if (inlineKatexMatch) {\n const singleDollars = countSingleDollarSigns(text);\n if (singleDollars % 2 === 1) {\n return `${text}$`;\n }\n }\n\n return text;\n};\n\n// Parses markdown text and removes incomplete tokens to prevent partial rendering\nexport const parseIncompleteMarkdown = (text: string): string => {\n if (!text || typeof text !== 'string') {\n return text;\n }\n\n let result = text;\n\n // Handle incomplete links and images first (removes content)\n result = handleIncompleteLinksAndImages(result);\n\n // Handle various formatting completions\n result = handleIncompleteBold(result);\n result = handleIncompleteDoubleUnderscoreItalic(result);\n result = handleIncompleteSingleAsteriskItalic(result);\n result = handleIncompleteSingleUnderscoreItalic(result);\n result = handleIncompleteInlineCode(result);\n result = handleIncompleteStrikethrough(result);\n \n // Handle KaTeX formatting (block first, then inline)\n result = handleIncompleteBlockKatex(result);\n result = handleIncompleteInlineKatex(result);\n\n return result;\n};\n"],"mappings":"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","names":["import_react","import_react","import_jsx_runtime","import_jsx_runtime","hardenReactMarkdownImport","ReactMarkdown","components","rehypeKatex","remarkGfm","remarkMath"]}
package/dist/index.d.cts DELETED
@@ -1,44 +0,0 @@
1
- import * as react_jsx_runtime from 'react/jsx-runtime';
2
- import * as react from 'react';
3
- import { HTMLAttributes, ComponentProps } from 'react';
4
- import { Options } from 'react-markdown';
5
- import { BundledLanguage, BundledTheme } from 'shiki';
6
-
7
- type MermaidProps = {
8
- chart: string;
9
- className?: string;
10
- };
11
- declare const Mermaid: ({ chart, className }: MermaidProps) => react_jsx_runtime.JSX.Element;
12
-
13
- type CodeBlockProps = HTMLAttributes<HTMLDivElement> & {
14
- code: string;
15
- language: BundledLanguage;
16
- };
17
- declare const CodeBlock: ({ code, language, className, children, ...props }: CodeBlockProps) => react_jsx_runtime.JSX.Element;
18
- type CodeBlockCopyButtonProps = ComponentProps<'button'> & {
19
- onCopy?: () => void;
20
- onError?: (error: Error) => void;
21
- timeout?: number;
22
- };
23
- declare const CodeBlockCopyButton: ({ onCopy, onError, timeout, children, className, code: propCode, ...props }: CodeBlockCopyButtonProps & {
24
- code?: string;
25
- }) => react_jsx_runtime.JSX.Element;
26
- type CodeBlockRenderButtonProps = ComponentProps<'button'> & {
27
- onRender?: (code: string) => void;
28
- };
29
- declare const CodeBlockRenderButton: ({ onRender, children, className, ...props }: CodeBlockRenderButtonProps) => react_jsx_runtime.JSX.Element;
30
-
31
- type HardenReactMarkdownProps = Options & {
32
- defaultOrigin?: string;
33
- allowedLinkPrefixes?: string[];
34
- allowedImagePrefixes?: string[];
35
- };
36
- type StreamdownProps = HardenReactMarkdownProps & {
37
- parseIncompleteMarkdown?: boolean;
38
- className?: string;
39
- shikiTheme?: BundledTheme;
40
- };
41
- declare const ShikiThemeContext: react.Context<BundledTheme>;
42
- declare const Streamdown: react.MemoExoticComponent<({ children, allowedImagePrefixes, allowedLinkPrefixes, defaultOrigin, parseIncompleteMarkdown: shouldParseIncompleteMarkdown, components, rehypePlugins, remarkPlugins, className, shikiTheme, ...props }: StreamdownProps) => react_jsx_runtime.JSX.Element>;
43
-
44
- export { CodeBlock, CodeBlockCopyButton, CodeBlockRenderButton, Mermaid, ShikiThemeContext, Streamdown, type StreamdownProps, Streamdown as default };
package/dist/index.d.ts DELETED
@@ -1,44 +0,0 @@
1
- import * as react_jsx_runtime from 'react/jsx-runtime';
2
- import * as react from 'react';
3
- import { HTMLAttributes, ComponentProps } from 'react';
4
- import { Options } from 'react-markdown';
5
- import { BundledLanguage, BundledTheme } from 'shiki';
6
-
7
- type MermaidProps = {
8
- chart: string;
9
- className?: string;
10
- };
11
- declare const Mermaid: ({ chart, className }: MermaidProps) => react_jsx_runtime.JSX.Element;
12
-
13
- type CodeBlockProps = HTMLAttributes<HTMLDivElement> & {
14
- code: string;
15
- language: BundledLanguage;
16
- };
17
- declare const CodeBlock: ({ code, language, className, children, ...props }: CodeBlockProps) => react_jsx_runtime.JSX.Element;
18
- type CodeBlockCopyButtonProps = ComponentProps<'button'> & {
19
- onCopy?: () => void;
20
- onError?: (error: Error) => void;
21
- timeout?: number;
22
- };
23
- declare const CodeBlockCopyButton: ({ onCopy, onError, timeout, children, className, code: propCode, ...props }: CodeBlockCopyButtonProps & {
24
- code?: string;
25
- }) => react_jsx_runtime.JSX.Element;
26
- type CodeBlockRenderButtonProps = ComponentProps<'button'> & {
27
- onRender?: (code: string) => void;
28
- };
29
- declare const CodeBlockRenderButton: ({ onRender, children, className, ...props }: CodeBlockRenderButtonProps) => react_jsx_runtime.JSX.Element;
30
-
31
- type HardenReactMarkdownProps = Options & {
32
- defaultOrigin?: string;
33
- allowedLinkPrefixes?: string[];
34
- allowedImagePrefixes?: string[];
35
- };
36
- type StreamdownProps = HardenReactMarkdownProps & {
37
- parseIncompleteMarkdown?: boolean;
38
- className?: string;
39
- shikiTheme?: BundledTheme;
40
- };
41
- declare const ShikiThemeContext: react.Context<BundledTheme>;
42
- declare const Streamdown: react.MemoExoticComponent<({ children, allowedImagePrefixes, allowedLinkPrefixes, defaultOrigin, parseIncompleteMarkdown: shouldParseIncompleteMarkdown, components, rehypePlugins, remarkPlugins, className, shikiTheme, ...props }: StreamdownProps) => react_jsx_runtime.JSX.Element>;
43
-
44
- export { CodeBlock, CodeBlockCopyButton, CodeBlockRenderButton, Mermaid, ShikiThemeContext, Streamdown, type StreamdownProps, Streamdown as default };
package/dist/index.js DELETED
@@ -1,3 +0,0 @@
1
- "use client";import{createContext as Le,memo as R,useId as He,useMemo as D}from"react";import Ae from"react-markdown";import _e from"rehype-katex";import xe from"remark-gfm";import Re from"remark-math";import"katex/dist/katex.min.css";import x from"harden-react-markdown";import{isValidElement as ee}from"react";import{CheckIcon as z,CopyIcon as V,RouteIcon as W}from"lucide-react";import{createContext as F,useContext as v,useEffect as G,useState as S}from"react";import{codeToHtml as J}from"shiki";import{clsx as U}from"clsx";import{twMerge as q}from"tailwind-merge";var n=(...e)=>q(U(e));import{jsx as f,jsxs as Y}from"react/jsx-runtime";var I=F({code:""});async function Q(e,t,r){return await J(e,{lang:t,theme:r})}var $=({code:e,language:t,className:r,children:o,...s})=>{let[a,l]=S(""),c=v(T);return G(()=>{let d=!0;return Q(e,t,c).then(m=>{d&&l(m)}).catch(m=>{console.error("Failed to highlight code:",m),d&&l(`<pre><code>${e}</code></pre>`)}),()=>{d=!1}},[e,t,c]),f(I.Provider,{value:{code:e},children:Y("div",{className:"group relative",children:[f("div",{className:n("overflow-x-auto",r),dangerouslySetInnerHTML:{__html:a},...s}),o]})})},y=({onCopy:e,onError:t,timeout:r=2e3,children:o,className:s,code:a,...l})=>{let[c,d]=S(!1),m=v(I).code,u=a!=null?a:m,h=async()=>{var g;if(typeof window=="undefined"||!((g=navigator==null?void 0:navigator.clipboard)!=null&&g.writeText)){t==null||t(new Error("Clipboard API not available"));return}try{await navigator.clipboard.writeText(u),d(!0),e==null||e(),setTimeout(()=>d(!1),r)}catch(k){t==null||t(k)}},p=c?z:V;return f("button",{className:n("absolute top-2 right-2 shrink-0 rounded-md p-3 opacity-0 transition-all","hover:bg-secondary group-hover:opacity-100",s),onClick:h,type:"button",...l,children:o!=null?o:f(p,{size:14})})},X=({onRender:e,children:t,className:r,...o})=>{let{code:s}=v(I),a=()=>{e==null||e(s)};return f("button",{className:n("absolute top-2 right-12 shrink-0 rounded-md p-3 opacity-0 transition-all hover:bg-secondary group-hover:opacity-100",r),onClick:a,type:"button",...o,children:t||f(W,{size:14})})};import{useEffect as Z,useState as M}from"react";import{jsx as b,jsxs as C}from"react/jsx-runtime";var L=!1,j=async()=>{if(!L){let r=(await import("mermaid")).default;return r.initialize({startOnLoad:!1,theme:"default",securityLevel:"strict",fontFamily:"monospace",suppressErrorRendering:!0}),L=!0,r}return(await import("mermaid")).default},w=({chart:e,className:t})=>{let[r,o]=M(null),[s,a]=M(!0),[l,c]=M(""),[d,m]=M("");if(Z(()=>{(async()=>{try{o(null),a(!0);let p=await j(),g=e.split("").reduce((P,O)=>(P<<5)-P+O.charCodeAt(0)|0,0),k=`mermaid-${Math.abs(g)}`,{svg:N}=await p.render(k,e);c(N),m(N)}catch(p){if(!(d||l)){let g=p instanceof Error?p.message:"Failed to render Mermaid chart";o(g)}}finally{a(!1)}})()},[e]),s&&!l&&!d)return b("div",{className:n("my-4 flex justify-center p-4",t),children:C("div",{className:"flex items-center space-x-2 text-muted-foreground",children:[b("div",{className:"h-4 w-4 animate-spin rounded-full border-current border-b-2"}),b("span",{className:"text-sm",children:"Loading diagram..."})]})});if(r&&!l&&!d)return C("div",{className:n("rounded-lg border border-red-200 bg-red-50 p-4",t),children:[C("p",{className:"font-mono text-red-700 text-sm",children:["Mermaid Error: ",r]}),C("details",{className:"mt-2",children:[b("summary",{className:"cursor-pointer text-red-600 text-xs",children:"Show Code"}),b("pre",{className:"mt-2 overflow-x-auto rounded bg-red-100 p-2 text-red-800 text-xs",children:e})]})]});let u=l||d;return b("div",{"aria-label":"Mermaid chart",className:n("my-4 flex justify-center",t),dangerouslySetInnerHTML:{__html:u},role:"img"})};import{jsx as i,jsxs as oe}from"react/jsx-runtime";var te=/language-([^\s]+)/,re=({node:e,className:t,children:r,...o})=>{var m,u,h;if(((m=e==null?void 0:e.position)==null?void 0:m.start.line)===((u=e==null?void 0:e.position)==null?void 0:u.end.line))return i("code",{className:n("rounded bg-muted px-1.5 py-0.5 font-mono text-sm",t),...o,children:r});let a=t==null?void 0:t.match(te),l=(h=a==null?void 0:a.at(1))!=null?h:"plaintext",c="";return ee(r)&&r.props&&typeof r.props=="object"&&"children"in r.props&&typeof r.props.children=="string"?c=r.props.children:typeof r=="string"&&(c=r),l==="mermaid"||c.includes("graph")||c.includes("flowchart")||c.includes("sequenceDiagram")||c.includes("classDiagram")||c.includes("gantt")?oe("div",{className:n("group relative my-4 h-auto rounded-lg border p-4",t),children:[i(w,{chart:c}),i(y,{code:c})]}):i($,{className:n("my-4 h-auto rounded-lg border p-4",t),code:c,language:l,children:i(y,{})})},H={ol:({node:e,children:t,className:r,...o})=>i("ol",{className:n("ml-4 list-outside list-decimal",r),...o,children:t}),li:({node:e,children:t,className:r,...o})=>i("li",{className:n("py-1",r),...o,children:t}),ul:({node:e,children:t,className:r,...o})=>i("ul",{className:n("ml-4 list-outside list-disc",r),...o,children:t}),hr:({node:e,className:t,...r})=>i("hr",{className:n("my-6 border-border",t),...r}),strong:({node:e,children:t,className:r,...o})=>i("span",{className:n("font-semibold",r),...o,children:t}),a:({node:e,children:t,className:r,href:o,...s})=>i("a",{className:n("font-medium text-primary underline",r),href:o,rel:"noreferrer",target:"_blank",...s,children:t}),h1:({node:e,children:t,className:r,...o})=>i("h1",{className:n("mt-6 mb-2 font-semibold text-3xl",r),...o,children:t}),h2:({node:e,children:t,className:r,...o})=>i("h2",{className:n("mt-6 mb-2 font-semibold text-2xl",r),...o,children:t}),h3:({node:e,children:t,className:r,...o})=>i("h3",{className:n("mt-6 mb-2 font-semibold text-xl",r),...o,children:t}),h4:({node:e,children:t,className:r,...o})=>i("h4",{className:n("mt-6 mb-2 font-semibold text-lg",r),...o,children:t}),h5:({node:e,children:t,className:r,...o})=>i("h5",{className:n("mt-6 mb-2 font-semibold text-base",r),...o,children:t}),h6:({node:e,children:t,className:r,...o})=>i("h6",{className:n("mt-6 mb-2 font-semibold text-sm",r),...o,children:t}),table:({node:e,children:t,className:r,...o})=>i("div",{className:"my-4 overflow-x-auto",children:i("table",{className:n("w-full border-collapse border border-border",r),...o,children:t})}),thead:({node:e,children:t,className:r,...o})=>i("thead",{className:n("bg-muted/50",r),...o,children:t}),tbody:({node:e,children:t,className:r,...o})=>i("tbody",{className:n("divide-y divide-border",r),...o,children:t}),tr:({node:e,children:t,className:r,...o})=>i("tr",{className:n("border-border border-b",r),...o,children:t}),th:({node:e,children:t,className:r,...o})=>i("th",{className:n("px-4 py-2 text-left font-semibold text-sm",r),...o,children:t}),td:({node:e,children:t,className:r,...o})=>i("td",{className:n("px-4 py-2 text-sm",r),...o,children:t}),blockquote:({node:e,children:t,className:r,...o})=>i("blockquote",{className:n("my-4 border-muted-foreground/30 border-l-4 pl-4 text-muted-foreground italic",r),...o,children:t}),code:re,pre:({children:e})=>e,sup:({node:e,children:t,className:r,...o})=>i("sup",{className:n("text-sm",r),...o,children:t}),sub:({node:e,children:t,className:r,...o})=>i("sub",{className:n("text-sm",r),...o,children:t})};import{marked as ne}from"marked";var A=e=>ne.lexer(e).map(r=>r.raw);var se=/(!?\[)([^\]]*?)$/,ie=/(\*\*)([^*]*?)$/,ae=/(__)([^_]*?)$/,ce=/(\*\*\*)([^*]*?)$/,le=/(\*)([^*]*?)$/,de=/(_)([^_]*?)$/,me=/(`)([^`]*?)$/,ue=/(~~)([^~]*?)$/,pe=/(\$)([^$]*?)$/,ge=/(\$\$)([^$]*?)$/,he=e=>{let t=e.match(se);if(t){let r=e.lastIndexOf(t[1]);return e.substring(0,r)}return e},fe=e=>e.match(ie)&&(e.match(/\*\*/g)||[]).length%2===1?`${e}**`:e,be=e=>e.match(ae)&&(e.match(/__/g)||[]).length%2===1?`${e}__`:e,ke=e=>e.split("").reduce((t,r,o)=>{if(r==="*"){let s=e[o-1],a=e[o+1];if(s==="\\")return t;if(s!=="*"&&a!=="*")return t+1}return t},0),ye=e=>e.match(le)&&ke(e)%2===1?`${e}*`:e,Me=e=>e.split("").reduce((t,r,o)=>{if(r==="_"){let s=e[o-1],a=e[o+1];if(s==="\\")return t;if(s!=="_"&&a!=="_")return t+1}return t},0),Ce=e=>e.match(de)&&Me(e)%2===1?`${e}_`:e,Be=(e,t)=>{let r=e.substring(t,t+3)==="```",o=t>0&&e.substring(t-1,t+2)==="```",s=t>1&&e.substring(t-2,t+1)==="```";return r||o||s},ve=e=>{let t=0;for(let r=0;r<e.length;r++)e[r]==="`"&&!Be(e,r)&&t++;return t},Ie=e=>{if(e.match(/^```[^`\n]*```?$/)&&!e.includes(`
2
- `))return e.endsWith("``")&&!e.endsWith("```")?`${e}\``:e;let r=(e.match(/```/g)||[]).length,o=r%2===1;return(e.endsWith("```\n")||e.endsWith("```"))&&r%2===0||r>0&&r%2===0&&e.includes(`
3
- `)?e:e.match(me)&&!o&&ve(e)%2===1?`${e}\``:e},$e=e=>e.match(ue)&&(e.match(/~~/g)||[]).length%2===1?`${e}~~`:e,Te=e=>e.split("").reduce((t,r,o)=>{if(r==="$"){let s=e[o-1],a=e[o+1];if(s==="\\")return t;if(s!=="$"&&a!=="$")return t+1}return t},0),we=e=>e.match(ge)&&(e.match(/\$\$/g)||[]).length%2===1?`${e}$$`:e,Ne=e=>e.match(pe)&&Te(e)%2===1?`${e}$`:e,Pe=e=>{let t=0,r=e.match(/\*+/g)||[];for(let o of r){let s=o.length;s>=3&&(t+=Math.floor(s/3))}return t},Se=e=>/^\*{4,}$/.test(e)?e:e.match(ce)&&Pe(e)%2===1?`${e}***`:e,_=e=>{if(!e||typeof e!="string")return e;let t=e;return t=he(t),t=Se(t),t=fe(t),t=be(t),t=ye(t),t=Ce(t),t=Ie(t),t=$e(t),t=we(t),t=Ne(t),t};import{jsx as B}from"react/jsx-runtime";var De=x.default||x,Ee=De(Ae),T=Le("github-light"),E=R(({content:e,shouldParseIncompleteMarkdown:t,...r})=>{let o=D(()=>typeof e=="string"&&t?_(e.trim()):e,[e,t]);return B(Ee,{...r,children:o})},(e,t)=>e.content===t.content);E.displayName="Block";var K=R(({children:e,allowedImagePrefixes:t,allowedLinkPrefixes:r,defaultOrigin:o,parseIncompleteMarkdown:s=!0,components:a,rehypePlugins:l,remarkPlugins:c,className:d,shikiTheme:m="github-light",...u})=>{let h=He(),p=D(()=>A(typeof e=="string"?e:""),[e]);return B(T.Provider,{value:m,children:B("div",{className:n("space-y-4",d),...u,children:p.map((g,k)=>B(E,{allowedImagePrefixes:t!=null?t:["*"],allowedLinkPrefixes:r!=null?r:["*"],components:{...H,...a},content:g,defaultOrigin:o,rehypePlugins:[_e,...l!=null?l:[]],remarkPlugins:[xe,Re,...c!=null?c:[]],shouldParseIncompleteMarkdown:s},`${h}-block_${k}`))})})},(e,t)=>e.children===t.children&&e.shikiTheme===t.shikiTheme);K.displayName="Streamdown";var Mt=K;export{$ as CodeBlock,y as CodeBlockCopyButton,X as CodeBlockRenderButton,w as Mermaid,T as ShikiThemeContext,K as Streamdown,Mt as default};
package/dist/index.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../index.tsx","../lib/components.tsx","../lib/code-block.tsx","../lib/utils.ts","../lib/parse-blocks.tsx","../lib/parse-incomplete-markdown.ts"],"sourcesContent":["'use client';\n\nimport type { ComponentProps } from 'react';\nimport { memo, useId, useMemo } from 'react';\nimport ReactMarkdown from 'react-markdown';\nimport rehypeKatex from 'rehype-katex';\nimport remarkGfm from 'remark-gfm';\nimport remarkMath from 'remark-math';\nimport 'katex/dist/katex.min.css';\nimport hardenReactMarkdownImport from 'harden-react-markdown';\nimport { components as defaultComponents } from './lib/components';\nimport { parseMarkdownIntoBlocks } from './lib/parse-blocks';\nimport { parseIncompleteMarkdown } from './lib/parse-incomplete-markdown';\nimport { cn } from './lib/utils';\n\n// Handle both ESM and CJS imports\nconst hardenReactMarkdown = (hardenReactMarkdownImport as any).default || hardenReactMarkdownImport;\n\n// Create a hardened version of ReactMarkdown\nconst HardenedMarkdown: ReturnType<typeof hardenReactMarkdown> =\n hardenReactMarkdown(ReactMarkdown);\n\nexport type StreamdownProps = ComponentProps<typeof HardenedMarkdown> & {\n parseIncompleteMarkdown?: boolean;\n className?: string;\n};\n\ntype BlockProps = ComponentProps<typeof HardenedMarkdown> & {\n content: string;\n shouldParseIncompleteMarkdown: boolean;\n};\n\nconst Block = memo(\n ({ content, shouldParseIncompleteMarkdown, ...props }: BlockProps) => {\n const parsedContent = useMemo(\n () =>\n typeof content === 'string' && shouldParseIncompleteMarkdown\n ? parseIncompleteMarkdown(content.trim())\n : content,\n [content, shouldParseIncompleteMarkdown]\n );\n\n return <HardenedMarkdown {...props}>{parsedContent}</HardenedMarkdown>;\n },\n (prevProps, nextProps) => prevProps.content === nextProps.content\n);\n\nexport const Streamdown = memo(\n ({\n children,\n allowedImagePrefixes,\n allowedLinkPrefixes,\n defaultOrigin,\n parseIncompleteMarkdown: shouldParseIncompleteMarkdown = true,\n components,\n rehypePlugins,\n remarkPlugins,\n className,\n ...props\n }: StreamdownProps) => {\n // Parse the children to remove incomplete markdown tokens if enabled\n const generatedId = useId();\n const blocks = useMemo(\n () =>\n parseMarkdownIntoBlocks(typeof children === 'string' ? children : ''),\n [children]\n );\n\n return (\n <div className={cn('space-y-4', className)} {...props}>\n {blocks.map((block, index) => (\n <Block\n allowedImagePrefixes={allowedImagePrefixes ?? ['*']}\n allowedLinkPrefixes={allowedLinkPrefixes ?? ['*']}\n components={{\n ...defaultComponents,\n ...components,\n }}\n content={block}\n defaultOrigin={defaultOrigin}\n // biome-ignore lint/suspicious/noArrayIndexKey: \"required\"\n key={`${generatedId}-block_${index}`}\n rehypePlugins={[rehypeKatex, ...(rehypePlugins ?? [])]}\n remarkPlugins={[remarkGfm, remarkMath, ...(remarkPlugins ?? [])]}\n shouldParseIncompleteMarkdown={shouldParseIncompleteMarkdown}\n />\n ))}\n </div>\n );\n },\n (prevProps, nextProps) => prevProps.children === nextProps.children\n);\nStreamdown.displayName = 'Streamdown';\n\nexport default Streamdown;\n","import { isValidElement } from 'react';\nimport type { Options } from 'react-markdown';\nimport type { BundledLanguage } from 'shiki';\nimport { CodeBlock, CodeBlockCopyButton } from './code-block';\nimport { cn } from './utils';\n\nexport const components: Options['components'] = {\n ol: ({ node, children, className, ...props }) => (\n <ol className={cn('ml-4 list-outside list-decimal', className)} {...props}>\n {children}\n </ol>\n ),\n li: ({ node, children, className, ...props }) => (\n <li className={cn('py-1', className)} {...props}>\n {children}\n </li>\n ),\n ul: ({ node, children, className, ...props }) => (\n <ul className={cn('ml-4 list-outside list-disc', className)} {...props}>\n {children}\n </ul>\n ),\n hr: ({ node, className, ...props }) => (\n <hr className={cn('my-6 border-border', className)} {...props} />\n ),\n strong: ({ node, children, className, ...props }) => (\n <span className={cn('font-semibold', className)} {...props}>\n {children}\n </span>\n ),\n a: ({ node, children, className, href, ...props }) => (\n <a\n className={cn('font-medium text-primary underline', className)}\n href={href}\n rel=\"noreferrer\"\n target=\"_blank\"\n {...props}\n >\n {children}\n </a>\n ),\n h1: ({ node, children, className, ...props }) => (\n <h1\n className={cn('mt-6 mb-2 font-semibold text-3xl', className)}\n {...props}\n >\n {children}\n </h1>\n ),\n h2: ({ node, children, className, ...props }) => (\n <h2\n className={cn('mt-6 mb-2 font-semibold text-2xl', className)}\n {...props}\n >\n {children}\n </h2>\n ),\n h3: ({ node, children, className, ...props }) => (\n <h3 className={cn('mt-6 mb-2 font-semibold text-xl', className)} {...props}>\n {children}\n </h3>\n ),\n h4: ({ node, children, className, ...props }) => (\n <h4 className={cn('mt-6 mb-2 font-semibold text-lg', className)} {...props}>\n {children}\n </h4>\n ),\n h5: ({ node, children, className, ...props }) => (\n <h5\n className={cn('mt-6 mb-2 font-semibold text-base', className)}\n {...props}\n >\n {children}\n </h5>\n ),\n h6: ({ node, children, className, ...props }) => (\n <h6 className={cn('mt-6 mb-2 font-semibold text-sm', className)} {...props}>\n {children}\n </h6>\n ),\n table: ({ node, children, className, ...props }) => (\n <div className=\"my-4 overflow-x-auto\">\n <table\n className={cn('w-full border-collapse border border-border', className)}\n {...props}\n >\n {children}\n </table>\n </div>\n ),\n thead: ({ node, children, className, ...props }) => (\n <thead className={cn('bg-muted/50', className)} {...props}>\n {children}\n </thead>\n ),\n tbody: ({ node, children, className, ...props }) => (\n <tbody className={cn('divide-y divide-border', className)} {...props}>\n {children}\n </tbody>\n ),\n tr: ({ node, children, className, ...props }) => (\n <tr className={cn('border-border border-b', className)} {...props}>\n {children}\n </tr>\n ),\n th: ({ node, children, className, ...props }) => (\n <th\n className={cn('px-4 py-2 text-left font-semibold text-sm', className)}\n {...props}\n >\n {children}\n </th>\n ),\n td: ({ node, children, className, ...props }) => (\n <td className={cn('px-4 py-2 text-sm', className)} {...props}>\n {children}\n </td>\n ),\n blockquote: ({ node, children, className, ...props }) => (\n <blockquote\n className={cn(\n 'my-4 border-muted-foreground/30 border-l-4 pl-4 text-muted-foreground italic',\n className\n )}\n {...props}\n >\n {children}\n </blockquote>\n ),\n code: ({ node, className, ...props }) => {\n const inline = node?.position?.start.line === node?.position?.end.line;\n\n if (!inline) {\n return <code className={className} {...props} />;\n }\n\n return (\n <code\n className={cn(\n 'rounded bg-muted px-1.5 py-0.5 font-mono text-sm',\n className\n )}\n {...props}\n />\n );\n },\n pre: ({ node, className, children }) => {\n let language: BundledLanguage = 'javascript';\n\n if (typeof node?.properties?.className === 'string') {\n language = node.properties.className.replace(\n 'language-',\n ''\n ) as BundledLanguage;\n }\n\n // Extract code content from children safely\n let code = '';\n if (\n isValidElement(children) &&\n children.props &&\n typeof children.props === 'object' &&\n 'children' in children.props &&\n typeof children.props.children === 'string'\n ) {\n code = children.props.children;\n } else if (typeof children === 'string') {\n code = children;\n }\n\n return (\n <CodeBlock\n className={cn('my-4 h-auto rounded-lg border p-4', className)}\n code={code}\n language={language}\n >\n <CodeBlockCopyButton />\n </CodeBlock>\n );\n },\n sup: ({ node, children, className, ...props }) => (\n <sup className={cn('text-sm', className)} {...props}>\n {children}\n </sup>\n ),\n sub: ({ node, children, className, ...props }) => (\n <sub className={cn('text-sm', className)} {...props}>\n {children}\n </sub>\n ),\n};\n","'use client';\n\nimport { CheckIcon, CopyIcon } from 'lucide-react';\nimport {\n type ComponentProps,\n createContext,\n type HTMLAttributes,\n useContext,\n useEffect,\n useState,\n} from 'react';\nimport { type BundledLanguage, codeToHtml } from 'shiki';\nimport { cn } from './utils';\n\ntype CodeBlockProps = HTMLAttributes<HTMLDivElement> & {\n code: string;\n language: BundledLanguage;\n};\n\ntype CodeBlockContextType = {\n code: string;\n};\n\nconst CodeBlockContext = createContext<CodeBlockContextType>({\n code: '',\n});\n\nexport async function highlightCode(code: string, language: BundledLanguage) {\n return await codeToHtml(code, {\n lang: language,\n theme: 'github-light',\n });\n}\n\nexport const CodeBlock = ({\n code,\n language,\n className,\n children,\n ...props\n}: CodeBlockProps) => {\n const [html, setHtml] = useState<string>('');\n\n useEffect(() => {\n let isMounted = true;\n\n highlightCode(code, language).then((result) => {\n if (isMounted) {\n setHtml(result);\n }\n });\n\n return () => {\n isMounted = false;\n };\n }, [code, language]);\n\n return (\n <CodeBlockContext.Provider value={{ code }}>\n <div className=\"group relative\">\n <div\n className={cn('overflow-x-auto', className)}\n // biome-ignore lint/security/noDangerouslySetInnerHtml: \"this is needed.\"\n dangerouslySetInnerHTML={{ __html: html }}\n {...props}\n />\n {children}\n </div>\n </CodeBlockContext.Provider>\n );\n};\n\nexport type CodeBlockCopyButtonProps = ComponentProps<'button'> & {\n onCopy?: () => void;\n onError?: (error: Error) => void;\n timeout?: number;\n};\n\nexport const CodeBlockCopyButton = ({\n onCopy,\n onError,\n timeout = 2000,\n children,\n className,\n ...props\n}: CodeBlockCopyButtonProps) => {\n const [isCopied, setIsCopied] = useState(false);\n const { code } = useContext(CodeBlockContext);\n\n const copyToClipboard = async () => {\n if (typeof window === 'undefined' || !navigator?.clipboard?.writeText) {\n onError?.(new Error('Clipboard API not available'));\n return;\n }\n\n try {\n await navigator.clipboard.writeText(code);\n setIsCopied(true);\n onCopy?.();\n setTimeout(() => setIsCopied(false), timeout);\n } catch (error) {\n onError?.(error as Error);\n }\n };\n\n const Icon = isCopied ? CheckIcon : CopyIcon;\n\n return (\n <button\n className={cn(\n 'absolute top-2 right-2 shrink-0 rounded-md p-3 opacity-0 transition-all',\n 'hover:bg-secondary group-hover:opacity-100',\n className\n )}\n onClick={copyToClipboard}\n type=\"button\"\n {...props}\n >\n {children ?? <Icon size={14} />}\n </button>\n );\n};\n","import { type ClassValue, clsx } from 'clsx';\nimport { twMerge } from 'tailwind-merge';\n\nexport const cn = (...inputs: ClassValue[]) => twMerge(clsx(inputs));\n","import { marked } from 'marked';\n\nexport const parseMarkdownIntoBlocks = (markdown: string): string[] => {\n const tokens = marked.lexer(markdown);\n return tokens.map((token) => token.raw);\n};\n","const linkImagePattern = /(!?\\[)([^\\]]*?)$/;\nconst boldPattern = /(\\*\\*)([^*]*?)$/;\nconst italicPattern = /(__)([^_]*?)$/;\nconst singleAsteriskPattern = /(\\*)([^*]*?)$/;\nconst singleUnderscorePattern = /(_)([^_]*?)$/;\nconst inlineCodePattern = /(`)([^`]*?)$/;\nconst strikethroughPattern = /(~~)([^~]*?)$/;\nconst inlineKatexPattern = /(\\$)([^$]*?)$/;\nconst blockKatexPattern = /(\\$\\$)([^$]*?)$/;\n\n// Handles incomplete links and images by removing them if not closed\nconst handleIncompleteLinksAndImages = (text: string): string => {\n const linkMatch = text.match(linkImagePattern);\n\n if (linkMatch) {\n const startIndex = text.lastIndexOf(linkMatch[1]);\n return text.substring(0, startIndex);\n }\n\n return text;\n};\n\n// Completes incomplete bold formatting (**)\nconst handleIncompleteBold = (text: string): string => {\n const boldMatch = text.match(boldPattern);\n\n if (boldMatch) {\n const asteriskPairs = (text.match(/\\*\\*/g) || []).length;\n if (asteriskPairs % 2 === 1) {\n return `${text}**`;\n }\n }\n\n return text;\n};\n\n// Completes incomplete italic formatting with double underscores (__)\nconst handleIncompleteDoubleUnderscoreItalic = (text: string): string => {\n const italicMatch = text.match(italicPattern);\n\n if (italicMatch) {\n const underscorePairs = (text.match(/__/g) || []).length;\n if (underscorePairs % 2 === 1) {\n return `${text}__`;\n }\n }\n\n return text;\n};\n\n// Counts single asterisks that are not part of double asterisks and not escaped\nconst countSingleAsterisks = (text: string): number => {\n return text.split('').reduce((acc, char, index) => {\n if (char === '*') {\n const prevChar = text[index - 1];\n const nextChar = text[index + 1];\n // Skip if escaped with backslash\n if (prevChar === '\\\\') {\n return acc;\n }\n if (prevChar !== '*' && nextChar !== '*') {\n return acc + 1;\n }\n }\n return acc;\n }, 0);\n};\n\n// Completes incomplete italic formatting with single asterisks (*)\nconst handleIncompleteSingleAsteriskItalic = (text: string): string => {\n const singleAsteriskMatch = text.match(singleAsteriskPattern);\n\n if (singleAsteriskMatch) {\n const singleAsterisks = countSingleAsterisks(text);\n if (singleAsterisks % 2 === 1) {\n return `${text}*`;\n }\n }\n\n return text;\n};\n\n// Counts single underscores that are not part of double underscores and not escaped\nconst countSingleUnderscores = (text: string): number => {\n return text.split('').reduce((acc, char, index) => {\n if (char === '_') {\n const prevChar = text[index - 1];\n const nextChar = text[index + 1];\n // Skip if escaped with backslash\n if (prevChar === '\\\\') {\n return acc;\n }\n if (prevChar !== '_' && nextChar !== '_') {\n return acc + 1;\n }\n }\n return acc;\n }, 0);\n};\n\n// Completes incomplete italic formatting with single underscores (_)\nconst handleIncompleteSingleUnderscoreItalic = (text: string): string => {\n const singleUnderscoreMatch = text.match(singleUnderscorePattern);\n\n if (singleUnderscoreMatch) {\n const singleUnderscores = countSingleUnderscores(text);\n if (singleUnderscores % 2 === 1) {\n return `${text}_`;\n }\n }\n\n return text;\n};\n\n// Checks if a backtick at position i is part of a triple backtick sequence\nconst isPartOfTripleBacktick = (text: string, i: number): boolean => {\n const isTripleStart = text.substring(i, i + 3) === '```';\n const isTripleMiddle = i > 0 && text.substring(i - 1, i + 2) === '```';\n const isTripleEnd = i > 1 && text.substring(i - 2, i + 1) === '```';\n\n return isTripleStart || isTripleMiddle || isTripleEnd;\n};\n\n// Counts single backticks that are not part of triple backticks\nconst countSingleBackticks = (text: string): number => {\n let count = 0;\n for (let i = 0; i < text.length; i++) {\n if (text[i] === '`' && !isPartOfTripleBacktick(text, i)) {\n count++;\n }\n }\n return count;\n};\n\n// Completes incomplete inline code formatting (`)\n// Avoids completing if inside an incomplete code block\nconst handleIncompleteInlineCode = (text: string): string => {\n // Check if we're inside a code block (complete or incomplete)\n const allTripleBackticks = (text.match(/```/g) || []).length;\n const insideIncompleteCodeBlock = allTripleBackticks % 2 === 1;\n \n // Don't modify text if we have complete code blocks (even pairs of ```)\n if (allTripleBackticks > 0 && allTripleBackticks % 2 === 0) {\n // We have complete code blocks, don't add any backticks\n return text;\n }\n\n const inlineCodeMatch = text.match(inlineCodePattern);\n\n if (inlineCodeMatch && !insideIncompleteCodeBlock) {\n const singleBacktickCount = countSingleBackticks(text);\n if (singleBacktickCount % 2 === 1) {\n return `${text}\\``;\n }\n }\n\n return text;\n};\n\n// Completes incomplete strikethrough formatting (~~)\nconst handleIncompleteStrikethrough = (text: string): string => {\n const strikethroughMatch = text.match(strikethroughPattern);\n\n if (strikethroughMatch) {\n const tildePairs = (text.match(/~~/g) || []).length;\n if (tildePairs % 2 === 1) {\n return `${text}~~`;\n }\n }\n\n return text;\n};\n\n// Counts single dollar signs that are not part of double dollar signs and not escaped\nconst countSingleDollarSigns = (text: string): number => {\n return text.split('').reduce((acc, char, index) => {\n if (char === '$') {\n const prevChar = text[index - 1];\n const nextChar = text[index + 1];\n // Skip if escaped with backslash\n if (prevChar === '\\\\') {\n return acc;\n }\n if (prevChar !== '$' && nextChar !== '$') {\n return acc + 1;\n }\n }\n return acc;\n }, 0);\n};\n\n// Completes incomplete block KaTeX formatting ($$)\nconst handleIncompleteBlockKatex = (text: string): string => {\n const blockKatexMatch = text.match(blockKatexPattern);\n\n if (blockKatexMatch) {\n const dollarPairs = (text.match(/\\$\\$/g) || []).length;\n if (dollarPairs % 2 === 1) {\n return `${text}$$`;\n }\n }\n\n return text;\n};\n\n// Completes incomplete inline KaTeX formatting ($)\nconst handleIncompleteInlineKatex = (text: string): string => {\n const inlineKatexMatch = text.match(inlineKatexPattern);\n\n if (inlineKatexMatch) {\n const singleDollars = countSingleDollarSigns(text);\n if (singleDollars % 2 === 1) {\n return `${text}$`;\n }\n }\n\n return text;\n};\n\n// Parses markdown text and removes incomplete tokens to prevent partial rendering\nexport const parseIncompleteMarkdown = (text: string): string => {\n if (!text || typeof text !== 'string') {\n return text;\n }\n\n let result = text;\n\n // Handle incomplete links and images first (removes content)\n result = handleIncompleteLinksAndImages(result);\n\n // Handle various formatting completions\n result = handleIncompleteBold(result);\n result = handleIncompleteDoubleUnderscoreItalic(result);\n result = handleIncompleteSingleAsteriskItalic(result);\n result = handleIncompleteSingleUnderscoreItalic(result);\n result = handleIncompleteInlineCode(result);\n result = handleIncompleteStrikethrough(result);\n \n // Handle KaTeX formatting (block first, then inline)\n result = handleIncompleteBlockKatex(result);\n result = handleIncompleteInlineKatex(result);\n\n return result;\n};\n"],"mappings":"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","names":["jsx","jsx","components"]}