@runtypelabs/persona 3.12.0 → 3.13.0
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 +79 -0
- package/dist/index.cjs +14 -14
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +6 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.global.js +4 -4
- package/dist/index.global.js.map +1 -1
- package/dist/index.js +15 -15
- package/dist/index.js.map +1 -1
- package/dist/install.global.js +1 -1
- package/dist/install.global.js.map +1 -1
- package/package.json +1 -1
- package/src/install.ts +10 -2
- package/src/runtime/init.test.ts +132 -0
- package/src/utils/code-generators.test.ts +57 -0
- package/src/utils/code-generators.ts +21 -6
package/dist/index.d.cts
CHANGED
|
@@ -5014,6 +5014,12 @@ type CodeGeneratorOptions = {
|
|
|
5014
5014
|
* @default true
|
|
5015
5015
|
*/
|
|
5016
5016
|
includeHookComments?: boolean;
|
|
5017
|
+
/**
|
|
5018
|
+
* If provided, emits `windowKey` in the generated `initAgentWidget()` call
|
|
5019
|
+
* so the widget handle is stored on `window[windowKey]`.
|
|
5020
|
+
* Only affects script formats (script-installer, script-manual, script-advanced).
|
|
5021
|
+
*/
|
|
5022
|
+
windowKey?: string;
|
|
5017
5023
|
};
|
|
5018
5024
|
declare function generateCodeSnippet(config: any, format?: CodeFormat, options?: CodeGeneratorOptions): string;
|
|
5019
5025
|
|
package/dist/index.d.ts
CHANGED
|
@@ -5014,6 +5014,12 @@ type CodeGeneratorOptions = {
|
|
|
5014
5014
|
* @default true
|
|
5015
5015
|
*/
|
|
5016
5016
|
includeHookComments?: boolean;
|
|
5017
|
+
/**
|
|
5018
|
+
* If provided, emits `windowKey` in the generated `initAgentWidget()` call
|
|
5019
|
+
* so the widget handle is stored on `window[windowKey]`.
|
|
5020
|
+
* Only affects script formats (script-installer, script-manual, script-advanced).
|
|
5021
|
+
*/
|
|
5022
|
+
windowKey?: string;
|
|
5017
5023
|
};
|
|
5018
5024
|
declare function generateCodeSnippet(config: any, format?: CodeFormat, options?: CodeGeneratorOptions): string;
|
|
5019
5025
|
|
package/dist/index.global.js
CHANGED
|
@@ -162,7 +162,7 @@ ${n.join(`
|
|
|
162
162
|
${n.join(`
|
|
163
163
|
`)}`)}return t.join(`
|
|
164
164
|
|
|
165
|
-
`)}var TI={name:"@runtypelabs/persona",version:"3.
|
|
165
|
+
`)}var TI={name:"@runtypelabs/persona",version:"3.13.0",description:"Themeable, pluggable streaming agent widget for websites, in plain JS with support for voice input and reasoning / tool output.",type:"module",main:"dist/index.cjs",module:"dist/index.js",types:"dist/index.d.ts",exports:{".":{types:"./dist/index.d.ts",import:"./dist/index.js",require:"./dist/index.cjs"},"./theme-reference":{types:"./dist/theme-reference.d.ts",import:"./dist/theme-reference.js",require:"./dist/theme-reference.cjs"},"./theme-editor":{types:"./dist/theme-editor.d.ts",import:"./dist/theme-editor.js",require:"./dist/theme-editor.cjs"},"./widget.css":"./dist/widget.css"},files:["dist","src"],scripts:{build:"rimraf dist && pnpm run build:styles && pnpm run build:client && pnpm run build:installer && pnpm run build:theme-ref && pnpm run build:theme-editor","build:theme-editor":"tsup src/theme-editor.ts --format esm,cjs --dts --out-dir dist --no-splitting","build:theme-ref":"tsup src/theme-reference.ts --format esm,cjs --minify --dts","build:styles":`node -e "const fs=require('fs');fs.mkdirSync('dist',{recursive:true});fs.copyFileSync('src/styles/widget.css','dist/widget.css');"`,"build:client":'tsup src/index.ts --format esm,cjs,iife --global-name AgentWidget --minify --sourcemap --splitting false --dts --loader ".css=text"',"build:installer":"tsup src/install.ts --format iife --global-name SiteAgentInstaller --out-dir dist --minify --sourcemap --no-splitting",lint:"eslint . --ext .ts",typecheck:"tsc --noEmit",test:"vitest","test:ui":"vitest --ui","test:run":"vitest run"},dependencies:{dompurify:"^3.3.3",idiomorph:"^0.7.4",lucide:"^0.552.0",marked:"^12.0.2","partial-json":"^0.1.7",zod:"^3.22.4"},devDependencies:{"@types/node":"^20.12.7","@typescript-eslint/eslint-plugin":"^7.0.0","@typescript-eslint/parser":"^7.0.0","@vitest/ui":"^4.0.9",eslint:"^8.57.0","eslint-config-prettier":"^9.1.0","fake-indexeddb":"^6.2.5",rimraf:"^5.0.5",tsup:"^8.0.1",typescript:"^5.4.5",vitest:"^4.0.9"},engines:{node:">=20.0.0"},author:"Runtype",license:"MIT",keywords:["ai","chat","widget","streaming","typescript","persona","agent"],repository:{type:"git",url:"git+https://github.com/runtypelabs/persona.git",directory:"packages/widget"},bugs:{url:"https://github.com/runtypelabs/persona/issues"},homepage:"https://github.com/runtypelabs/persona/tree/main/packages/widget#readme",publishConfig:{access:"public"}};var ko=TI.version;function Wr(r){if(r!==void 0)return typeof r=="string"?r:Array.isArray(r)?`[${r.map(a=>a.toString()).join(", ")}]`:r.toString()}function XF(r){if(r)return{getHeaders:Wr(r.getHeaders),onFeedback:Wr(r.onFeedback),onCopy:Wr(r.onCopy),requestMiddleware:Wr(r.requestMiddleware),actionHandlers:Wr(r.actionHandlers),actionParsers:Wr(r.actionParsers),postprocessMessage:Wr(r.postprocessMessage),contextProviders:Wr(r.contextProviders),streamParser:Wr(r.streamParser)}}var kI=`({ text, message }: any) => {
|
|
166
166
|
const jsonSource = (message as any).rawContent || text || message.content;
|
|
167
167
|
if (!jsonSource || typeof jsonSource !== 'string') return null;
|
|
168
168
|
let cleanJson = jsonSource
|
|
@@ -234,13 +234,13 @@ ${n.join(`
|
|
|
234
234
|
if (parsed.action === 'message') return parsed.text || '';
|
|
235
235
|
if (parsed.action === 'message_and_click') return parsed.text || 'Processing...';
|
|
236
236
|
return parsed.text || null;
|
|
237
|
-
}`;function YF(r){if(!r)return null;let a=r.toString();return a.includes("createJsonStreamParser")||a.includes("partial-json")?"json":a.includes("createRegexJsonParser")||a.includes("regex")?"regex-json":a.includes("createXmlParser")||a.includes("<text>")?"xml":null}function xk(r){var a,e;return(e=(a=r.parserType)!=null?a:YF(r.streamParser))!=null?e:"plain"}function gk(r,a){let e=[];return r.toolCall&&(e.push(`${a}toolCall: {`),Object.entries(r.toolCall).forEach(([t,s])=>{typeof s=="string"&&e.push(`${a} ${t}: "${s}",`)}),e.push(`${a}},`)),e}function Mk(r,a,e){let t=[],s=r.messageActions&&Object.entries(r.messageActions).some(([n,l])=>n!=="onFeedback"&&n!=="onCopy"&&l!==void 0),o=(e==null?void 0:e.onFeedback)||(e==null?void 0:e.onCopy);return(s||o)&&(t.push(`${a}messageActions: {`),r.messageActions&&Object.entries(r.messageActions).forEach(([n,l])=>{n==="onFeedback"||n==="onCopy"||(typeof l=="string"?t.push(`${a} ${n}: "${l}",`):typeof l=="boolean"&&t.push(`${a} ${n}: ${l},`))}),e!=null&&e.onFeedback&&t.push(`${a} onFeedback: ${e.onFeedback},`),e!=null&&e.onCopy&&t.push(`${a} onCopy: ${e.onCopy},`),t.push(`${a}},`)),t}function yk(r,a){let e=[];if(r.markdown){let t=r.markdown.options&&Object.keys(r.markdown.options).length>0,s=r.markdown.disableDefaultStyles!==void 0;(t||s)&&(e.push(`${a}markdown: {`),t&&(e.push(`${a} options: {`),Object.entries(r.markdown.options).forEach(([o,n])=>{typeof n=="string"?e.push(`${a} ${o}: "${n}",`):typeof n=="boolean"&&e.push(`${a} ${o}: ${n},`)}),e.push(`${a} },`)),s&&e.push(`${a} disableDefaultStyles: ${r.markdown.disableDefaultStyles},`),e.push(`${a}},`))}return e}function vk(r,a){let e=[];if(r.layout){let t=r.layout.header&&Object.keys(r.layout.header).some(o=>o!=="render"),s=r.layout.messages&&Object.keys(r.layout.messages).some(o=>o!=="renderUserMessage"&&o!=="renderAssistantMessage");(t||s)&&(e.push(`${a}layout: {`),t&&(e.push(`${a} header: {`),Object.entries(r.layout.header).forEach(([o,n])=>{o!=="render"&&(typeof n=="string"?e.push(`${a} ${o}: "${n}",`):typeof n=="boolean"&&e.push(`${a} ${o}: ${n},`))}),e.push(`${a} },`)),s&&(e.push(`${a} messages: {`),Object.entries(r.layout.messages).forEach(([o,n])=>{o==="renderUserMessage"||o==="renderAssistantMessage"||(o==="avatar"&&typeof n=="object"&&n!==null?(e.push(`${a} avatar: {`),Object.entries(n).forEach(([l,p])=>{typeof p=="string"?e.push(`${a} ${l}: "${p}",`):typeof p=="boolean"&&e.push(`${a} ${l}: ${p},`)}),e.push(`${a} },`)):o==="timestamp"&&typeof n=="object"&&n!==null?Object.entries(n).some(([p])=>p!=="format")&&(e.push(`${a} timestamp: {`),Object.entries(n).forEach(([p,i])=>{p!=="format"&&(typeof i=="string"?e.push(`${a} ${p}: "${i}",`):typeof i=="boolean"&&e.push(`${a} ${p}: ${i},`))}),e.push(`${a} },`)):typeof n=="string"?e.push(`${a} ${o}: "${n}",`):typeof n=="boolean"&&e.push(`${a} ${o}: ${n},`))}),e.push(`${a} },`)),e.push(`${a}},`))}return e}function EL(r,a){let e=[];return r&&(r.getHeaders&&e.push(`${a}getHeaders: ${r.getHeaders},`),r.requestMiddleware&&e.push(`${a}requestMiddleware: ${r.requestMiddleware},`),r.actionParsers&&e.push(`${a}actionParsers: ${r.actionParsers},`),r.actionHandlers&&e.push(`${a}actionHandlers: ${r.actionHandlers},`),r.contextProviders&&e.push(`${a}contextProviders: ${r.contextProviders},`),r.streamParser&&e.push(`${a}streamParser: ${r.streamParser},`)),e}function PI(r,a,e){Object.entries(a).forEach(([t,s])=>{if(!(s===void 0||typeof s=="function")){if(Array.isArray(s)){r.push(`${e}${t}: ${JSON.stringify(s)},`);return}if(s&&typeof s=="object"){r.push(`${e}${t}: {`),PI(r,s,`${e} `),r.push(`${e}},`);return}r.push(`${e}${t}: ${JSON.stringify(s)},`)}})}function ao(r,a,e,t){e&&(r.push(`${t}${a}: {`),PI(r,e,`${t} `),r.push(`${t}},`))}function RI(r,a="esm",e){let t={...r};delete t.postprocessMessage,delete t.initialMessages;let s=e?{...e,hooks:XF(e.hooks)}:void 0;return a==="esm"?QF(t,s):a==="script-installer"?aV(t):a==="script-advanced"?oV(t,s):a==="react-component"?eV(t,s):a==="react-advanced"?tV(t,s):rV(t,s)}function QF(r,a){let e=a==null?void 0:a.hooks,t=xk(r),s=t!=="plain",o=["import '@runtypelabs/persona/widget.css';","import { initAgentWidget, markdownPostprocessor } from '@runtypelabs/persona';","","initAgentWidget({"," target: 'body',"," config: {"];return r.apiUrl&&o.push(` apiUrl: "${r.apiUrl}",`),r.clientToken&&o.push(` clientToken: "${r.clientToken}",`),r.flowId&&o.push(` flowId: "${r.flowId}",`),s&&o.push(` parserType: "${t}",`),r.theme&&typeof r.theme=="object"&&Object.keys(r.theme).length>0&&ao(o,"theme",r.theme," "),r.launcher&&ao(o,"launcher",r.launcher," "),r.copy&&(o.push(" copy: {"),Object.entries(r.copy).forEach(([n,l])=>{o.push(` ${n}: "${l}",`)}),o.push(" },")),r.sendButton&&(o.push(" sendButton: {"),Object.entries(r.sendButton).forEach(([n,l])=>{typeof l=="string"?o.push(` ${n}: "${l}",`):typeof l=="boolean"&&o.push(` ${n}: ${l},`)}),o.push(" },")),r.voiceRecognition&&(o.push(" voiceRecognition: {"),Object.entries(r.voiceRecognition).forEach(([n,l])=>{typeof l=="string"?o.push(` ${n}: "${l}",`):typeof l=="boolean"?o.push(` ${n}: ${l},`):typeof l=="number"&&o.push(` ${n}: ${l},`)}),o.push(" },")),r.statusIndicator&&(o.push(" statusIndicator: {"),Object.entries(r.statusIndicator).forEach(([n,l])=>{typeof l=="string"?o.push(` ${n}: "${l}",`):typeof l=="boolean"&&o.push(` ${n}: ${l},`)}),o.push(" },")),r.features&&(o.push(" features: {"),Object.entries(r.features).forEach(([n,l])=>{o.push(` ${n}: ${l},`)}),o.push(" },")),r.suggestionChips&&r.suggestionChips.length>0&&(o.push(" suggestionChips: ["),r.suggestionChips.forEach(n=>{o.push(` "${n}",`)}),o.push(" ],")),r.suggestionChipsConfig&&(o.push(" suggestionChipsConfig: {"),r.suggestionChipsConfig.fontFamily&&o.push(` fontFamily: "${r.suggestionChipsConfig.fontFamily}",`),r.suggestionChipsConfig.fontWeight&&o.push(` fontWeight: "${r.suggestionChipsConfig.fontWeight}",`),r.suggestionChipsConfig.paddingX&&o.push(` paddingX: "${r.suggestionChipsConfig.paddingX}",`),r.suggestionChipsConfig.paddingY&&o.push(` paddingY: "${r.suggestionChipsConfig.paddingY}",`),o.push(" },")),o.push(...gk(r," ")),o.push(...Mk(r," ",e)),o.push(...yk(r," ")),o.push(...vk(r," ")),o.push(...EL(e," ")),r.debug&&o.push(` debug: ${r.debug},`),e!=null&&e.postprocessMessage?o.push(` postprocessMessage: ${e.postprocessMessage}`):o.push(" postprocessMessage: ({ text }) => markdownPostprocessor(text)"),o.push(" }"),o.push("});"),o.join(`
|
|
237
|
+
}`;function YF(r){if(!r)return null;let a=r.toString();return a.includes("createJsonStreamParser")||a.includes("partial-json")?"json":a.includes("createRegexJsonParser")||a.includes("regex")?"regex-json":a.includes("createXmlParser")||a.includes("<text>")?"xml":null}function xk(r){var a,e;return(e=(a=r.parserType)!=null?a:YF(r.streamParser))!=null?e:"plain"}function gk(r,a){let e=[];return r.toolCall&&(e.push(`${a}toolCall: {`),Object.entries(r.toolCall).forEach(([t,s])=>{typeof s=="string"&&e.push(`${a} ${t}: "${s}",`)}),e.push(`${a}},`)),e}function Mk(r,a,e){let t=[],s=r.messageActions&&Object.entries(r.messageActions).some(([n,l])=>n!=="onFeedback"&&n!=="onCopy"&&l!==void 0),o=(e==null?void 0:e.onFeedback)||(e==null?void 0:e.onCopy);return(s||o)&&(t.push(`${a}messageActions: {`),r.messageActions&&Object.entries(r.messageActions).forEach(([n,l])=>{n==="onFeedback"||n==="onCopy"||(typeof l=="string"?t.push(`${a} ${n}: "${l}",`):typeof l=="boolean"&&t.push(`${a} ${n}: ${l},`))}),e!=null&&e.onFeedback&&t.push(`${a} onFeedback: ${e.onFeedback},`),e!=null&&e.onCopy&&t.push(`${a} onCopy: ${e.onCopy},`),t.push(`${a}},`)),t}function yk(r,a){let e=[];if(r.markdown){let t=r.markdown.options&&Object.keys(r.markdown.options).length>0,s=r.markdown.disableDefaultStyles!==void 0;(t||s)&&(e.push(`${a}markdown: {`),t&&(e.push(`${a} options: {`),Object.entries(r.markdown.options).forEach(([o,n])=>{typeof n=="string"?e.push(`${a} ${o}: "${n}",`):typeof n=="boolean"&&e.push(`${a} ${o}: ${n},`)}),e.push(`${a} },`)),s&&e.push(`${a} disableDefaultStyles: ${r.markdown.disableDefaultStyles},`),e.push(`${a}},`))}return e}function vk(r,a){let e=[];if(r.layout){let t=r.layout.header&&Object.keys(r.layout.header).some(o=>o!=="render"),s=r.layout.messages&&Object.keys(r.layout.messages).some(o=>o!=="renderUserMessage"&&o!=="renderAssistantMessage");(t||s)&&(e.push(`${a}layout: {`),t&&(e.push(`${a} header: {`),Object.entries(r.layout.header).forEach(([o,n])=>{o!=="render"&&(typeof n=="string"?e.push(`${a} ${o}: "${n}",`):typeof n=="boolean"&&e.push(`${a} ${o}: ${n},`))}),e.push(`${a} },`)),s&&(e.push(`${a} messages: {`),Object.entries(r.layout.messages).forEach(([o,n])=>{o==="renderUserMessage"||o==="renderAssistantMessage"||(o==="avatar"&&typeof n=="object"&&n!==null?(e.push(`${a} avatar: {`),Object.entries(n).forEach(([l,p])=>{typeof p=="string"?e.push(`${a} ${l}: "${p}",`):typeof p=="boolean"&&e.push(`${a} ${l}: ${p},`)}),e.push(`${a} },`)):o==="timestamp"&&typeof n=="object"&&n!==null?Object.entries(n).some(([p])=>p!=="format")&&(e.push(`${a} timestamp: {`),Object.entries(n).forEach(([p,i])=>{p!=="format"&&(typeof i=="string"?e.push(`${a} ${p}: "${i}",`):typeof i=="boolean"&&e.push(`${a} ${p}: ${i},`))}),e.push(`${a} },`)):typeof n=="string"?e.push(`${a} ${o}: "${n}",`):typeof n=="boolean"&&e.push(`${a} ${o}: ${n},`))}),e.push(`${a} },`)),e.push(`${a}},`))}return e}function EL(r,a){let e=[];return r&&(r.getHeaders&&e.push(`${a}getHeaders: ${r.getHeaders},`),r.requestMiddleware&&e.push(`${a}requestMiddleware: ${r.requestMiddleware},`),r.actionParsers&&e.push(`${a}actionParsers: ${r.actionParsers},`),r.actionHandlers&&e.push(`${a}actionHandlers: ${r.actionHandlers},`),r.contextProviders&&e.push(`${a}contextProviders: ${r.contextProviders},`),r.streamParser&&e.push(`${a}streamParser: ${r.streamParser},`)),e}function PI(r,a,e){Object.entries(a).forEach(([t,s])=>{if(!(s===void 0||typeof s=="function")){if(Array.isArray(s)){r.push(`${e}${t}: ${JSON.stringify(s)},`);return}if(s&&typeof s=="object"){r.push(`${e}${t}: {`),PI(r,s,`${e} `),r.push(`${e}},`);return}r.push(`${e}${t}: ${JSON.stringify(s)},`)}})}function ao(r,a,e,t){e&&(r.push(`${t}${a}: {`),PI(r,e,`${t} `),r.push(`${t}},`))}function RI(r,a="esm",e){let t={...r};delete t.postprocessMessage,delete t.initialMessages;let s=e?{...e,hooks:XF(e.hooks)}:void 0;return a==="esm"?QF(t,s):a==="script-installer"?aV(t,s):a==="script-advanced"?oV(t,s):a==="react-component"?eV(t,s):a==="react-advanced"?tV(t,s):rV(t,s)}function QF(r,a){let e=a==null?void 0:a.hooks,t=xk(r),s=t!=="plain",o=["import '@runtypelabs/persona/widget.css';","import { initAgentWidget, markdownPostprocessor } from '@runtypelabs/persona';","","initAgentWidget({"," target: 'body',"," config: {"];return r.apiUrl&&o.push(` apiUrl: "${r.apiUrl}",`),r.clientToken&&o.push(` clientToken: "${r.clientToken}",`),r.flowId&&o.push(` flowId: "${r.flowId}",`),s&&o.push(` parserType: "${t}",`),r.theme&&typeof r.theme=="object"&&Object.keys(r.theme).length>0&&ao(o,"theme",r.theme," "),r.launcher&&ao(o,"launcher",r.launcher," "),r.copy&&(o.push(" copy: {"),Object.entries(r.copy).forEach(([n,l])=>{o.push(` ${n}: "${l}",`)}),o.push(" },")),r.sendButton&&(o.push(" sendButton: {"),Object.entries(r.sendButton).forEach(([n,l])=>{typeof l=="string"?o.push(` ${n}: "${l}",`):typeof l=="boolean"&&o.push(` ${n}: ${l},`)}),o.push(" },")),r.voiceRecognition&&(o.push(" voiceRecognition: {"),Object.entries(r.voiceRecognition).forEach(([n,l])=>{typeof l=="string"?o.push(` ${n}: "${l}",`):typeof l=="boolean"?o.push(` ${n}: ${l},`):typeof l=="number"&&o.push(` ${n}: ${l},`)}),o.push(" },")),r.statusIndicator&&(o.push(" statusIndicator: {"),Object.entries(r.statusIndicator).forEach(([n,l])=>{typeof l=="string"?o.push(` ${n}: "${l}",`):typeof l=="boolean"&&o.push(` ${n}: ${l},`)}),o.push(" },")),r.features&&(o.push(" features: {"),Object.entries(r.features).forEach(([n,l])=>{o.push(` ${n}: ${l},`)}),o.push(" },")),r.suggestionChips&&r.suggestionChips.length>0&&(o.push(" suggestionChips: ["),r.suggestionChips.forEach(n=>{o.push(` "${n}",`)}),o.push(" ],")),r.suggestionChipsConfig&&(o.push(" suggestionChipsConfig: {"),r.suggestionChipsConfig.fontFamily&&o.push(` fontFamily: "${r.suggestionChipsConfig.fontFamily}",`),r.suggestionChipsConfig.fontWeight&&o.push(` fontWeight: "${r.suggestionChipsConfig.fontWeight}",`),r.suggestionChipsConfig.paddingX&&o.push(` paddingX: "${r.suggestionChipsConfig.paddingX}",`),r.suggestionChipsConfig.paddingY&&o.push(` paddingY: "${r.suggestionChipsConfig.paddingY}",`),o.push(" },")),o.push(...gk(r," ")),o.push(...Mk(r," ",e)),o.push(...yk(r," ")),o.push(...vk(r," ")),o.push(...EL(e," ")),r.debug&&o.push(` debug: ${r.debug},`),e!=null&&e.postprocessMessage?o.push(` postprocessMessage: ${e.postprocessMessage}`):o.push(" postprocessMessage: ({ text }) => markdownPostprocessor(text)"),o.push(" }"),o.push("});"),o.join(`
|
|
238
238
|
`)}function eV(r,a){let e=a==null?void 0:a.hooks,t=xk(r),s=t!=="plain",o=["// ChatWidget.tsx","'use client'; // Required for Next.js - remove for Vite/CRA","","import { useEffect } from 'react';","import '@runtypelabs/persona/widget.css';","import { initAgentWidget, markdownPostprocessor } from '@runtypelabs/persona';","import type { AgentWidgetInitHandle } from '@runtypelabs/persona';","","export function ChatWidget() {"," useEffect(() => {"," let handle: AgentWidgetInitHandle | null = null;",""," handle = initAgentWidget({"," target: 'body',"," config: {"];return r.apiUrl&&o.push(` apiUrl: "${r.apiUrl}",`),r.clientToken&&o.push(` clientToken: "${r.clientToken}",`),r.flowId&&o.push(` flowId: "${r.flowId}",`),s&&o.push(` parserType: "${t}",`),r.theme&&typeof r.theme=="object"&&Object.keys(r.theme).length>0&&ao(o,"theme",r.theme," "),r.launcher&&ao(o,"launcher",r.launcher," "),r.copy&&(o.push(" copy: {"),Object.entries(r.copy).forEach(([n,l])=>{o.push(` ${n}: "${l}",`)}),o.push(" },")),r.sendButton&&(o.push(" sendButton: {"),Object.entries(r.sendButton).forEach(([n,l])=>{typeof l=="string"?o.push(` ${n}: "${l}",`):typeof l=="boolean"&&o.push(` ${n}: ${l},`)}),o.push(" },")),r.voiceRecognition&&(o.push(" voiceRecognition: {"),Object.entries(r.voiceRecognition).forEach(([n,l])=>{typeof l=="string"?o.push(` ${n}: "${l}",`):typeof l=="boolean"?o.push(` ${n}: ${l},`):typeof l=="number"&&o.push(` ${n}: ${l},`)}),o.push(" },")),r.statusIndicator&&(o.push(" statusIndicator: {"),Object.entries(r.statusIndicator).forEach(([n,l])=>{typeof l=="string"?o.push(` ${n}: "${l}",`):typeof l=="boolean"&&o.push(` ${n}: ${l},`)}),o.push(" },")),r.features&&(o.push(" features: {"),Object.entries(r.features).forEach(([n,l])=>{o.push(` ${n}: ${l},`)}),o.push(" },")),r.suggestionChips&&r.suggestionChips.length>0&&(o.push(" suggestionChips: ["),r.suggestionChips.forEach(n=>{o.push(` "${n}",`)}),o.push(" ],")),r.suggestionChipsConfig&&(o.push(" suggestionChipsConfig: {"),r.suggestionChipsConfig.fontFamily&&o.push(` fontFamily: "${r.suggestionChipsConfig.fontFamily}",`),r.suggestionChipsConfig.fontWeight&&o.push(` fontWeight: "${r.suggestionChipsConfig.fontWeight}",`),r.suggestionChipsConfig.paddingX&&o.push(` paddingX: "${r.suggestionChipsConfig.paddingX}",`),r.suggestionChipsConfig.paddingY&&o.push(` paddingY: "${r.suggestionChipsConfig.paddingY}",`),o.push(" },")),o.push(...gk(r," ")),o.push(...Mk(r," ",e)),o.push(...yk(r," ")),o.push(...vk(r," ")),o.push(...EL(e," ")),r.debug&&o.push(` debug: ${r.debug},`),e!=null&&e.postprocessMessage?o.push(` postprocessMessage: ${e.postprocessMessage}`):o.push(" postprocessMessage: ({ text }) => markdownPostprocessor(text)"),o.push(" }"),o.push(" });"),o.push(""),o.push(" // Cleanup on unmount"),o.push(" return () => {"),o.push(" if (handle) {"),o.push(" handle.destroy();"),o.push(" }"),o.push(" };"),o.push(" }, []);"),o.push(""),o.push(" return null; // Widget injects itself into the DOM"),o.push("}"),o.push(""),o.push("// Usage in your app:"),o.push("// import { ChatWidget } from './components/ChatWidget';"),o.push("//"),o.push("// export default function App() {"),o.push("// return ("),o.push("// <div>"),o.push("// {/* Your app content */}"),o.push("// <ChatWidget />"),o.push("// </div>"),o.push("// );"),o.push("// }"),o.join(`
|
|
239
239
|
`)}function tV(r,a){let e=a==null?void 0:a.hooks,t=["// ChatWidgetAdvanced.tsx","'use client'; // Required for Next.js - remove for Vite/CRA","","import { useEffect } from 'react';","import '@runtypelabs/persona/widget.css';","import {"," initAgentWidget,"," createFlexibleJsonStreamParser,"," defaultJsonActionParser,"," defaultActionHandlers,"," markdownPostprocessor","} from '@runtypelabs/persona';","import type { AgentWidgetInitHandle } from '@runtypelabs/persona';","","const STORAGE_KEY = 'chat-widget-state';","const PROCESSED_ACTIONS_KEY = 'chat-widget-processed-actions';","","// Types for DOM elements","interface PageElement {"," type: string;"," tagName: string;"," selector: string;"," innerText: string;"," href?: string;","}","","interface DOMContext {"," page_elements: PageElement[];"," page_element_count: number;"," element_types: Record<string, number>;"," page_url: string;"," page_title: string;"," timestamp: string;","}","","// DOM context provider - extracts page elements for AI context","const collectDOMContext = (): DOMContext => {"," const selectors = {",` products: '[data-product-id], .product-card, .product-item, [role="article"]',`,` buttons: 'button, [role="button"], .btn',`," links: 'a[href]',"," inputs: 'input, textarea, select'"," };",""," const elements: PageElement[] = [];"," Object.entries(selectors).forEach(([type, selector]) => {"," document.querySelectorAll(selector).forEach((element) => {"," if (!(element instanceof HTMLElement)) return;"," "," // Exclude elements within the widget"," const widgetHost = element.closest('.persona-host');"," if (widgetHost) return;"," "," const text = element.innerText?.trim();"," if (!text) return;",""," const selectorString ="," element.id ? `#${element.id}` :"," element.getAttribute('data-testid') ? `[data-testid=\"${element.getAttribute('data-testid')}\"]` :"," element.getAttribute('data-product-id') ? `[data-product-id=\"${element.getAttribute('data-product-id')}\"]` :"," element.tagName.toLowerCase();",""," const elementData: PageElement = {"," type,"," tagName: element.tagName.toLowerCase(),"," selector: selectorString,"," innerText: text.substring(0, 200)"," };",""," if (type === 'links' && element instanceof HTMLAnchorElement && element.href) {"," elementData.href = element.href;"," }",""," elements.push(elementData);"," });"," });",""," const counts = elements.reduce((acc, el) => {"," acc[el.type] = (acc[el.type] || 0) + 1;"," return acc;"," }, {} as Record<string, number>);",""," return {"," page_elements: elements.slice(0, 50),"," page_element_count: elements.length,"," element_types: counts,"," page_url: window.location.href,"," page_title: document.title,"," timestamp: new Date().toISOString()"," };","};","","export function ChatWidgetAdvanced() {"," useEffect(() => {"," let handle: AgentWidgetInitHandle | null = null;",""," // Load saved state"," const loadSavedMessages = () => {"," const savedState = localStorage.getItem(STORAGE_KEY);"," if (savedState) {"," try {"," const { messages } = JSON.parse(savedState);"," return messages || [];"," } catch (e) {"," console.error('Failed to load saved state:', e);"," }"," }"," return [];"," };",""," handle = initAgentWidget({"," target: 'body',"," config: {"];return r.apiUrl&&t.push(` apiUrl: "${r.apiUrl}",`),r.clientToken&&t.push(` clientToken: "${r.clientToken}",`),r.flowId&&t.push(` flowId: "${r.flowId}",`),r.theme&&typeof r.theme=="object"&&Object.keys(r.theme).length>0&&ao(t,"theme",r.theme," "),r.launcher&&ao(t,"launcher",r.launcher," "),r.copy&&(t.push(" copy: {"),Object.entries(r.copy).forEach(([s,o])=>{t.push(` ${s}: "${o}",`)}),t.push(" },")),r.sendButton&&(t.push(" sendButton: {"),Object.entries(r.sendButton).forEach(([s,o])=>{typeof o=="string"?t.push(` ${s}: "${o}",`):typeof o=="boolean"&&t.push(` ${s}: ${o},`)}),t.push(" },")),r.voiceRecognition&&(t.push(" voiceRecognition: {"),Object.entries(r.voiceRecognition).forEach(([s,o])=>{typeof o=="string"?t.push(` ${s}: "${o}",`):typeof o=="boolean"?t.push(` ${s}: ${o},`):typeof o=="number"&&t.push(` ${s}: ${o},`)}),t.push(" },")),r.statusIndicator&&(t.push(" statusIndicator: {"),Object.entries(r.statusIndicator).forEach(([s,o])=>{typeof o=="string"?t.push(` ${s}: "${o}",`):typeof o=="boolean"&&t.push(` ${s}: ${o},`)}),t.push(" },")),r.features&&(t.push(" features: {"),Object.entries(r.features).forEach(([s,o])=>{t.push(` ${s}: ${o},`)}),t.push(" },")),r.suggestionChips&&r.suggestionChips.length>0&&(t.push(" suggestionChips: ["),r.suggestionChips.forEach(s=>{t.push(` "${s}",`)}),t.push(" ],")),r.suggestionChipsConfig&&(t.push(" suggestionChipsConfig: {"),r.suggestionChipsConfig.fontFamily&&t.push(` fontFamily: "${r.suggestionChipsConfig.fontFamily}",`),r.suggestionChipsConfig.fontWeight&&t.push(` fontWeight: "${r.suggestionChipsConfig.fontWeight}",`),r.suggestionChipsConfig.paddingX&&t.push(` paddingX: "${r.suggestionChipsConfig.paddingX}",`),r.suggestionChipsConfig.paddingY&&t.push(` paddingY: "${r.suggestionChipsConfig.paddingY}",`),t.push(" },")),t.push(...gk(r," ")),t.push(...Mk(r," ",e)),t.push(...yk(r," ")),t.push(...vk(r," ")),e!=null&&e.getHeaders&&t.push(` getHeaders: ${e.getHeaders},`),e!=null&&e.contextProviders&&t.push(` contextProviders: ${e.contextProviders},`),r.debug&&t.push(` debug: ${r.debug},`),t.push(" initialMessages: loadSavedMessages(),"),e!=null&&e.streamParser?t.push(` streamParser: ${e.streamParser},`):(t.push(" // Flexible JSON stream parser for handling structured actions"),t.push(` streamParser: () => createFlexibleJsonStreamParser(${JF}),`)),e!=null&&e.actionParsers?(t.push(" // Action parsers (custom merged with defaults)"),t.push(` actionParsers: [...(${e.actionParsers}), defaultJsonActionParser,`),t.push(" // Built-in parser for markdown-wrapped JSON"),t.push(` ${kI}`),t.push(" ],")):(t.push(" // Action parsers to detect JSON actions in responses"),t.push(" actionParsers: ["),t.push(" defaultJsonActionParser,"),t.push(" // Parser for markdown-wrapped JSON"),t.push(` ${kI}`),t.push(" ],")),e!=null&&e.actionHandlers?(t.push(" // Action handlers (custom merged with defaults)"),t.push(` actionHandlers: [...(${e.actionHandlers}),`),t.push(" defaultActionHandlers.message,"),t.push(" defaultActionHandlers.messageAndClick,"),t.push(" // Built-in handler for nav_then_click action"),t.push(` ${EI}`),t.push(" ],")):(t.push(" // Action handlers for navigation and other actions"),t.push(" actionHandlers: ["),t.push(" defaultActionHandlers.message,"),t.push(" defaultActionHandlers.messageAndClick,"),t.push(" // Handler for nav_then_click action"),t.push(` ${EI}`),t.push(" ],")),e!=null&&e.postprocessMessage?t.push(` postprocessMessage: ${e.postprocessMessage},`):t.push(" postprocessMessage: ({ text }) => markdownPostprocessor(text),"),e!=null&&e.requestMiddleware?(t.push(" // Request middleware (custom merged with DOM context)"),t.push(" requestMiddleware: ({ payload, config }) => {"),t.push(` const customResult = (${e.requestMiddleware})({ payload, config });`),t.push(" const merged = customResult || payload;"),t.push(" return {"),t.push(" ...merged,"),t.push(" metadata: { ...merged.metadata, ...collectDOMContext() }"),t.push(" };"),t.push(" }")):(t.push(" requestMiddleware: ({ payload }) => {"),t.push(" return {"),t.push(" ...payload,"),t.push(" metadata: collectDOMContext()"),t.push(" };"),t.push(" }")),t.push(" }"),t.push(" });"),t.push(""),t.push(" // Save state on message events"),t.push(" const handleMessage = () => {"),t.push(" const session = handle?.getSession?.();"),t.push(" if (session) {"),t.push(" localStorage.setItem(STORAGE_KEY, JSON.stringify({"),t.push(" messages: session.messages,"),t.push(" timestamp: new Date().toISOString()"),t.push(" }));"),t.push(" }"),t.push(" };"),t.push(""),t.push(" // Clear state on clear chat"),t.push(" const handleClearChat = () => {"),t.push(" localStorage.removeItem(STORAGE_KEY);"),t.push(" localStorage.removeItem(PROCESSED_ACTIONS_KEY);"),t.push(" };"),t.push(""),t.push(" window.addEventListener('persona:message', handleMessage);"),t.push(" window.addEventListener('persona:clear-chat', handleClearChat);"),t.push(""),t.push(" // Cleanup on unmount"),t.push(" return () => {"),t.push(" window.removeEventListener('persona:message', handleMessage);"),t.push(" window.removeEventListener('persona:clear-chat', handleClearChat);"),t.push(" if (handle) {"),t.push(" handle.destroy();"),t.push(" }"),t.push(" };"),t.push(" }, []);"),t.push(""),t.push(" return null; // Widget injects itself into the DOM"),t.push("}"),t.push(""),t.push("// Usage: Collects DOM context for AI-powered navigation"),t.push("// Features:"),t.push("// - Extracts page elements (products, buttons, links)"),t.push("// - Persists chat history across page loads"),t.push("// - Handles navigation actions (nav_then_click)"),t.push("// - Processes structured JSON actions from AI"),t.push("//"),t.push("// Example usage in Next.js:"),t.push("// import { ChatWidgetAdvanced } from './components/ChatWidgetAdvanced';"),t.push("//"),t.push("// export default function RootLayout({ children }) {"),t.push("// return ("),t.push('// <html lang="en">'),t.push("// <body>"),t.push("// {children}"),t.push("// <ChatWidgetAdvanced />"),t.push("// </body>"),t.push("// </html>"),t.push("// );"),t.push("// }"),t.join(`
|
|
240
|
-
`)}function II(r){var s;let a=xk(r),e=a!=="plain",t={};if(r.apiUrl&&(t.apiUrl=r.apiUrl),r.clientToken&&(t.clientToken=r.clientToken),r.flowId&&(t.flowId=r.flowId),e&&(t.parserType=a),r.theme&&(t.theme=r.theme),r.launcher&&(t.launcher=r.launcher),r.copy&&(t.copy=r.copy),r.sendButton&&(t.sendButton=r.sendButton),r.voiceRecognition&&(t.voiceRecognition=r.voiceRecognition),r.statusIndicator&&(t.statusIndicator=r.statusIndicator),r.features&&(t.features=r.features),((s=r.suggestionChips)==null?void 0:s.length)>0&&(t.suggestionChips=r.suggestionChips),r.suggestionChipsConfig&&(t.suggestionChipsConfig=r.suggestionChipsConfig),r.debug&&(t.debug=r.debug),r.toolCall){let o={};Object.entries(r.toolCall).forEach(([n,l])=>{typeof l=="string"&&(o[n]=l)}),Object.keys(o).length>0&&(t.toolCall=o)}if(r.messageActions){let o={};Object.entries(r.messageActions).forEach(([n,l])=>{n!=="onFeedback"&&n!=="onCopy"&&l!==void 0&&(typeof l=="string"||typeof l=="boolean")&&(o[n]=l)}),Object.keys(o).length>0&&(t.messageActions=o)}if(r.markdown){let o={};r.markdown.options&&(o.options=r.markdown.options),r.markdown.disableDefaultStyles!==void 0&&(o.disableDefaultStyles=r.markdown.disableDefaultStyles),Object.keys(o).length>0&&(t.markdown=o)}if(r.layout){let o={};if(r.layout.header){let n={};Object.entries(r.layout.header).forEach(([l,p])=>{l!=="render"&&(typeof p=="string"||typeof p=="boolean")&&(n[l]=p)}),Object.keys(n).length>0&&(o.header=n)}if(r.layout.messages){let n={};Object.entries(r.layout.messages).forEach(([l,p])=>{if(l!=="renderUserMessage"&&l!=="renderAssistantMessage")if(l==="avatar"&&typeof p=="object"&&p!==null)n.avatar=p;else if(l==="timestamp"&&typeof p=="object"&&p!==null){let i={};Object.entries(p).forEach(([u,c])=>{u!=="format"&&(typeof c=="string"||typeof c=="boolean")&&(i[u]=c)}),Object.keys(i).length>0&&(n.timestamp=i)}else(typeof p=="string"||typeof p=="boolean")&&(n[l]=p)}),Object.keys(n).length>0&&(o.messages=n)}Object.keys(o).length>0&&(t.layout=o)}return t}function aV(r){let
|
|
240
|
+
`)}function II(r){var s;let a=xk(r),e=a!=="plain",t={};if(r.apiUrl&&(t.apiUrl=r.apiUrl),r.clientToken&&(t.clientToken=r.clientToken),r.flowId&&(t.flowId=r.flowId),e&&(t.parserType=a),r.theme&&(t.theme=r.theme),r.launcher&&(t.launcher=r.launcher),r.copy&&(t.copy=r.copy),r.sendButton&&(t.sendButton=r.sendButton),r.voiceRecognition&&(t.voiceRecognition=r.voiceRecognition),r.statusIndicator&&(t.statusIndicator=r.statusIndicator),r.features&&(t.features=r.features),((s=r.suggestionChips)==null?void 0:s.length)>0&&(t.suggestionChips=r.suggestionChips),r.suggestionChipsConfig&&(t.suggestionChipsConfig=r.suggestionChipsConfig),r.debug&&(t.debug=r.debug),r.toolCall){let o={};Object.entries(r.toolCall).forEach(([n,l])=>{typeof l=="string"&&(o[n]=l)}),Object.keys(o).length>0&&(t.toolCall=o)}if(r.messageActions){let o={};Object.entries(r.messageActions).forEach(([n,l])=>{n!=="onFeedback"&&n!=="onCopy"&&l!==void 0&&(typeof l=="string"||typeof l=="boolean")&&(o[n]=l)}),Object.keys(o).length>0&&(t.messageActions=o)}if(r.markdown){let o={};r.markdown.options&&(o.options=r.markdown.options),r.markdown.disableDefaultStyles!==void 0&&(o.disableDefaultStyles=r.markdown.disableDefaultStyles),Object.keys(o).length>0&&(t.markdown=o)}if(r.layout){let o={};if(r.layout.header){let n={};Object.entries(r.layout.header).forEach(([l,p])=>{l!=="render"&&(typeof p=="string"||typeof p=="boolean")&&(n[l]=p)}),Object.keys(n).length>0&&(o.header=n)}if(r.layout.messages){let n={};Object.entries(r.layout.messages).forEach(([l,p])=>{if(l!=="renderUserMessage"&&l!=="renderAssistantMessage")if(l==="avatar"&&typeof p=="object"&&p!==null)n.avatar=p;else if(l==="timestamp"&&typeof p=="object"&&p!==null){let i={};Object.entries(p).forEach(([u,c])=>{u!=="format"&&(typeof c=="string"||typeof c=="boolean")&&(i[u]=c)}),Object.keys(i).length>0&&(n.timestamp=i)}else(typeof p=="string"||typeof p=="boolean")&&(n[l]=p)}),Object.keys(n).length>0&&(o.messages=n)}Object.keys(o).length>0&&(t.layout=o)}return t}function aV(r,a){let e=II(r),t=a!=null&&a.windowKey?{config:e,windowKey:a.windowKey}:e,s=JSON.stringify(t,null,0).replace(/'/g,"'");return`<script src="https://cdn.jsdelivr.net/npm/@runtypelabs/persona@${ko}/dist/install.global.js" data-config='${s}'></script>`}function rV(r,a){let e=a==null?void 0:a.hooks,t=xk(r),s=t!=="plain",o=["<!-- Load CSS -->",`<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@runtypelabs/persona@${ko}/dist/widget.css" />`,"","<!-- Load JavaScript -->",`<script src="https://cdn.jsdelivr.net/npm/@runtypelabs/persona@${ko}/dist/index.global.js"></script>`,"","<!-- Initialize widget -->","<script>"," var handle = window.AgentWidget.initAgentWidget({"," target: 'body',",...a!=null&&a.windowKey?[` windowKey: '${a.windowKey}',`]:[]," config: {"];return r.apiUrl&&o.push(` apiUrl: "${r.apiUrl}",`),r.clientToken&&o.push(` clientToken: "${r.clientToken}",`),r.flowId&&o.push(` flowId: "${r.flowId}",`),s&&o.push(` parserType: "${t}",`),r.theme&&typeof r.theme=="object"&&Object.keys(r.theme).length>0&&ao(o,"theme",r.theme," "),r.launcher&&ao(o,"launcher",r.launcher," "),r.copy&&(o.push(" copy: {"),Object.entries(r.copy).forEach(([n,l])=>{o.push(` ${n}: "${l}",`)}),o.push(" },")),r.sendButton&&(o.push(" sendButton: {"),Object.entries(r.sendButton).forEach(([n,l])=>{typeof l=="string"?o.push(` ${n}: "${l}",`):typeof l=="boolean"&&o.push(` ${n}: ${l},`)}),o.push(" },")),r.voiceRecognition&&(o.push(" voiceRecognition: {"),Object.entries(r.voiceRecognition).forEach(([n,l])=>{typeof l=="string"?o.push(` ${n}: "${l}",`):typeof l=="boolean"?o.push(` ${n}: ${l},`):typeof l=="number"&&o.push(` ${n}: ${l},`)}),o.push(" },")),r.statusIndicator&&(o.push(" statusIndicator: {"),Object.entries(r.statusIndicator).forEach(([n,l])=>{typeof l=="string"?o.push(` ${n}: "${l}",`):typeof l=="boolean"&&o.push(` ${n}: ${l},`)}),o.push(" },")),r.features&&(o.push(" features: {"),Object.entries(r.features).forEach(([n,l])=>{o.push(` ${n}: ${l},`)}),o.push(" },")),r.suggestionChips&&r.suggestionChips.length>0&&(o.push(" suggestionChips: ["),r.suggestionChips.forEach(n=>{o.push(` "${n}",`)}),o.push(" ],")),r.suggestionChipsConfig&&(o.push(" suggestionChipsConfig: {"),r.suggestionChipsConfig.fontFamily&&o.push(` fontFamily: "${r.suggestionChipsConfig.fontFamily}",`),r.suggestionChipsConfig.fontWeight&&o.push(` fontWeight: "${r.suggestionChipsConfig.fontWeight}",`),r.suggestionChipsConfig.paddingX&&o.push(` paddingX: "${r.suggestionChipsConfig.paddingX}",`),r.suggestionChipsConfig.paddingY&&o.push(` paddingY: "${r.suggestionChipsConfig.paddingY}",`),o.push(" },")),o.push(...gk(r," ")),o.push(...Mk(r," ",e)),o.push(...yk(r," ")),o.push(...vk(r," ")),o.push(...EL(e," ")),r.debug&&o.push(` debug: ${r.debug},`),e!=null&&e.postprocessMessage?o.push(` postprocessMessage: ${e.postprocessMessage}`):o.push(" postprocessMessage: ({ text }) => window.AgentWidget.markdownPostprocessor(text)"),o.push(" }"),o.push(" });"),o.push("</script>"),o.join(`
|
|
241
241
|
`)}function oV(r,a){let e=a==null?void 0:a.hooks,t=II(r),o=["<script>","(function() {"," 'use strict';",""," // Configuration",` var CONFIG = ${JSON.stringify(t,null,2).split(`
|
|
242
242
|
`).map((n,l)=>l===0?n:" "+n).join(`
|
|
243
|
-
`)};`,""," // Constants",` var CDN_BASE = 'https://cdn.jsdelivr.net/npm/@runtypelabs/persona@${ko}/dist';`," var STORAGE_KEY = 'chat-widget-state';"," var PROCESSED_ACTIONS_KEY = 'chat-widget-processed-actions';",""," // DOM context provider - extracts page elements for AI context"," var domContextProvider = function() {"," var selectors = {",` products: '[data-product-id], .product-card, .product-item, [role="article"]',`,` buttons: 'button, [role="button"], .btn',`," links: 'a[href]',"," inputs: 'input, textarea, select'"," };",""," var elements = [];"," Object.entries(selectors).forEach(function(entry) {"," var type = entry[0], selector = entry[1];"," document.querySelectorAll(selector).forEach(function(element) {"," if (!(element instanceof HTMLElement)) return;"," var widgetHost = element.closest('.persona-host');"," if (widgetHost) return;"," var text = element.innerText ? element.innerText.trim() : '';"," if (!text) return;",""," var selectorString = element.id ? '#' + element.id :",` element.getAttribute('data-testid') ? '[data-testid="' + element.getAttribute('data-testid') + '"]' :`,` element.getAttribute('data-product-id') ? '[data-product-id="' + element.getAttribute('data-product-id') + '"]' :`," element.tagName.toLowerCase();",""," var elementData = {"," type: type,"," tagName: element.tagName.toLowerCase(),"," selector: selectorString,"," innerText: text.substring(0, 200)"," };",""," if (type === 'links' && element instanceof HTMLAnchorElement && element.href) {"," elementData.href = element.href;"," }"," elements.push(elementData);"," });"," });",""," var counts = elements.reduce(function(acc, el) {"," acc[el.type] = (acc[el.type] || 0) + 1;"," return acc;"," }, {});",""," return {"," page_elements: elements.slice(0, 50),"," page_element_count: elements.length,"," element_types: counts,"," page_url: window.location.href,"," page_title: document.title,"," timestamp: new Date().toISOString()"," };"," };",""," // Load CSS dynamically"," var loadCSS = function() {"," if (document.querySelector('link[data-persona]')) return;"," var link = document.createElement('link');"," link.rel = 'stylesheet';"," link.href = CDN_BASE + '/widget.css';"," link.setAttribute('data-persona', 'true');"," document.head.appendChild(link);"," };",""," // Load JS dynamically"," var loadJS = function(callback) {"," if (window.AgentWidget) { callback(); return; }"," var script = document.createElement('script');"," script.src = CDN_BASE + '/index.global.js';"," script.onload = callback;"," script.onerror = function() { console.error('Failed to load AgentWidget'); };"," document.head.appendChild(script);"," };",""," // Create widget config with advanced features"," var createWidgetConfig = function(agentWidget) {"," var widgetConfig = Object.assign({}, CONFIG);",""];return e!=null&&e.getHeaders&&(o.push(` widgetConfig.getHeaders = ${e.getHeaders};`),o.push("")),e!=null&&e.contextProviders&&(o.push(` widgetConfig.contextProviders = ${e.contextProviders};`),o.push("")),e!=null&&e.streamParser?o.push(` widgetConfig.streamParser = ${e.streamParser};`):(o.push(" // Flexible JSON stream parser for handling structured actions"),o.push(" widgetConfig.streamParser = function() {"),o.push(` return agentWidget.createFlexibleJsonStreamParser(${KF});`),o.push(" };")),o.push(""),e!=null&&e.actionParsers?(o.push(" // Action parsers (custom merged with defaults)"),o.push(` var customParsers = ${e.actionParsers};`),o.push(" widgetConfig.actionParsers = customParsers.concat(["),o.push(" agentWidget.defaultJsonActionParser,"),o.push(` ${LI}`),o.push(" ]);")):(o.push(" // Action parsers to detect JSON actions in responses"),o.push(" widgetConfig.actionParsers = ["),o.push(" agentWidget.defaultJsonActionParser,"),o.push(` ${LI}`),o.push(" ];")),o.push(""),e!=null&&e.actionHandlers?(o.push(" // Action handlers (custom merged with defaults)"),o.push(` var customHandlers = ${e.actionHandlers};`),o.push(" widgetConfig.actionHandlers = customHandlers.concat(["),o.push(" agentWidget.defaultActionHandlers.message,"),o.push(" agentWidget.defaultActionHandlers.messageAndClick,"),o.push(` ${HI}`),o.push(" ]);")):(o.push(" // Action handlers for navigation and other actions"),o.push(" widgetConfig.actionHandlers = ["),o.push(" agentWidget.defaultActionHandlers.message,"),o.push(" agentWidget.defaultActionHandlers.messageAndClick,"),o.push(` ${HI}`),o.push(" ];")),o.push(""),e!=null&&e.requestMiddleware?(o.push(" // Request middleware (custom merged with DOM context)"),o.push(" widgetConfig.requestMiddleware = function(ctx) {"),o.push(` var customResult = (${e.requestMiddleware})(ctx);`),o.push(" var merged = customResult || ctx.payload;"),o.push(" return Object.assign({}, merged, { metadata: Object.assign({}, merged.metadata, domContextProvider()) });"),o.push(" };")):(o.push(" // Send DOM context with each request"),o.push(" widgetConfig.requestMiddleware = function(ctx) {"),o.push(" return Object.assign({}, ctx.payload, { metadata: domContextProvider() });"),o.push(" };")),o.push(""),e!=null&&e.postprocessMessage?o.push(` widgetConfig.postprocessMessage = ${e.postprocessMessage};`):(o.push(" // Markdown postprocessor"),o.push(" widgetConfig.postprocessMessage = function(ctx) {"),o.push(" return agentWidget.markdownPostprocessor(ctx.text);"),o.push(" };")),o.push(""),(e!=null&&e.onFeedback||e!=null&&e.onCopy)&&(o.push(" // Message action callbacks"),o.push(" widgetConfig.messageActions = widgetConfig.messageActions || {};"),e!=null&&e.onFeedback&&o.push(` widgetConfig.messageActions.onFeedback = ${e.onFeedback};`),e!=null&&e.onCopy&&o.push(` widgetConfig.messageActions.onCopy = ${e.onCopy};`),o.push("")),o.push(" return widgetConfig;"," };",""," // Initialize widget"," var init = function() {"," var agentWidget = window.AgentWidget;"," if (!agentWidget) {"," console.error('AgentWidget not loaded');"," return;"," }",""," var widgetConfig = createWidgetConfig(agentWidget);",""," // Load saved state"," var savedState = localStorage.getItem(STORAGE_KEY);"," if (savedState) {"," try {"," var parsed = JSON.parse(savedState);"," widgetConfig.initialMessages = parsed.messages || [];"," } catch (e) {"," console.error('Failed to load saved state:', e);"," }"," }",""," // Initialize widget"," var handle = agentWidget.initAgentWidget({"," target: 'body',"," useShadowDom: false,"," config: widgetConfig"," });",""," // Save state on message events"," window.addEventListener('persona:message', function() {"," var session = handle.getSession ? handle.getSession() : null;"," if (session) {"," localStorage.setItem(STORAGE_KEY, JSON.stringify({"," messages: session.messages,"," timestamp: new Date().toISOString()"," }));"," }"," });",""," // Clear state on clear chat"," window.addEventListener('persona:clear-chat', function() {"," localStorage.removeItem(STORAGE_KEY);"," localStorage.removeItem(PROCESSED_ACTIONS_KEY);"," });"," };",""," // Wait for framework hydration to complete (Next.js, Nuxt, etc.)"," // This prevents the framework from removing dynamically added CSS during reconciliation"," var waitForHydration = function(callback) {"," var executed = false;"," "," var execute = function() {"," if (executed) return;"," executed = true;"," callback();"," };",""," var afterDom = function() {"," // Strategy 1: Use requestIdleCallback if available (best for detecting idle after hydration)"," if (typeof requestIdleCallback !== 'undefined') {"," requestIdleCallback(function() {"," // Double requestAnimationFrame ensures at least one full paint cycle completed"," requestAnimationFrame(function() {"," requestAnimationFrame(execute);"," });"," }, { timeout: 3000 }); // Max wait 3 seconds, then proceed anyway"," } else {"," // Strategy 2: Fallback for Safari (no requestIdleCallback)"," // 300ms is typically enough for hydration on most pages"," setTimeout(execute, 300);"," }"," };",""," if (document.readyState === 'loading') {"," document.addEventListener('DOMContentLoaded', afterDom);"," } else {"," // DOM already ready, but still wait for potential hydration"," afterDom();"," }"," };",""," // Boot sequence: wait for hydration, then load CSS and JS, then initialize"," // This prevents Next.js/Nuxt/etc. from removing dynamically added CSS during reconciliation"," waitForHydration(function() {"," loadCSS();"," loadJS(function() {"," init();"," });"," });","})();","</script>"),o.join(`
|
|
243
|
+
`)};`,""," // Constants",` var CDN_BASE = 'https://cdn.jsdelivr.net/npm/@runtypelabs/persona@${ko}/dist';`," var STORAGE_KEY = 'chat-widget-state';"," var PROCESSED_ACTIONS_KEY = 'chat-widget-processed-actions';",""," // DOM context provider - extracts page elements for AI context"," var domContextProvider = function() {"," var selectors = {",` products: '[data-product-id], .product-card, .product-item, [role="article"]',`,` buttons: 'button, [role="button"], .btn',`," links: 'a[href]',"," inputs: 'input, textarea, select'"," };",""," var elements = [];"," Object.entries(selectors).forEach(function(entry) {"," var type = entry[0], selector = entry[1];"," document.querySelectorAll(selector).forEach(function(element) {"," if (!(element instanceof HTMLElement)) return;"," var widgetHost = element.closest('.persona-host');"," if (widgetHost) return;"," var text = element.innerText ? element.innerText.trim() : '';"," if (!text) return;",""," var selectorString = element.id ? '#' + element.id :",` element.getAttribute('data-testid') ? '[data-testid="' + element.getAttribute('data-testid') + '"]' :`,` element.getAttribute('data-product-id') ? '[data-product-id="' + element.getAttribute('data-product-id') + '"]' :`," element.tagName.toLowerCase();",""," var elementData = {"," type: type,"," tagName: element.tagName.toLowerCase(),"," selector: selectorString,"," innerText: text.substring(0, 200)"," };",""," if (type === 'links' && element instanceof HTMLAnchorElement && element.href) {"," elementData.href = element.href;"," }"," elements.push(elementData);"," });"," });",""," var counts = elements.reduce(function(acc, el) {"," acc[el.type] = (acc[el.type] || 0) + 1;"," return acc;"," }, {});",""," return {"," page_elements: elements.slice(0, 50),"," page_element_count: elements.length,"," element_types: counts,"," page_url: window.location.href,"," page_title: document.title,"," timestamp: new Date().toISOString()"," };"," };",""," // Load CSS dynamically"," var loadCSS = function() {"," if (document.querySelector('link[data-persona]')) return;"," var link = document.createElement('link');"," link.rel = 'stylesheet';"," link.href = CDN_BASE + '/widget.css';"," link.setAttribute('data-persona', 'true');"," document.head.appendChild(link);"," };",""," // Load JS dynamically"," var loadJS = function(callback) {"," if (window.AgentWidget) { callback(); return; }"," var script = document.createElement('script');"," script.src = CDN_BASE + '/index.global.js';"," script.onload = callback;"," script.onerror = function() { console.error('Failed to load AgentWidget'); };"," document.head.appendChild(script);"," };",""," // Create widget config with advanced features"," var createWidgetConfig = function(agentWidget) {"," var widgetConfig = Object.assign({}, CONFIG);",""];return e!=null&&e.getHeaders&&(o.push(` widgetConfig.getHeaders = ${e.getHeaders};`),o.push("")),e!=null&&e.contextProviders&&(o.push(` widgetConfig.contextProviders = ${e.contextProviders};`),o.push("")),e!=null&&e.streamParser?o.push(` widgetConfig.streamParser = ${e.streamParser};`):(o.push(" // Flexible JSON stream parser for handling structured actions"),o.push(" widgetConfig.streamParser = function() {"),o.push(` return agentWidget.createFlexibleJsonStreamParser(${KF});`),o.push(" };")),o.push(""),e!=null&&e.actionParsers?(o.push(" // Action parsers (custom merged with defaults)"),o.push(` var customParsers = ${e.actionParsers};`),o.push(" widgetConfig.actionParsers = customParsers.concat(["),o.push(" agentWidget.defaultJsonActionParser,"),o.push(` ${LI}`),o.push(" ]);")):(o.push(" // Action parsers to detect JSON actions in responses"),o.push(" widgetConfig.actionParsers = ["),o.push(" agentWidget.defaultJsonActionParser,"),o.push(` ${LI}`),o.push(" ];")),o.push(""),e!=null&&e.actionHandlers?(o.push(" // Action handlers (custom merged with defaults)"),o.push(` var customHandlers = ${e.actionHandlers};`),o.push(" widgetConfig.actionHandlers = customHandlers.concat(["),o.push(" agentWidget.defaultActionHandlers.message,"),o.push(" agentWidget.defaultActionHandlers.messageAndClick,"),o.push(` ${HI}`),o.push(" ]);")):(o.push(" // Action handlers for navigation and other actions"),o.push(" widgetConfig.actionHandlers = ["),o.push(" agentWidget.defaultActionHandlers.message,"),o.push(" agentWidget.defaultActionHandlers.messageAndClick,"),o.push(` ${HI}`),o.push(" ];")),o.push(""),e!=null&&e.requestMiddleware?(o.push(" // Request middleware (custom merged with DOM context)"),o.push(" widgetConfig.requestMiddleware = function(ctx) {"),o.push(` var customResult = (${e.requestMiddleware})(ctx);`),o.push(" var merged = customResult || ctx.payload;"),o.push(" return Object.assign({}, merged, { metadata: Object.assign({}, merged.metadata, domContextProvider()) });"),o.push(" };")):(o.push(" // Send DOM context with each request"),o.push(" widgetConfig.requestMiddleware = function(ctx) {"),o.push(" return Object.assign({}, ctx.payload, { metadata: domContextProvider() });"),o.push(" };")),o.push(""),e!=null&&e.postprocessMessage?o.push(` widgetConfig.postprocessMessage = ${e.postprocessMessage};`):(o.push(" // Markdown postprocessor"),o.push(" widgetConfig.postprocessMessage = function(ctx) {"),o.push(" return agentWidget.markdownPostprocessor(ctx.text);"),o.push(" };")),o.push(""),(e!=null&&e.onFeedback||e!=null&&e.onCopy)&&(o.push(" // Message action callbacks"),o.push(" widgetConfig.messageActions = widgetConfig.messageActions || {};"),e!=null&&e.onFeedback&&o.push(` widgetConfig.messageActions.onFeedback = ${e.onFeedback};`),e!=null&&e.onCopy&&o.push(` widgetConfig.messageActions.onCopy = ${e.onCopy};`),o.push("")),o.push(" return widgetConfig;"," };",""," // Initialize widget"," var init = function() {"," var agentWidget = window.AgentWidget;"," if (!agentWidget) {"," console.error('AgentWidget not loaded');"," return;"," }",""," var widgetConfig = createWidgetConfig(agentWidget);",""," // Load saved state"," var savedState = localStorage.getItem(STORAGE_KEY);"," if (savedState) {"," try {"," var parsed = JSON.parse(savedState);"," widgetConfig.initialMessages = parsed.messages || [];"," } catch (e) {"," console.error('Failed to load saved state:', e);"," }"," }",""," // Initialize widget"," var handle = agentWidget.initAgentWidget({"," target: 'body',"," useShadowDom: false,",...a!=null&&a.windowKey?[` windowKey: '${a.windowKey}',`]:[]," config: widgetConfig"," });",""," // Save state on message events"," window.addEventListener('persona:message', function() {"," var session = handle.getSession ? handle.getSession() : null;"," if (session) {"," localStorage.setItem(STORAGE_KEY, JSON.stringify({"," messages: session.messages,"," timestamp: new Date().toISOString()"," }));"," }"," });",""," // Clear state on clear chat"," window.addEventListener('persona:clear-chat', function() {"," localStorage.removeItem(STORAGE_KEY);"," localStorage.removeItem(PROCESSED_ACTIONS_KEY);"," });"," };",""," // Wait for framework hydration to complete (Next.js, Nuxt, etc.)"," // This prevents the framework from removing dynamically added CSS during reconciliation"," var waitForHydration = function(callback) {"," var executed = false;"," "," var execute = function() {"," if (executed) return;"," executed = true;"," callback();"," };",""," var afterDom = function() {"," // Strategy 1: Use requestIdleCallback if available (best for detecting idle after hydration)"," if (typeof requestIdleCallback !== 'undefined') {"," requestIdleCallback(function() {"," // Double requestAnimationFrame ensures at least one full paint cycle completed"," requestAnimationFrame(function() {"," requestAnimationFrame(execute);"," });"," }, { timeout: 3000 }); // Max wait 3 seconds, then proceed anyway"," } else {"," // Strategy 2: Fallback for Safari (no requestIdleCallback)"," // 300ms is typically enough for hydration on most pages"," setTimeout(execute, 300);"," }"," };",""," if (document.readyState === 'loading') {"," document.addEventListener('DOMContentLoaded', afterDom);"," } else {"," // DOM already ready, but still wait for potential hydration"," afterDom();"," }"," };",""," // Boot sequence: wait for hydration, then load CSS and JS, then initialize"," // This prevents Next.js/Nuxt/etc. from removing dynamically added CSS during reconciliation"," waitForHydration(function() {"," loadCSS();"," loadJS(function() {"," init();"," });"," });","})();","</script>"),o.join(`
|
|
244
244
|
`)}var BI={desktop:{w:1280,h:800},mobile:{w:390,h:844}},DI=.1,FI=.15,VI=1.5,HL=24,WI=40,sV=`
|
|
245
245
|
/* \u2500\u2500 Root \u2500\u2500 */
|
|
246
246
|
.persona-dc-root {
|