@auticlabs/bulut 1.2.3 → 1.2.4

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.
@@ -1 +1 @@
1
- {"version":3,"file":"embed.cjs","sources":["../node_modules/preact/dist/preact.module.js","../node_modules/preact/jsx-runtime/dist/jsxRuntime.module.js","../node_modules/preact/hooks/dist/hooks.module.js","../src/styles/constants.ts","../src/assets.ts","../src/assets/icons/microphone.svg?raw","../src/assets/icons/close.svg?raw","../src/assets/icons/stop.svg?raw","../src/components/SvgIcon.tsx","../src/components/ChatButton.tsx","../src/agent/context.ts","../src/agent/contextConfig.ts","../src/agent/tools.ts","../src/api/client.ts","../src/audio/sfxManager.ts","../src/assets/sfx/sent.mp3","../src/assets/sfx/thinking.mp3","../src/assets/sfx/tool_call.mp3","../src/assets/sfx/completed.mp3","../src/components/ChatWindow.tsx","../src/assets/icons/bulut_logo.svg?raw","../src/assets/icons/restart.svg?raw","../src/index.tsx"],"sourcesContent":["var n,l,u,t,i,o,r,e,f,c,s,a,h,p={},v=[],y=/acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i,d=Array.isArray;function w(n,l){for(var u in l)n[u]=l[u];return n}function g(n){n&&n.parentNode&&n.parentNode.removeChild(n)}function _(l,u,t){var i,o,r,e={};for(r in u)\"key\"==r?i=u[r]:\"ref\"==r?o=u[r]:e[r]=u[r];if(arguments.length>2&&(e.children=arguments.length>3?n.call(arguments,2):t),\"function\"==typeof l&&null!=l.defaultProps)for(r in l.defaultProps)void 0===e[r]&&(e[r]=l.defaultProps[r]);return m(l,e,i,o,null)}function m(n,t,i,o,r){var e={type:n,props:t,key:i,ref:o,__k:null,__:null,__b:0,__e:null,__c:null,constructor:void 0,__v:null==r?++u:r,__i:-1,__u:0};return null==r&&null!=l.vnode&&l.vnode(e),e}function b(){return{current:null}}function k(n){return n.children}function x(n,l){this.props=n,this.context=l}function S(n,l){if(null==l)return n.__?S(n.__,n.__i+1):null;for(var u;l<n.__k.length;l++)if(null!=(u=n.__k[l])&&null!=u.__e)return u.__e;return\"function\"==typeof n.type?S(n):null}function C(n){var l,u;if(null!=(n=n.__)&&null!=n.__c){for(n.__e=n.__c.base=null,l=0;l<n.__k.length;l++)if(null!=(u=n.__k[l])&&null!=u.__e){n.__e=n.__c.base=u.__e;break}return C(n)}}function M(n){(!n.__d&&(n.__d=!0)&&i.push(n)&&!$.__r++||o!=l.debounceRendering)&&((o=l.debounceRendering)||r)($)}function $(){for(var n,u,t,o,r,f,c,s=1;i.length;)i.length>s&&i.sort(e),n=i.shift(),s=i.length,n.__d&&(t=void 0,o=void 0,r=(o=(u=n).__v).__e,f=[],c=[],u.__P&&((t=w({},o)).__v=o.__v+1,l.vnode&&l.vnode(t),O(u.__P,t,o,u.__n,u.__P.namespaceURI,32&o.__u?[r]:null,f,null==r?S(o):r,!!(32&o.__u),c),t.__v=o.__v,t.__.__k[t.__i]=t,N(f,t,c),o.__e=o.__=null,t.__e!=r&&C(t)));$.__r=0}function I(n,l,u,t,i,o,r,e,f,c,s){var a,h,y,d,w,g,_,m=t&&t.__k||v,b=l.length;for(f=P(u,l,m,f,b),a=0;a<b;a++)null!=(y=u.__k[a])&&(h=-1==y.__i?p:m[y.__i]||p,y.__i=a,g=O(n,y,h,i,o,r,e,f,c,s),d=y.__e,y.ref&&h.ref!=y.ref&&(h.ref&&B(h.ref,null,y),s.push(y.ref,y.__c||d,y)),null==w&&null!=d&&(w=d),(_=!!(4&y.__u))||h.__k===y.__k?f=A(y,f,n,_):\"function\"==typeof y.type&&void 0!==g?f=g:d&&(f=d.nextSibling),y.__u&=-7);return u.__e=w,f}function P(n,l,u,t,i){var o,r,e,f,c,s=u.length,a=s,h=0;for(n.__k=new Array(i),o=0;o<i;o++)null!=(r=l[o])&&\"boolean\"!=typeof r&&\"function\"!=typeof r?(\"string\"==typeof r||\"number\"==typeof r||\"bigint\"==typeof r||r.constructor==String?r=n.__k[o]=m(null,r,null,null,null):d(r)?r=n.__k[o]=m(k,{children:r},null,null,null):void 0===r.constructor&&r.__b>0?r=n.__k[o]=m(r.type,r.props,r.key,r.ref?r.ref:null,r.__v):n.__k[o]=r,f=o+h,r.__=n,r.__b=n.__b+1,e=null,-1!=(c=r.__i=L(r,u,f,a))&&(a--,(e=u[c])&&(e.__u|=2)),null==e||null==e.__v?(-1==c&&(i>s?h--:i<s&&h++),\"function\"!=typeof r.type&&(r.__u|=4)):c!=f&&(c==f-1?h--:c==f+1?h++:(c>f?h--:h++,r.__u|=4))):n.__k[o]=null;if(a)for(o=0;o<s;o++)null!=(e=u[o])&&0==(2&e.__u)&&(e.__e==t&&(t=S(e)),D(e,e));return t}function A(n,l,u,t){var i,o;if(\"function\"==typeof n.type){for(i=n.__k,o=0;i&&o<i.length;o++)i[o]&&(i[o].__=n,l=A(i[o],l,u,t));return l}n.__e!=l&&(t&&(l&&n.type&&!l.parentNode&&(l=S(n)),u.insertBefore(n.__e,l||null)),l=n.__e);do{l=l&&l.nextSibling}while(null!=l&&8==l.nodeType);return l}function H(n,l){return l=l||[],null==n||\"boolean\"==typeof n||(d(n)?n.some(function(n){H(n,l)}):l.push(n)),l}function L(n,l,u,t){var i,o,r,e=n.key,f=n.type,c=l[u],s=null!=c&&0==(2&c.__u);if(null===c&&null==e||s&&e==c.key&&f==c.type)return u;if(t>(s?1:0))for(i=u-1,o=u+1;i>=0||o<l.length;)if(null!=(c=l[r=i>=0?i--:o++])&&0==(2&c.__u)&&e==c.key&&f==c.type)return r;return-1}function T(n,l,u){\"-\"==l[0]?n.setProperty(l,null==u?\"\":u):n[l]=null==u?\"\":\"number\"!=typeof u||y.test(l)?u:u+\"px\"}function j(n,l,u,t,i){var o,r;n:if(\"style\"==l)if(\"string\"==typeof u)n.style.cssText=u;else{if(\"string\"==typeof t&&(n.style.cssText=t=\"\"),t)for(l in t)u&&l in u||T(n.style,l,\"\");if(u)for(l in u)t&&u[l]==t[l]||T(n.style,l,u[l])}else if(\"o\"==l[0]&&\"n\"==l[1])o=l!=(l=l.replace(f,\"$1\")),r=l.toLowerCase(),l=r in n||\"onFocusOut\"==l||\"onFocusIn\"==l?r.slice(2):l.slice(2),n.l||(n.l={}),n.l[l+o]=u,u?t?u.u=t.u:(u.u=c,n.addEventListener(l,o?a:s,o)):n.removeEventListener(l,o?a:s,o);else{if(\"http://www.w3.org/2000/svg\"==i)l=l.replace(/xlink(H|:h)/,\"h\").replace(/sName$/,\"s\");else if(\"width\"!=l&&\"height\"!=l&&\"href\"!=l&&\"list\"!=l&&\"form\"!=l&&\"tabIndex\"!=l&&\"download\"!=l&&\"rowSpan\"!=l&&\"colSpan\"!=l&&\"role\"!=l&&\"popover\"!=l&&l in n)try{n[l]=null==u?\"\":u;break n}catch(n){}\"function\"==typeof u||(null==u||!1===u&&\"-\"!=l[4]?n.removeAttribute(l):n.setAttribute(l,\"popover\"==l&&1==u?\"\":u))}}function F(n){return function(u){if(this.l){var t=this.l[u.type+n];if(null==u.t)u.t=c++;else if(u.t<t.u)return;return t(l.event?l.event(u):u)}}}function O(n,u,t,i,o,r,e,f,c,s){var a,h,p,v,y,_,m,b,S,C,M,$,P,A,H,L,T,j=u.type;if(void 0!==u.constructor)return null;128&t.__u&&(c=!!(32&t.__u),r=[f=u.__e=t.__e]),(a=l.__b)&&a(u);n:if(\"function\"==typeof j)try{if(b=u.props,S=\"prototype\"in j&&j.prototype.render,C=(a=j.contextType)&&i[a.__c],M=a?C?C.props.value:a.__:i,t.__c?m=(h=u.__c=t.__c).__=h.__E:(S?u.__c=h=new j(b,M):(u.__c=h=new x(b,M),h.constructor=j,h.render=E),C&&C.sub(h),h.state||(h.state={}),h.__n=i,p=h.__d=!0,h.__h=[],h._sb=[]),S&&null==h.__s&&(h.__s=h.state),S&&null!=j.getDerivedStateFromProps&&(h.__s==h.state&&(h.__s=w({},h.__s)),w(h.__s,j.getDerivedStateFromProps(b,h.__s))),v=h.props,y=h.state,h.__v=u,p)S&&null==j.getDerivedStateFromProps&&null!=h.componentWillMount&&h.componentWillMount(),S&&null!=h.componentDidMount&&h.__h.push(h.componentDidMount);else{if(S&&null==j.getDerivedStateFromProps&&b!==v&&null!=h.componentWillReceiveProps&&h.componentWillReceiveProps(b,M),u.__v==t.__v||!h.__e&&null!=h.shouldComponentUpdate&&!1===h.shouldComponentUpdate(b,h.__s,M)){for(u.__v!=t.__v&&(h.props=b,h.state=h.__s,h.__d=!1),u.__e=t.__e,u.__k=t.__k,u.__k.some(function(n){n&&(n.__=u)}),$=0;$<h._sb.length;$++)h.__h.push(h._sb[$]);h._sb=[],h.__h.length&&e.push(h);break n}null!=h.componentWillUpdate&&h.componentWillUpdate(b,h.__s,M),S&&null!=h.componentDidUpdate&&h.__h.push(function(){h.componentDidUpdate(v,y,_)})}if(h.context=M,h.props=b,h.__P=n,h.__e=!1,P=l.__r,A=0,S){for(h.state=h.__s,h.__d=!1,P&&P(u),a=h.render(h.props,h.state,h.context),H=0;H<h._sb.length;H++)h.__h.push(h._sb[H]);h._sb=[]}else do{h.__d=!1,P&&P(u),a=h.render(h.props,h.state,h.context),h.state=h.__s}while(h.__d&&++A<25);h.state=h.__s,null!=h.getChildContext&&(i=w(w({},i),h.getChildContext())),S&&!p&&null!=h.getSnapshotBeforeUpdate&&(_=h.getSnapshotBeforeUpdate(v,y)),L=a,null!=a&&a.type===k&&null==a.key&&(L=V(a.props.children)),f=I(n,d(L)?L:[L],u,t,i,o,r,e,f,c,s),h.base=u.__e,u.__u&=-161,h.__h.length&&e.push(h),m&&(h.__E=h.__=null)}catch(n){if(u.__v=null,c||null!=r)if(n.then){for(u.__u|=c?160:128;f&&8==f.nodeType&&f.nextSibling;)f=f.nextSibling;r[r.indexOf(f)]=null,u.__e=f}else{for(T=r.length;T--;)g(r[T]);z(u)}else u.__e=t.__e,u.__k=t.__k,n.then||z(u);l.__e(n,u,t)}else null==r&&u.__v==t.__v?(u.__k=t.__k,u.__e=t.__e):f=u.__e=q(t.__e,u,t,i,o,r,e,c,s);return(a=l.diffed)&&a(u),128&u.__u?void 0:f}function z(n){n&&n.__c&&(n.__c.__e=!0),n&&n.__k&&n.__k.forEach(z)}function N(n,u,t){for(var i=0;i<t.length;i++)B(t[i],t[++i],t[++i]);l.__c&&l.__c(u,n),n.some(function(u){try{n=u.__h,u.__h=[],n.some(function(n){n.call(u)})}catch(n){l.__e(n,u.__v)}})}function V(n){return\"object\"!=typeof n||null==n||n.__b&&n.__b>0?n:d(n)?n.map(V):w({},n)}function q(u,t,i,o,r,e,f,c,s){var a,h,v,y,w,_,m,b=i.props||p,k=t.props,x=t.type;if(\"svg\"==x?r=\"http://www.w3.org/2000/svg\":\"math\"==x?r=\"http://www.w3.org/1998/Math/MathML\":r||(r=\"http://www.w3.org/1999/xhtml\"),null!=e)for(a=0;a<e.length;a++)if((w=e[a])&&\"setAttribute\"in w==!!x&&(x?w.localName==x:3==w.nodeType)){u=w,e[a]=null;break}if(null==u){if(null==x)return document.createTextNode(k);u=document.createElementNS(r,x,k.is&&k),c&&(l.__m&&l.__m(t,e),c=!1),e=null}if(null==x)b===k||c&&u.data==k||(u.data=k);else{if(e=e&&n.call(u.childNodes),!c&&null!=e)for(b={},a=0;a<u.attributes.length;a++)b[(w=u.attributes[a]).name]=w.value;for(a in b)if(w=b[a],\"children\"==a);else if(\"dangerouslySetInnerHTML\"==a)v=w;else if(!(a in k)){if(\"value\"==a&&\"defaultValue\"in k||\"checked\"==a&&\"defaultChecked\"in k)continue;j(u,a,null,w,r)}for(a in k)w=k[a],\"children\"==a?y=w:\"dangerouslySetInnerHTML\"==a?h=w:\"value\"==a?_=w:\"checked\"==a?m=w:c&&\"function\"!=typeof w||b[a]===w||j(u,a,w,b[a],r);if(h)c||v&&(h.__html==v.__html||h.__html==u.innerHTML)||(u.innerHTML=h.__html),t.__k=[];else if(v&&(u.innerHTML=\"\"),I(\"template\"==t.type?u.content:u,d(y)?y:[y],t,i,o,\"foreignObject\"==x?\"http://www.w3.org/1999/xhtml\":r,e,f,e?e[0]:i.__k&&S(i,0),c,s),null!=e)for(a=e.length;a--;)g(e[a]);c||(a=\"value\",\"progress\"==x&&null==_?u.removeAttribute(\"value\"):null!=_&&(_!==u[a]||\"progress\"==x&&!_||\"option\"==x&&_!=b[a])&&j(u,a,_,b[a],r),a=\"checked\",null!=m&&m!=u[a]&&j(u,a,m,b[a],r))}return u}function B(n,u,t){try{if(\"function\"==typeof n){var i=\"function\"==typeof n.__u;i&&n.__u(),i&&null==u||(n.__u=n(u))}else n.current=u}catch(n){l.__e(n,t)}}function D(n,u,t){var i,o;if(l.unmount&&l.unmount(n),(i=n.ref)&&(i.current&&i.current!=n.__e||B(i,null,u)),null!=(i=n.__c)){if(i.componentWillUnmount)try{i.componentWillUnmount()}catch(n){l.__e(n,u)}i.base=i.__P=null}if(i=n.__k)for(o=0;o<i.length;o++)i[o]&&D(i[o],u,t||\"function\"!=typeof n.type);t||g(n.__e),n.__c=n.__=n.__e=void 0}function E(n,l,u){return this.constructor(n,u)}function G(u,t,i){var o,r,e,f;t==document&&(t=document.documentElement),l.__&&l.__(u,t),r=(o=\"function\"==typeof i)?null:i&&i.__k||t.__k,e=[],f=[],O(t,u=(!o&&i||t).__k=_(k,null,[u]),r||p,p,t.namespaceURI,!o&&i?[i]:r?null:t.firstChild?n.call(t.childNodes):null,e,!o&&i?i:r?r.__e:t.firstChild,o,f),N(e,u,f)}function J(n,l){G(n,l,J)}function K(l,u,t){var i,o,r,e,f=w({},l.props);for(r in l.type&&l.type.defaultProps&&(e=l.type.defaultProps),u)\"key\"==r?i=u[r]:\"ref\"==r?o=u[r]:f[r]=void 0===u[r]&&null!=e?e[r]:u[r];return arguments.length>2&&(f.children=arguments.length>3?n.call(arguments,2):t),m(l.type,f,i||l.key,o||l.ref,null)}function Q(n){function l(n){var u,t;return this.getChildContext||(u=new Set,(t={})[l.__c]=this,this.getChildContext=function(){return t},this.componentWillUnmount=function(){u=null},this.shouldComponentUpdate=function(n){this.props.value!=n.value&&u.forEach(function(n){n.__e=!0,M(n)})},this.sub=function(n){u.add(n);var l=n.componentWillUnmount;n.componentWillUnmount=function(){u&&u.delete(n),l&&l.call(n)}}),n.children}return l.__c=\"__cC\"+h++,l.__=n,l.Provider=l.__l=(l.Consumer=function(n,l){return n.children(l)}).contextType=l,l}n=v.slice,l={__e:function(n,l,u,t){for(var i,o,r;l=l.__;)if((i=l.__c)&&!i.__)try{if((o=i.constructor)&&null!=o.getDerivedStateFromError&&(i.setState(o.getDerivedStateFromError(n)),r=i.__d),null!=i.componentDidCatch&&(i.componentDidCatch(n,t||{}),r=i.__d),r)return i.__E=i}catch(l){n=l}throw n}},u=0,t=function(n){return null!=n&&void 0===n.constructor},x.prototype.setState=function(n,l){var u;u=null!=this.__s&&this.__s!=this.state?this.__s:this.__s=w({},this.state),\"function\"==typeof n&&(n=n(w({},u),this.props)),n&&w(u,n),null!=n&&this.__v&&(l&&this._sb.push(l),M(this))},x.prototype.forceUpdate=function(n){this.__v&&(this.__e=!0,n&&this.__h.push(n),M(this))},x.prototype.render=k,i=[],r=\"function\"==typeof Promise?Promise.prototype.then.bind(Promise.resolve()):setTimeout,e=function(n,l){return n.__v.__b-l.__v.__b},$.__r=0,f=/(PointerCapture)$|Capture$/i,c=0,s=F(!1),a=F(!0),h=0;export{x as Component,k as Fragment,K as cloneElement,Q as createContext,_ as createElement,b as createRef,_ as h,J as hydrate,t as isValidElement,l as options,G as render,H as toChildArray};\n//# sourceMappingURL=preact.module.js.map\n","import{options as r,Fragment as e}from\"preact\";export{Fragment}from\"preact\";var t=/[\"&<]/;function n(r){if(0===r.length||!1===t.test(r))return r;for(var e=0,n=0,o=\"\",f=\"\";n<r.length;n++){switch(r.charCodeAt(n)){case 34:f=\"&quot;\";break;case 38:f=\"&amp;\";break;case 60:f=\"&lt;\";break;default:continue}n!==e&&(o+=r.slice(e,n)),o+=f,e=n+1}return n!==e&&(o+=r.slice(e,n)),o}var o=/acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i,f=0,i=Array.isArray;function u(e,t,n,o,i,u){t||(t={});var a,c,p=t;if(\"ref\"in p)for(c in p={},t)\"ref\"==c?a=t[c]:p[c]=t[c];var l={type:e,props:p,key:n,ref:a,__k:null,__:null,__b:0,__e:null,__c:null,constructor:void 0,__v:--f,__i:-1,__u:0,__source:i,__self:u};if(\"function\"==typeof e&&(a=e.defaultProps))for(c in a)void 0===p[c]&&(p[c]=a[c]);return r.vnode&&r.vnode(l),l}function a(r){var t=u(e,{tpl:r,exprs:[].slice.call(arguments,1)});return t.key=t.__v,t}var c={},p=/[A-Z]/g;function l(e,t){if(r.attr){var f=r.attr(e,t);if(\"string\"==typeof f)return f}if(t=function(r){return null!==r&&\"object\"==typeof r&&\"function\"==typeof r.valueOf?r.valueOf():r}(t),\"ref\"===e||\"key\"===e)return\"\";if(\"style\"===e&&\"object\"==typeof t){var i=\"\";for(var u in t){var a=t[u];if(null!=a&&\"\"!==a){var l=\"-\"==u[0]?u:c[u]||(c[u]=u.replace(p,\"-$&\").toLowerCase()),s=\";\";\"number\"!=typeof a||l.startsWith(\"--\")||o.test(l)||(s=\"px;\"),i=i+l+\":\"+a+s}}return e+'=\"'+n(i)+'\"'}return null==t||!1===t||\"function\"==typeof t||\"object\"==typeof t?\"\":!0===t?e:e+'=\"'+n(\"\"+t)+'\"'}function s(r){if(null==r||\"boolean\"==typeof r||\"function\"==typeof r)return null;if(\"object\"==typeof r){if(void 0===r.constructor)return r;if(i(r)){for(var e=0;e<r.length;e++)r[e]=s(r[e]);return r}}return n(\"\"+r)}export{u as jsx,l as jsxAttr,u as jsxDEV,s as jsxEscape,a as jsxTemplate,u as jsxs};\n//# sourceMappingURL=jsxRuntime.module.js.map\n","import{options as n}from\"preact\";var t,r,u,i,o=0,f=[],c=n,e=c.__b,a=c.__r,v=c.diffed,l=c.__c,m=c.unmount,s=c.__;function p(n,t){c.__h&&c.__h(r,n,o||t),o=0;var u=r.__H||(r.__H={__:[],__h:[]});return n>=u.__.length&&u.__.push({}),u.__[n]}function d(n){return o=1,h(D,n)}function h(n,u,i){var o=p(t++,2);if(o.t=n,!o.__c&&(o.__=[i?i(u):D(void 0,u),function(n){var t=o.__N?o.__N[0]:o.__[0],r=o.t(t,n);t!==r&&(o.__N=[r,o.__[1]],o.__c.setState({}))}],o.__c=r,!r.__f)){var f=function(n,t,r){if(!o.__c.__H)return!0;var u=o.__c.__H.__.filter(function(n){return!!n.__c});if(u.every(function(n){return!n.__N}))return!c||c.call(this,n,t,r);var i=o.__c.props!==n;return u.forEach(function(n){if(n.__N){var t=n.__[0];n.__=n.__N,n.__N=void 0,t!==n.__[0]&&(i=!0)}}),c&&c.call(this,n,t,r)||i};r.__f=!0;var c=r.shouldComponentUpdate,e=r.componentWillUpdate;r.componentWillUpdate=function(n,t,r){if(this.__e){var u=c;c=void 0,f(n,t,r),c=u}e&&e.call(this,n,t,r)},r.shouldComponentUpdate=f}return o.__N||o.__}function y(n,u){var i=p(t++,3);!c.__s&&C(i.__H,u)&&(i.__=n,i.u=u,r.__H.__h.push(i))}function _(n,u){var i=p(t++,4);!c.__s&&C(i.__H,u)&&(i.__=n,i.u=u,r.__h.push(i))}function A(n){return o=5,T(function(){return{current:n}},[])}function F(n,t,r){o=6,_(function(){if(\"function\"==typeof n){var r=n(t());return function(){n(null),r&&\"function\"==typeof r&&r()}}if(n)return n.current=t(),function(){return n.current=null}},null==r?r:r.concat(n))}function T(n,r){var u=p(t++,7);return C(u.__H,r)&&(u.__=n(),u.__H=r,u.__h=n),u.__}function q(n,t){return o=8,T(function(){return n},t)}function x(n){var u=r.context[n.__c],i=p(t++,9);return i.c=n,u?(null==i.__&&(i.__=!0,u.sub(r)),u.props.value):n.__}function P(n,t){c.useDebugValue&&c.useDebugValue(t?t(n):n)}function b(n){var u=p(t++,10),i=d();return u.__=n,r.componentDidCatch||(r.componentDidCatch=function(n,t){u.__&&u.__(n,t),i[1](n)}),[i[0],function(){i[1](void 0)}]}function g(){var n=p(t++,11);if(!n.__){for(var u=r.__v;null!==u&&!u.__m&&null!==u.__;)u=u.__;var i=u.__m||(u.__m=[0,0]);n.__=\"P\"+i[0]+\"-\"+i[1]++}return n.__}function j(){for(var n;n=f.shift();)if(n.__P&&n.__H)try{n.__H.__h.forEach(z),n.__H.__h.forEach(B),n.__H.__h=[]}catch(t){n.__H.__h=[],c.__e(t,n.__v)}}c.__b=function(n){r=null,e&&e(n)},c.__=function(n,t){n&&t.__k&&t.__k.__m&&(n.__m=t.__k.__m),s&&s(n,t)},c.__r=function(n){a&&a(n),t=0;var i=(r=n.__c).__H;i&&(u===r?(i.__h=[],r.__h=[],i.__.forEach(function(n){n.__N&&(n.__=n.__N),n.u=n.__N=void 0})):(i.__h.forEach(z),i.__h.forEach(B),i.__h=[],t=0)),u=r},c.diffed=function(n){v&&v(n);var t=n.__c;t&&t.__H&&(t.__H.__h.length&&(1!==f.push(t)&&i===c.requestAnimationFrame||((i=c.requestAnimationFrame)||w)(j)),t.__H.__.forEach(function(n){n.u&&(n.__H=n.u),n.u=void 0})),u=r=null},c.__c=function(n,t){t.some(function(n){try{n.__h.forEach(z),n.__h=n.__h.filter(function(n){return!n.__||B(n)})}catch(r){t.some(function(n){n.__h&&(n.__h=[])}),t=[],c.__e(r,n.__v)}}),l&&l(n,t)},c.unmount=function(n){m&&m(n);var t,r=n.__c;r&&r.__H&&(r.__H.__.forEach(function(n){try{z(n)}catch(n){t=n}}),r.__H=void 0,t&&c.__e(t,r.__v))};var k=\"function\"==typeof requestAnimationFrame;function w(n){var t,r=function(){clearTimeout(u),k&&cancelAnimationFrame(t),setTimeout(n)},u=setTimeout(r,35);k&&(t=requestAnimationFrame(r))}function z(n){var t=r,u=n.__c;\"function\"==typeof u&&(n.__c=void 0,u()),r=t}function B(n){var t=r;n.__c=n.__(),r=t}function C(n,t){return!n||n.length!==t.length||t.some(function(t,r){return t!==n[r]})}function D(n,t){return\"function\"==typeof t?t(n):t}export{q as useCallback,x as useContext,P as useDebugValue,y as useEffect,b as useErrorBoundary,g as useId,F as useImperativeHandle,_ as useLayoutEffect,T as useMemo,h as useReducer,A as useRef,d as useState};\n//# sourceMappingURL=hooks.module.js.map\n","// Widget dimensions\r\nexport const BUTTON_SIZE = 60;\r\nexport const WINDOW_WIDTH = 350;\r\nexport const WINDOW_HEIGHT = 500;\r\n\r\n// Positioning\r\nexport const POSITION_BOTTOM = 20;\r\nexport const POSITION_RIGHT = 20;\r\n\r\n// Colors — initial values match the backend ProjectSettings default.\r\n// applyTheme() in index.tsx overrides primary/primaryHover/messageUser\r\n// with the remote config value before the widget renders.\r\nexport const COLORS = {\r\n primary: \"#6C03C1\",\r\n primaryHover: \"#5b02a4\",\r\n background: \"#ffffff\",\r\n text: \"hsla(215, 100%, 5%, 1)\",\r\n textSecondary: \"hsla(215, 100%, 5%, 1)\",\r\n border: \"#e5e7eb\",\r\n messageBot: \"\",\r\n messageUser: \"#6C03C1\",\r\n messageUserText: \"#ffffff\",\r\n};\r\n\r\nconst normalizeHexColor = (hex: string): string => {\r\n const trimmed = hex.trim();\r\n if (!/^#([0-9a-fA-F]{3}|[0-9a-fA-F]{6})$/.test(trimmed)) {\r\n return \"hsla(215, 100%, 5%, 1)\";\r\n }\r\n if (trimmed.length === 4) {\r\n const r = trimmed[1];\r\n const g = trimmed[2];\r\n const b = trimmed[3];\r\n return `#${r}${r}${g}${g}${b}${b}`;\r\n }\r\n return trimmed;\r\n};\r\n\r\nexport const getContrastIconFilter = (backgroundHex: string): string => {\r\n const hex = normalizeHexColor(backgroundHex).slice(1);\r\n const r = parseInt(hex.slice(0, 2), 16);\r\n const g = parseInt(hex.slice(2, 4), 16);\r\n const b = parseInt(hex.slice(4, 6), 16);\r\n\r\n // Relative luminance approximation for quick contrast choice.\r\n const luminance = (0.299 * r + 0.587 * g + 0.114 * b) / 255;\r\n return luminance > 0.62 ? \"brightness(0) invert(0)\" : \"brightness(0) invert(1)\";\r\n};\r\n\r\n// Border radius\r\nexport const BORDER_RADIUS = {\r\n button: '50%',\r\n window: '17px',\r\n message: '10px'\r\n};\r\n\r\n// Shadows\r\nexport const SHADOW = \"0 0 15px hsla(215, 100%, 5%, 0.15)\";\r\n\r\n// Transitions\r\nexport const TRANSITIONS = {\r\n fast: '150ms ease-in-out',\r\n medium: '250ms ease-in-out'\r\n};\r\n","import microphoneIcon from \"./assets/icons/microphone.svg?inline\";\r\nimport microphoneIconRaw from \"./assets/icons/microphone.svg?raw\";\r\nimport restartIcon from \"./assets/icons/restart.svg?inline\";\r\nimport restartIconRaw from \"./assets/icons/restart.svg?raw\";\r\nimport closeIcon from \"./assets/icons/close.svg?inline\";\r\nimport closeIconRaw from \"./assets/icons/close.svg?raw\";\r\nimport stopIcon from \"./assets/icons/stop.svg?inline\";\r\nimport stopIconRaw from \"./assets/icons/stop.svg?raw\";\r\nimport bulutLogo from \"./assets/icons/bulut_logo.svg\";\r\nimport bulutLogoRaw from \"./assets/icons/bulut_logo.svg?raw\";\r\nimport sentSfx from \"./assets/sfx/sent.mp3\";\r\nimport thinkingSfx from \"./assets/sfx/thinking.mp3\";\r\nimport toolCallSfx from \"./assets/sfx/tool_call.mp3\";\r\nimport completedSfx from \"./assets/sfx/completed.mp3\";\r\n\r\nexport const microphoneIconUrl = microphoneIcon;\r\nexport const microphoneIconContent = microphoneIconRaw;\r\nexport const restartIconUrl = restartIcon;\r\nexport const restartIconContent = restartIconRaw;\r\nexport const closeIconUrl = closeIcon;\r\nexport const closeIconContent = closeIconRaw;\r\nexport const stopIconUrl = stopIcon;\r\nexport const stopIconContent = stopIconRaw;\r\nexport const logoUrl = bulutLogo;\r\nexport const logoContent = bulutLogoRaw;\r\nexport const sentSfxUrl = sentSfx;\r\nexport const thinkingSfxUrl = thinkingSfx;\r\nexport const toolCallSfxUrl = toolCallSfx;\r\nexport const completedSfxUrl = completedSfx;\r\n","export default \"<svg width=\\\"50\\\" height=\\\"50\\\" viewBox=\\\"0 0 50 50\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\">\\r\\n<path d=\\\"M17.6667 47H32.3333M39.6666 19.5001V23.1667C39.6666 31.2334 33.0666 37.8334 25 37.8334M25 37.8334C16.9333 37.8334 10.3334 31.2334 10.3334 23.1667V19.5001M25 37.8334V47M25 3.00009C24.0356 2.99523 23.0798 3.1816 22.1879 3.54841C21.296 3.91523 20.4857 4.45521 19.8037 5.13714C19.1218 5.81907 18.5818 6.62942 18.215 7.52133C17.8482 8.41325 17.6618 9.36903 17.6667 10.3334V23.0521C17.6667 27.0855 20.9896 30.5 25 30.5C29.0104 30.5 32.3333 27.1771 32.3333 23.0521V10.3334C32.3333 6.20842 29.125 3.00009 25 3.00009Z\\\" stroke=\\\"hsla(215, 100%, 5%, 1)\\\" stroke-width=\\\"3\\\" stroke-linecap=\\\"round\\\" stroke-linejoin=\\\"round\\\"/>\\r\\n</svg>\\r\\n\"","export default \"<svg width=\\\"50\\\" height=\\\"50\\\" viewBox=\\\"0 0 50 50\\\" fill=\\\"none\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\">\\r\\n<path d=\\\"M42.5 42.5L7.5 7.5M42.5 7.5L7.5 42.5\\\" stroke=\\\"hsla(215, 100%, 5%, 1)\\\" stroke-width=\\\"3\\\" stroke-linecap=\\\"round\\\" stroke-linejoin=\\\"round\\\"/>\\r\\n</svg>\\r\\n\"","export default \"<svg width=\\\"50\\\" height=\\\"50\\\" viewBox=\\\"0 0 50 50\\\" fill=\\\"none\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\">\\r\\n<rect x=\\\"12\\\" y=\\\"12\\\" width=\\\"26\\\" height=\\\"26\\\" rx=\\\"4\\\" stroke=\\\"hsla(215, 100%, 5%, 1)\\\" stroke-width=\\\"3\\\" fill=\\\"none\\\"/>\\r\\n</svg>\\r\\n\"","\r\nimport type { CSSProperties, JSX } from \"preact\";\r\nimport { useMemo } from \"preact/hooks\";\r\n\r\nexport type SvgIconProps = Omit<JSX.IntrinsicElements[\"svg\"], \"style\"> & {\r\n src: string;\r\n title?: string;\r\n /**\r\n * If true, replaces fill and stroke attributes with \"currentColor\" in the inner SVG content.\r\n * Default: true\r\n */\r\n stripColors?: boolean;\r\n style?: CSSProperties;\r\n // Explicitly add common props to ensure destructuring works smoothly\r\n className?: string;\r\n fill?: string;\r\n stroke?: string;\r\n strokeWidth?: string | number;\r\n width?: string | number;\r\n height?: string | number;\r\n};\r\n\r\nexport function SvgIcon({\r\n src,\r\n width,\r\n height,\r\n title,\r\n stripColors = true,\r\n className,\r\n style,\r\n fill,\r\n stroke,\r\n strokeWidth,\r\n ...props\r\n}: SvgIconProps) {\r\n const { viewBox, content } = useMemo(() => {\r\n if (!src) return { viewBox: \"0 0 24 24\", content: \"\" };\r\n\r\n const trimmedSrc = src.trim();\r\n // Extract viewBox\r\n const viewBoxMatch = trimmedSrc.match(/viewBox=\"([^\"]*)\"/);\r\n const viewBox = viewBoxMatch ? viewBoxMatch[1] : \"0 0 24 24\";\r\n\r\n // Extract inner content by removing the outer <svg> wrapper\r\n // We remove the opening <svg ...> tag and the closing </svg> tag only.\r\n let content = trimmedSrc.replace(/^<svg[^>]*>/i, \"\").replace(/<\\/svg>\\s*$/i, \"\");\r\n\r\n return { viewBox, content };\r\n }, [src]);\r\n\r\n const cleanContent = useMemo(() => {\r\n if (!content) return \"\";\r\n let nextContent = content;\r\n\r\n if (stripColors) {\r\n // Force inner nodes to use props instead of hardcoded SVG values.\r\n nextContent = nextContent\r\n .replace(/fill=\"[^\"]*\"/gi, `fill=\"${fill}\"`)\r\n .replace(/stroke=\"[^\"]*\"/gi, `stroke=\"${stroke}\"`);\r\n }\r\n\r\n if (strokeWidth !== undefined) {\r\n const strokeWidthValue = String(strokeWidth);\r\n nextContent = /stroke-width=\"[^\"]*\"/i.test(nextContent)\r\n ? nextContent.replace(/stroke-width=\"[^\"]*\"/gi, `stroke-width=\"${strokeWidthValue}\"`)\r\n : nextContent.replace(\r\n /<(path|circle|ellipse|line|polyline|polygon|rect)\\b/gi,\r\n `<$1 stroke-width=\"${strokeWidthValue}\"`,\r\n );\r\n }\r\n\r\n return nextContent;\r\n }, [content, stripColors, fill, stroke, strokeWidth]);\r\n\r\n return (\r\n <svg\r\n viewBox={viewBox}\r\n width={width}\r\n height={height}\r\n className={className}\r\n style={{\r\n display: \"inline-block\",\r\n verticalAlign: \"middle\",\r\n flexShrink: 0,\r\n ...style,\r\n }}\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n {...props}\r\n dangerouslySetInnerHTML={{ __html: cleanContent }}\r\n >\r\n {title && <title>{title}</title>}\r\n </svg>\r\n );\r\n}\r\n","import {\r\n BUTTON_SIZE,\r\n POSITION_BOTTOM,\r\n POSITION_RIGHT,\r\n COLORS,\r\n SHADOW,\r\n TRANSITIONS,\r\n BORDER_RADIUS,\r\n getContrastIconFilter,\r\n} from \"../styles/constants\";\r\nimport { closeIconContent, microphoneIconContent, stopIconContent } from \"../assets\";\r\nimport { SvgIcon } from \"./SvgIcon\";\r\n\r\ninterface ChatButtonProps {\r\n onMicClick: () => void;\r\n onCancelRecording: () => void;\r\n onStopTask: () => void;\r\n isRecording: boolean;\r\n isBusy: boolean;\r\n showBubble: boolean;\r\n onBubbleClick: () => void;\r\n previewMessage: string | null;\r\n onPreviewClick: () => void;\r\n onPreviewClose: () => void;\r\n}\r\n\r\nexport const ChatButton = ({\r\n onMicClick,\r\n onCancelRecording,\r\n onStopTask,\r\n isRecording,\r\n isBusy,\r\n showBubble,\r\n onBubbleClick,\r\n previewMessage,\r\n onPreviewClick,\r\n onPreviewClose,\r\n}: ChatButtonProps) => {\r\n const bgColor = COLORS.primary;\r\n\r\n const containerStyle: { [key: string]: string } = {\r\n position: \"fixed\",\r\n right: `${POSITION_RIGHT}px`,\r\n bottom: `${POSITION_BOTTOM}px`,\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n alignItems: \"flex-end\",\r\n gap: \"8px\",\r\n zIndex: \"9999\",\r\n fontFamily: \"\\\"Geist\\\", sans-serif\",\r\n };\r\n\r\n const controlsRowStyle: { [key: string]: string } = {\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n gap: \"10px\",\r\n };\r\n\r\n const buttonStyle: { [key: string]: string } = {\r\n width: `${BUTTON_SIZE}px`,\r\n height: `${BUTTON_SIZE}px`,\r\n minWidth: `${BUTTON_SIZE}px`,\r\n minHeight: `${BUTTON_SIZE}px`,\r\n borderRadius: BORDER_RADIUS.button,\r\n backgroundColor: bgColor,\r\n color: \"#ffffff\",\r\n border: \"none\",\r\n cursor: \"pointer\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n transition: `background-color ${TRANSITIONS.fast}, transform ${TRANSITIONS.fast}`,\r\n position: \"relative\",\r\n flexShrink: \"0\",\r\n };\r\n\r\n const iconStyle: { [key: string]: string } = {\r\n width: \"24px\",\r\n height: \"24px\",\r\n display: \"block\",\r\n filter: getContrastIconFilter(bgColor),\r\n };\r\n\r\n const showStopButton = isBusy && !isRecording;\r\n\r\n const handleClick = () => {\r\n if (showStopButton) {\r\n onStopTask();\r\n } else if (isRecording) {\r\n onCancelRecording();\r\n } else {\r\n onMicClick();\r\n }\r\n };\r\n\r\n // Shared close button style\r\n const closeBtnStyle: { [key: string]: string } = {\r\n position: \"absolute\",\r\n top: \"6px\",\r\n right: \"6px\",\r\n width: \"20px\",\r\n height: \"20px\",\r\n borderRadius: \"50%\",\r\n border: \"none\",\r\n background: \"transparent\",\r\n cursor: \"pointer\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n fontSize: \"12px\",\r\n lineHeight: \"1\",\r\n color: COLORS.text,\r\n padding: \"0\",\r\n };\r\n\r\n const renderPopup = (\r\n content: preact.ComponentChildren,\r\n onClick: () => void,\r\n onClose: (() => void) | null,\r\n extraClass: string,\r\n scrollable: boolean,\r\n ) => (\r\n <div\r\n className={`bulut-popup ${extraClass}`}\r\n style={{ cursor: \"pointer\" }}\r\n onClick={onClick}\r\n >\r\n {/* Close button */}\r\n {onClose && (\r\n <button\r\n type=\"button\"\r\n style={closeBtnStyle}\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n onClose();\r\n }}\r\n aria-label=\"Kapat\"\r\n >\r\n <SvgIcon\r\n strokeWidth={3}\r\n src={closeIconContent}\r\n stroke={\"currentColor\"}\r\n height={14}\r\n />\r\n </button>\r\n )}\r\n\r\n {/* Text content */}\r\n <div\r\n style={{\r\n paddingRight: onClose ? \"22px\" : \"0\",\r\n wordBreak: \"break-word\",\r\n ...(scrollable ? { maxHeight: \"96px\", overflowY: \"auto\" } : {}),\r\n }}\r\n >\r\n {content}\r\n </div>\r\n </div>\r\n );\r\n\r\n return (\r\n <>\r\n <style>{`\r\n @import url('https://fonts.googleapis.com/css2?family=Geist:wght@100..900&display=swap');\r\n\r\n .bulut-popup {\r\n background: #ffffff;\r\n color: ${COLORS.text};\r\n padding: 10px 14px;\r\n border-radius: 12px;\r\n font-size: 14px;\r\n line-height: 1.4;\r\n position: relative;\r\n overflow: visible;\r\n box-shadow: ${SHADOW};\r\n }\r\n .bulut-popup-bubble {\r\n animation: bulut-bubbleIn 400ms ease-out;\r\n }\r\n .bulut-popup-preview {\r\n animation: bulut-popIn ${TRANSITIONS.medium};\r\n }\r\n\r\n /* Desktop: limit width, lean to right */\r\n .bulut-popup {\r\n max-width: 320px;\r\n }\r\n\r\n /* Mobile: full-width layout with popup filling remaining space */\r\n @media (max-width: 600px) {\r\n .bulut-fab-container:has(.bulut-popup) {\r\n left: 16px !important;\r\n right: 16px !important;\r\n }\r\n .bulut-fab-container:has(.bulut-popup) .bulut-controls-row {\r\n width: 100%;\r\n }\r\n .bulut-popup {\r\n flex: 1;\r\n min-width: 0;\r\n max-width: none;\r\n }\r\n }\r\n\r\n @keyframes bulut-popIn {\r\n from { opacity: 0; transform: translateX(10px); }\r\n to { opacity: 1; transform: translateX(0); }\r\n }\r\n @keyframes bulut-bubbleIn {\r\n 0% { opacity: 0; transform: translateX(10px) scale(0.95); }\r\n 60% { opacity: 1; transform: translateX(-4px) scale(1.02); }\r\n 100% { opacity: 1; transform: translateX(0) scale(1); }\r\n }\r\n @keyframes bulut-badgeIn {\r\n from { opacity: 0; transform: translateY(-4px); }\r\n to { opacity: 1; transform: translateY(0); }\r\n }\r\n `}</style>\r\n\r\n <div className=\"bulut-fab-container\" style={containerStyle}>\r\n <div className=\"bulut-controls-row\" style={controlsRowStyle}>\r\n {/* Welcome bubble */}\r\n {showBubble &&\r\n !isRecording &&\r\n !previewMessage &&\r\n renderPopup(\r\n \"Destek lazımsa hemen konuşmaya başlayabiliriz!\",\r\n onBubbleClick,\r\n null,\r\n \"bulut-popup-bubble\",\r\n false,\r\n )}\r\n\r\n {/* New-message preview */}\r\n {previewMessage &&\r\n renderPopup(\r\n previewMessage,\r\n onPreviewClick,\r\n onPreviewClose,\r\n \"bulut-popup-preview\",\r\n true,\r\n )}\r\n\r\n {/* Main mic / cancel button */}\r\n <button\r\n style={buttonStyle}\r\n onClick={handleClick}\r\n onMouseEnter={(e) => {\r\n Object.assign(e.currentTarget.style, {\r\n backgroundColor: COLORS.primaryHover,\r\n transform: \"scale(1.05)\",\r\n });\r\n }}\r\n onMouseLeave={(e) => {\r\n Object.assign(e.currentTarget.style, {\r\n transform: \"scale(1)\",\r\n });\r\n }}\r\n aria-label={showStopButton ? \"Görevi durdur\" : isRecording ? \"Kaydı iptal et\" : \"Konuşmaya başla\"}\r\n >\r\n <SvgIcon\r\n src={showStopButton ? stopIconContent : isRecording ? closeIconContent : microphoneIconContent}\r\n aria-hidden=\"true\"\r\n fill-opacity={0}\r\n stroke={\"currentColor\"}\r\n style={iconStyle}\r\n />\r\n </button>\r\n </div>\r\n </div>\r\n </>\r\n );\r\n};\r\n","export interface PageContext {\r\n links: string[];\r\n interactables: string[];\r\n summary: string;\r\n}\r\n\r\nexport interface CachedPageContextEntry {\r\n url: string;\r\n summary: string;\r\n links: string[];\r\n interactables: string[];\r\n capturedAt: number;\r\n version: number;\r\n}\r\n\r\nexport interface PageContextSummaryInput {\r\n url: string;\r\n title: string;\r\n lang: string;\r\n headings: string[];\r\n landmarks: string[];\r\n links: string[];\r\n interactables: string[];\r\n interactionSignals: string[];\r\n pageBlueprint: string[];\r\n textSnippets: string[];\r\n outerHtmlDigest: string;\r\n}\r\n\r\ninterface InteractableCandidate {\r\n line: string;\r\n score: number;\r\n order: number;\r\n}\r\n\r\ninterface PageSignalSnapshot {\r\n links: string[];\r\n interactables: string[];\r\n interactionSignals: string[];\r\n pageBlueprint: string[];\r\n}\r\n\r\nimport {\r\n MAX_LINKS,\r\n MAX_INTERACTABLES,\r\n MAX_HEADINGS,\r\n MAX_TEXT_SNIPPETS,\r\n MAX_OUTER_HTML_DIGEST,\r\n MAX_CACHED_PAGES,\r\n MAX_PAGE_SCAN_ELEMENTS,\r\n MAX_EVENT_HINTS_PER_ELEMENT,\r\n MAX_BRANCH_SAMPLES,\r\n MAX_BRANCH_DEPTH,\r\n MAX_CONTEXT_SUMMARY_CHARS,\r\n MAX_CONTEXT_WITH_HISTORY_CHARS,\r\n} from \"./contextConfig\";\r\n\r\nexport { MAX_CONTEXT_SUMMARY_CHARS };\r\n\r\nexport const PAGE_CONTEXT_CACHE_VERSION = 2;\r\nexport const PAGE_CONTEXT_CACHE_KEY = \"auticbot_page_context_cache_v2\";\r\n\r\nconst NON_CONTENT_TAGS = new Set([\r\n \"script\",\r\n \"style\",\r\n \"noscript\",\r\n \"template\",\r\n \"link\",\r\n \"meta\",\r\n]);\r\n\r\nconst NATIVE_INTERACTIVE_TAGS = new Set([\r\n \"a\",\r\n \"button\",\r\n \"input\",\r\n \"textarea\",\r\n \"select\",\r\n \"summary\",\r\n \"details\",\r\n \"option\",\r\n]);\r\n\r\nconst INTERACTIVE_ROLES = new Set([\r\n \"button\",\r\n \"link\",\r\n \"tab\",\r\n \"menuitem\",\r\n \"option\",\r\n \"checkbox\",\r\n \"radio\",\r\n \"switch\",\r\n \"combobox\",\r\n \"textbox\",\r\n \"searchbox\",\r\n \"slider\",\r\n \"spinbutton\",\r\n \"treeitem\",\r\n]);\r\n\r\nconst TRACKED_DISPLAY_VALUES = new Set([\r\n \"block\",\r\n \"inline\",\r\n \"inline-block\",\r\n \"flex\",\r\n \"inline-flex\",\r\n \"grid\",\r\n \"inline-grid\",\r\n]);\r\n\r\nconst TRACKED_POSITION_VALUES = new Set([\r\n \"relative\",\r\n \"absolute\",\r\n \"fixed\",\r\n \"sticky\",\r\n]);\r\n\r\nconst EVENT_HINT_NAMES = [\r\n \"click\",\r\n \"dblclick\",\r\n \"mousedown\",\r\n \"mouseup\",\r\n \"pointerdown\",\r\n \"pointerup\",\r\n \"touchstart\",\r\n \"touchend\",\r\n \"keydown\",\r\n \"keyup\",\r\n \"keypress\",\r\n \"input\",\r\n \"change\",\r\n \"submit\",\r\n \"focus\",\r\n \"blur\",\r\n];\r\n\r\nconst ARIA_INTERACTION_ATTRS = [\r\n \"aria-controls\",\r\n \"aria-expanded\",\r\n \"aria-haspopup\",\r\n \"aria-pressed\",\r\n \"aria-selected\",\r\n];\r\n\r\nconst DATA_INTERACTION_PATTERN =\r\n /(action|click|press|toggle|target|trigger|nav|open|close|menu|modal|command|submit)/i;\r\n\r\nconst pageContextCache = new Map<string, CachedPageContextEntry>();\r\nlet cacheHydrated = false;\r\n\r\nconst normalizeWhitespace = (value: string): string =>\r\n value.replace(/\\s+/g, \" \").trim();\r\n\r\nconst truncate = (value: string, maxChars: number): string => {\r\n if (value.length <= maxChars) {\r\n return value;\r\n }\r\n\r\n const suffix = \"\\n...[truncated]\";\r\n return `${value.slice(0, Math.max(0, maxChars - suffix.length))}${suffix}`;\r\n};\r\n\r\nconst truncateInline = (value: string, maxChars: number): string => {\r\n if (value.length <= maxChars) {\r\n return value;\r\n }\r\n return `${value.slice(0, Math.max(0, maxChars - 3))}...`;\r\n};\r\n\r\nconst canonicalUrl = (rawUrl: string): string => {\r\n try {\r\n return new URL(rawUrl, rawUrl).href;\r\n } catch {\r\n return rawUrl;\r\n }\r\n};\r\n\r\nconst isCacheEntry = (value: unknown): value is CachedPageContextEntry => {\r\n if (typeof value !== \"object\" || value === null) {\r\n return false;\r\n }\r\n\r\n const obj = value as Record<string, unknown>;\r\n return (\r\n typeof obj.url === \"string\" &&\r\n typeof obj.summary === \"string\" &&\r\n Array.isArray(obj.links) &&\r\n Array.isArray(obj.interactables) &&\r\n typeof obj.capturedAt === \"number\" &&\r\n typeof obj.version === \"number\"\r\n );\r\n};\r\n\r\nconst bumpCount = (map: Map<string, number>, key: string): void => {\r\n if (!key) {\r\n return;\r\n }\r\n map.set(key, (map.get(key) ?? 0) + 1);\r\n};\r\n\r\nconst formatTopCounts = (map: Map<string, number>, maxItems: number): string => {\r\n if (map.size === 0) {\r\n return \"none\";\r\n }\r\n\r\n return Array.from(map.entries())\r\n .sort((a, b) => b[1] - a[1] || a[0].localeCompare(b[0]))\r\n .slice(0, maxItems)\r\n .map(([name, count]) => `${name}*${count}`)\r\n .join(\", \");\r\n};\r\n\r\nconst parseTabIndex = (value: string | null): number | null => {\r\n if (value === null) {\r\n return null;\r\n }\r\n\r\n const parsed = Number.parseInt(value, 10);\r\n return Number.isNaN(parsed) ? null : parsed;\r\n};\r\n\r\nconst compactToken = (value: string, maxChars: number = 18): string => {\r\n const compact = value.replace(/\\s+/g, \"-\").replace(/[^a-zA-Z0-9_-]/g, \"\");\r\n return compact ? truncateInline(compact, maxChars) : \"\";\r\n};\r\n\r\nconst getElementDepth = (element: Element): number => {\r\n let depth = 0;\r\n let cursor: Element | null = element;\r\n while (cursor?.parentElement) {\r\n depth += 1;\r\n cursor = cursor.parentElement;\r\n if (cursor === document.body) {\r\n break;\r\n }\r\n }\r\n return depth;\r\n};\r\n\r\nconst getPrimaryRole = (element: Element): string => {\r\n const rawRole = normalizeWhitespace(element.getAttribute(\"role\") || \"\")\r\n .toLowerCase()\r\n .split(\" \")[0];\r\n return rawRole || \"\";\r\n};\r\n\r\nconst hydrateCacheFromStorage = (): void => {\r\n if (cacheHydrated || typeof sessionStorage === \"undefined\") {\r\n return;\r\n }\r\n\r\n cacheHydrated = true;\r\n\r\n try {\r\n const raw = sessionStorage.getItem(PAGE_CONTEXT_CACHE_KEY);\r\n if (!raw) {\r\n return;\r\n }\r\n\r\n const parsed = JSON.parse(raw);\r\n if (!Array.isArray(parsed)) {\r\n return;\r\n }\r\n\r\n for (const value of parsed) {\r\n if (!isCacheEntry(value)) {\r\n continue;\r\n }\r\n if (value.version !== PAGE_CONTEXT_CACHE_VERSION) {\r\n continue;\r\n }\r\n pageContextCache.set(value.url, value);\r\n }\r\n if (pageContextCache.size > 0) {\r\n console.info(\r\n `[Autic] context cache restored entries=${pageContextCache.size}`,\r\n );\r\n }\r\n } catch (error) {\r\n console.warn(\"[Autic] context cache restore failed\", error);\r\n }\r\n};\r\n\r\nconst persistCacheToStorage = (): void => {\r\n if (typeof sessionStorage === \"undefined\") {\r\n return;\r\n }\r\n\r\n try {\r\n const serialized = JSON.stringify(\r\n Array.from(pageContextCache.values()).sort(\r\n (a, b) => a.capturedAt - b.capturedAt,\r\n ),\r\n );\r\n sessionStorage.setItem(PAGE_CONTEXT_CACHE_KEY, serialized);\r\n } catch (error) {\r\n console.warn(\"[Autic] context cache persist failed\", error);\r\n }\r\n};\r\n\r\nconst pruneOldestCacheEntries = (): void => {\r\n if (pageContextCache.size <= MAX_CACHED_PAGES) {\r\n return;\r\n }\r\n\r\n const sorted = Array.from(pageContextCache.values()).sort(\r\n (a, b) => a.capturedAt - b.capturedAt,\r\n );\r\n const overflow = sorted.length - MAX_CACHED_PAGES;\r\n for (let i = 0; i < overflow; i += 1) {\r\n pageContextCache.delete(sorted[i].url);\r\n }\r\n};\r\n\r\nconst buildSummaryWithHistory = (\r\n current: CachedPageContextEntry,\r\n): string => {\r\n const recentPages = Array.from(pageContextCache.values())\r\n .filter((entry) => entry.url !== current.url)\r\n .sort((a, b) => b.capturedAt - a.capturedAt)\r\n .slice(0, 3);\r\n\r\n if (recentPages.length === 0) {\r\n return current.summary;\r\n }\r\n\r\n const historySection = [\r\n \"Recent Page Memory:\",\r\n ...recentPages.map((entry) => {\r\n const compactSummary = normalizeWhitespace(entry.summary).slice(0, 180);\r\n return `- ${entry.url} :: ${compactSummary}`;\r\n }),\r\n ].join(\"\\n\");\r\n\r\n return truncate(\r\n `${current.summary}\\n\\n${historySection}`,\r\n MAX_CONTEXT_WITH_HISTORY_CHARS,\r\n );\r\n};\r\n\r\nconst isVisible = (element: Element): boolean => {\r\n if (element.getAttribute(\"aria-hidden\") === \"true\") {\r\n return false;\r\n }\r\n\r\n if (element instanceof HTMLElement && element.hidden) {\r\n return false;\r\n }\r\n\r\n const style = window.getComputedStyle(element);\r\n if (style.display === \"none\" || style.visibility === \"hidden\") {\r\n return false;\r\n }\r\n\r\n const rect = element.getBoundingClientRect();\r\n return rect.width > 0 && rect.height > 0;\r\n};\r\n\r\nconst toAbsoluteUrl = (href: string): string => {\r\n try {\r\n return new URL(href, window.location.href).href;\r\n } catch {\r\n return href;\r\n }\r\n};\r\n\r\nconst escapeCssValue = (value: string): string => {\r\n if (typeof CSS !== \"undefined\" && typeof CSS.escape === \"function\") {\r\n return CSS.escape(value);\r\n }\r\n\r\n return value.replace(/([ #;&,.+*~':\"!^$\\[\\]()=>|\\/@])/g, \"\\\\$1\");\r\n};\r\n\r\nconst buildSelector = (element: Element): string => {\r\n const tag = element.tagName.toLowerCase();\r\n\r\n if (element.id) {\r\n return `#${escapeCssValue(element.id)}`;\r\n }\r\n\r\n const name = element.getAttribute(\"name\");\r\n if (name) {\r\n return `${tag}[name=\"${escapeCssValue(name)}\"]`;\r\n }\r\n\r\n const ariaLabel = element.getAttribute(\"aria-label\");\r\n if (ariaLabel) {\r\n return `${tag}[aria-label=\"${escapeCssValue(ariaLabel)}\"]`;\r\n }\r\n\r\n const classes = Array.from(element.classList)\r\n .filter(Boolean)\r\n .slice(0, 2)\r\n .map((className) => `.${escapeCssValue(className)}`)\r\n .join(\"\");\r\n if (classes) {\r\n return `${tag}${classes}`;\r\n }\r\n\r\n const parent = element.parentElement;\r\n if (!parent) {\r\n return tag;\r\n }\r\n\r\n const siblingsOfTag = Array.from(parent.children).filter(\r\n (sibling) => sibling.tagName === element.tagName,\r\n );\r\n const index = siblingsOfTag.indexOf(element) + 1;\r\n return `${tag}:nth-of-type(${index})`;\r\n};\r\n\r\nconst getElementLabel = (element: Element): string => {\r\n const text = normalizeWhitespace(\r\n (element instanceof HTMLElement ? element.innerText : element.textContent) ||\r\n \"\",\r\n );\r\n const ariaLabel = normalizeWhitespace(element.getAttribute(\"aria-label\") || \"\");\r\n const title = normalizeWhitespace(element.getAttribute(\"title\") || \"\");\r\n const placeholder = normalizeWhitespace(\r\n element.getAttribute(\"placeholder\") || \"\",\r\n );\r\n const name = normalizeWhitespace(element.getAttribute(\"name\") || \"\");\r\n const value =\r\n element instanceof HTMLInputElement ||\r\n element instanceof HTMLTextAreaElement ||\r\n element instanceof HTMLButtonElement\r\n ? normalizeWhitespace(element.value || \"\")\r\n : \"\";\r\n\r\n const classHint = Array.from(element.classList)\r\n .map((item) => compactToken(item, 16))\r\n .find(Boolean);\r\n const fallback =\r\n (element.id && `#${element.id}`) ||\r\n (classHint && `.${classHint}`) ||\r\n buildSelector(element);\r\n\r\n const label =\r\n text || ariaLabel || title || placeholder || value || name || fallback;\r\n\r\n if (element.tagName.toLowerCase() === \"input\") {\r\n const inputType = element.getAttribute(\"type\") || \"text\";\r\n return `${inputType} ${label || \"input\"}`;\r\n }\r\n\r\n return label || \"untitled\";\r\n};\r\n\r\nconst getEventHints = (element: Element): string[] => {\r\n const record = element as unknown as Record<string, unknown>;\r\n const eventHints: string[] = [];\r\n\r\n for (const eventName of EVENT_HINT_NAMES) {\r\n const handlerKey = `on${eventName}`;\r\n const hasInlineHandler = Boolean(element.getAttribute(handlerKey));\r\n const hasPropertyHandler = typeof record[handlerKey] === \"function\";\r\n\r\n if (!hasInlineHandler && !hasPropertyHandler) {\r\n continue;\r\n }\r\n\r\n eventHints.push(eventName);\r\n if (eventHints.length >= MAX_EVENT_HINTS_PER_ELEMENT) {\r\n break;\r\n }\r\n }\r\n\r\n return eventHints;\r\n};\r\n\r\nconst getAriaInteractionHints = (element: Element): string[] =>\r\n ARIA_INTERACTION_ATTRS.filter((attrName) => element.hasAttribute(attrName)).map(\r\n (attrName) => attrName.replace(\"aria-\", \"\"),\r\n );\r\n\r\nconst getDataInteractionHints = (element: Element): string[] =>\r\n element\r\n .getAttributeNames()\r\n .filter(\r\n (attrName) =>\r\n attrName.startsWith(\"data-\") && DATA_INTERACTION_PATTERN.test(attrName),\r\n )\r\n .slice(0, 2)\r\n .map((attrName) => attrName.replace(\"data-\", \"\"));\r\n\r\nconst getStyleHints = (style: CSSStyleDeclaration): string[] => {\r\n const styleHints: string[] = [];\r\n\r\n if (style.cursor === \"pointer\") {\r\n styleHints.push(\"cursor:pointer\");\r\n }\r\n\r\n if (\r\n style.display === \"flex\" ||\r\n style.display === \"grid\" ||\r\n style.display === \"inline-flex\" ||\r\n style.display === \"inline-grid\"\r\n ) {\r\n styleHints.push(`display:${style.display}`);\r\n }\r\n\r\n if (style.position === \"fixed\" || style.position === \"sticky\") {\r\n styleHints.push(`position:${style.position}`);\r\n }\r\n\r\n return styleHints.slice(0, 2);\r\n};\r\n\r\nconst buildBlueprintToken = (element: Element): string => {\r\n const tag = element.tagName.toLowerCase();\r\n const idToken = element.id ? `#${compactToken(element.id)}` : \"\";\r\n const classToken = Array.from(element.classList)\r\n .map((item) => compactToken(item, 16))\r\n .find(Boolean);\r\n\r\n return `${tag}${idToken}${classToken ? `.${classToken}` : \"\"}`;\r\n};\r\n\r\nconst buildBranchDigest = (element: Element, depth: number): string => {\r\n const token = buildBlueprintToken(element);\r\n if (depth <= 0) {\r\n return token;\r\n }\r\n\r\n const children = Array.from(element.children)\r\n .filter((child) => !NON_CONTENT_TAGS.has(child.tagName.toLowerCase()))\r\n .filter((child) => isVisible(child));\r\n if (children.length === 0) {\r\n return token;\r\n }\r\n\r\n const sampled = children\r\n .slice(0, 3)\r\n .map((child) => buildBranchDigest(child, depth - 1));\r\n const overflow =\r\n children.length > sampled.length ? `+${children.length - sampled.length}` : \"\";\r\n\r\n return `${token}>${sampled.join(\"+\")}${overflow}`;\r\n};\r\n\r\nconst collectDomBranchDigest = (): string[] => {\r\n const root = document.body ?? document.documentElement;\r\n const topLevelNodes = Array.from(root.children)\r\n .filter((child) => !NON_CONTENT_TAGS.has(child.tagName.toLowerCase()))\r\n .filter((child) => isVisible(child))\r\n .slice(0, MAX_BRANCH_SAMPLES);\r\n\r\n return topLevelNodes.map((child) =>\r\n truncateInline(buildBranchDigest(child, MAX_BRANCH_DEPTH), 140),\r\n );\r\n};\r\n\r\nconst formatSection = (title: string, lines: string[]): string => {\r\n if (lines.length === 0) {\r\n return `${title}:\\n- none`;\r\n }\r\n\r\n return `${title}:\\n${lines.join(\"\\n\")}`;\r\n};\r\n\r\nconst buildOuterHtmlDigest = (): string => {\r\n const raw = document.body?.outerHTML || document.documentElement.outerHTML;\r\n\r\n const withoutScripts = raw\r\n .replace(/<script[\\s\\S]*?<\\/script>/gi, \"\")\r\n .replace(/<style[\\s\\S]*?<\\/style>/gi, \"\")\r\n .replace(/<noscript[\\s\\S]*?<\\/noscript>/gi, \"\")\r\n .replace(/<!--[\\s\\S]*?-->/g, \"\")\r\n .replace(/\\s+/g, \" \")\r\n .trim();\r\n\r\n const structural = withoutScripts\r\n .replace(/>[^<]*</g, \"><\")\r\n .replace(/\\s+/g, \" \")\r\n .trim();\r\n\r\n return truncate(structural, MAX_OUTER_HTML_DIGEST);\r\n};\r\n\r\nconst collectTextSnippets = (): string[] => {\r\n const root =\r\n document.querySelector(\"main, article, [role='main']\") ?? document.body;\r\n const snippets: string[] = [];\r\n const seen = new Set<string>();\r\n\r\n const candidates = Array.from(root.querySelectorAll(\"p, li, h1, h2, h3\"));\r\n for (const node of candidates) {\r\n if (!isVisible(node)) {\r\n continue;\r\n }\r\n\r\n const text = normalizeWhitespace(node.textContent || \"\");\r\n if (!text || text.length < 20) {\r\n continue;\r\n }\r\n\r\n const compact = truncateInline(text, 180);\r\n if (seen.has(compact)) {\r\n continue;\r\n }\r\n\r\n seen.add(compact);\r\n snippets.push(`- ${compact}`);\r\n if (snippets.length >= MAX_TEXT_SNIPPETS) {\r\n break;\r\n }\r\n }\r\n\r\n return snippets;\r\n};\r\n\r\nconst collectLandmarkSnapshot = (): string[] => {\r\n const probes: Array<{ label: string; selector: string }> = [\r\n { label: \"main\", selector: \"main, [role='main']\" },\r\n { label: \"nav\", selector: \"nav, [role='navigation']\" },\r\n { label: \"section\", selector: \"section\" },\r\n { label: \"article\", selector: \"article\" },\r\n { label: \"form\", selector: \"form\" },\r\n { label: \"a\", selector: \"a\" },\r\n { label: \"button\", selector: \"button\" },\r\n { label: \"input\", selector: \"input\" },\r\n { label: \"role=button/link\", selector: \"[role='button'], [role='link']\" },\r\n { label: \"onclick attrs\", selector: \"[onclick]\" },\r\n {\r\n label: \"other event attrs\",\r\n selector:\r\n \"[onpointerdown], [onpointerup], [onkeydown], [onkeyup], [onchange], [onsubmit]\",\r\n },\r\n { label: \"tabindex\", selector: \"[tabindex]\" },\r\n { label: \"contenteditable\", selector: \"[contenteditable='true']\" },\r\n { label: \"inline cursor styles\", selector: \"[style*='cursor']\" },\r\n ];\r\n\r\n return probes.map(\r\n ({ label, selector }) => `- ${label}: ${document.querySelectorAll(selector).length}`,\r\n );\r\n};\r\n\r\nconst collectPageSignalSnapshot = (): PageSignalSnapshot => {\r\n const allElements = Array.from(document.querySelectorAll(\"*\"));\r\n const sampledElements = allElements.slice(0, MAX_PAGE_SCAN_ELEMENTS);\r\n\r\n const links: string[] = [];\r\n const linkSet = new Set<string>();\r\n const interactableCandidates = new Map<string, InteractableCandidate>();\r\n const tagCounts = new Map<string, number>();\r\n const roleCounts = new Map<string, number>();\r\n const eventCounts = new Map<string, number>();\r\n const displayCounts = new Map<string, number>();\r\n const positionCounts = new Map<string, number>();\r\n\r\n let visibleElements = 0;\r\n let maxDepth = 0;\r\n let semanticInteractables = 0;\r\n let nonSemanticInteractables = 0;\r\n let eventHintElements = 0;\r\n let tabStopElements = 0;\r\n let pointerCursorElements = 0;\r\n let dataHintElements = 0;\r\n let ariaHintElements = 0;\r\n let contentEditableElements = 0;\r\n\r\n for (let order = 0; order < sampledElements.length; order += 1) {\r\n const element = sampledElements[order];\r\n const tag = element.tagName.toLowerCase();\r\n\r\n if (NON_CONTENT_TAGS.has(tag)) {\r\n continue;\r\n }\r\n\r\n if (!isVisible(element)) {\r\n continue;\r\n }\r\n\r\n visibleElements += 1;\r\n bumpCount(tagCounts, tag);\r\n\r\n const role = getPrimaryRole(element);\r\n if (role) {\r\n bumpCount(roleCounts, role);\r\n }\r\n\r\n const depth = getElementDepth(element);\r\n if (depth > maxDepth) {\r\n maxDepth = depth;\r\n }\r\n\r\n const style = window.getComputedStyle(element);\r\n if (TRACKED_DISPLAY_VALUES.has(style.display)) {\r\n bumpCount(displayCounts, style.display);\r\n }\r\n if (TRACKED_POSITION_VALUES.has(style.position)) {\r\n bumpCount(positionCounts, style.position);\r\n }\r\n\r\n const eventHints = getEventHints(element);\r\n if (eventHints.length > 0) {\r\n eventHintElements += 1;\r\n for (const eventName of eventHints) {\r\n bumpCount(eventCounts, eventName);\r\n }\r\n }\r\n\r\n const tabIndex = parseTabIndex(element.getAttribute(\"tabindex\"));\r\n const hasTabStop = tabIndex !== null && tabIndex >= 0;\r\n if (hasTabStop) {\r\n tabStopElements += 1;\r\n }\r\n\r\n const hasPointerCursor = style.cursor === \"pointer\";\r\n if (hasPointerCursor) {\r\n pointerCursorElements += 1;\r\n }\r\n\r\n const dataHints = getDataInteractionHints(element);\r\n if (dataHints.length > 0) {\r\n dataHintElements += 1;\r\n }\r\n\r\n const ariaHints = getAriaInteractionHints(element);\r\n if (ariaHints.length > 0) {\r\n ariaHintElements += 1;\r\n }\r\n\r\n const isContentEditable = element.getAttribute(\"contenteditable\") === \"true\";\r\n if (isContentEditable) {\r\n contentEditableElements += 1;\r\n }\r\n\r\n const href = element.getAttribute(\"href\");\r\n const isNativeInteractive = NATIVE_INTERACTIVE_TAGS.has(tag) && (tag !== \"a\" || Boolean(href));\r\n const isRoleInteractive = INTERACTIVE_ROLES.has(role);\r\n const isDisabled =\r\n element.hasAttribute(\"disabled\") ||\r\n element.getAttribute(\"aria-disabled\") === \"true\";\r\n\r\n if (\r\n tag === \"a\" &&\r\n href &&\r\n !href.startsWith(\"#\") &&\r\n !href.startsWith(\"javascript:\")\r\n ) {\r\n const absoluteHref = toAbsoluteUrl(href);\r\n const label = getElementLabel(element) || absoluteHref;\r\n const line = `- ${truncateInline(label, 90)} -> ${truncateInline(absoluteHref, 140)}`;\r\n\r\n if (!linkSet.has(line)) {\r\n linkSet.add(line);\r\n links.push(line);\r\n if (links.length >= MAX_LINKS) {\r\n // Keep scanning other elements for page blueprint and interactables.\r\n }\r\n }\r\n }\r\n\r\n const hasInteractionSignals =\r\n isNativeInteractive ||\r\n isRoleInteractive ||\r\n isContentEditable ||\r\n eventHints.length > 0 ||\r\n hasTabStop ||\r\n hasPointerCursor ||\r\n dataHints.length > 0 ||\r\n ariaHints.length > 0;\r\n\r\n if (!hasInteractionSignals || isDisabled) {\r\n continue;\r\n }\r\n\r\n if (isNativeInteractive) {\r\n semanticInteractables += 1;\r\n } else {\r\n nonSemanticInteractables += 1;\r\n }\r\n\r\n const selector = buildSelector(element);\r\n const label = truncateInline(getElementLabel(element), 90);\r\n const styleHints = getStyleHints(style);\r\n const signalTokens: string[] = [];\r\n\r\n if (eventHints.length > 0) {\r\n signalTokens.push(`evt:${eventHints.join(\"|\")}`);\r\n }\r\n if (isRoleInteractive) {\r\n signalTokens.push(`role:${role}`);\r\n }\r\n if (hasTabStop) {\r\n signalTokens.push(`tab:${tabIndex}`);\r\n }\r\n if (dataHints.length > 0) {\r\n signalTokens.push(`data:${dataHints.join(\"|\")}`);\r\n }\r\n if (ariaHints.length > 0) {\r\n signalTokens.push(`aria:${ariaHints.join(\"|\")}`);\r\n }\r\n if (styleHints.length > 0) {\r\n signalTokens.push(`css:${styleHints.join(\"|\")}`);\r\n } else if (hasPointerCursor) {\r\n signalTokens.push(\"css:cursor:pointer\");\r\n }\r\n\r\n const signalBlock =\r\n signalTokens.length > 0 ? ` [${signalTokens.join(\"; \")}]` : \"\";\r\n const line = truncateInline(\r\n `- ${tag} ${selector}${signalBlock} (${label})`,\r\n 240,\r\n );\r\n\r\n const score =\r\n eventHints.length * 5 +\r\n (isNativeInteractive ? 5 : 0) +\r\n (isRoleInteractive ? 4 : 0) +\r\n (hasTabStop ? 2 : 0) +\r\n (hasPointerCursor ? 2 : 0) +\r\n (dataHints.length > 0 ? 2 : 0) +\r\n (ariaHints.length > 0 ? 1 : 0) +\r\n (isContentEditable ? 2 : 0);\r\n\r\n const existing = interactableCandidates.get(line);\r\n if (!existing || score > existing.score) {\r\n interactableCandidates.set(line, { line, score, order });\r\n }\r\n }\r\n\r\n const interactables = Array.from(interactableCandidates.values())\r\n .sort((a, b) => b.score - a.score || a.order - b.order)\r\n .slice(0, MAX_INTERACTABLES)\r\n .map((candidate) => candidate.line);\r\n\r\n const interactiveRoleCounts = new Map(\r\n Array.from(roleCounts.entries()).filter(([role]) =>\r\n INTERACTIVE_ROLES.has(role),\r\n ),\r\n );\r\n\r\n const interactionSignals = [\r\n `- coverage: semantic=${semanticInteractables}, non-semantic=${nonSemanticInteractables}, contenteditable=${contentEditableElements}`,\r\n `- listener hints: ${formatTopCounts(eventCounts, 8)}`,\r\n `- interaction cues: tabindex>=0=${tabStopElements}, pointer-cursor=${pointerCursorElements}, data-hints=${dataHintElements}, aria-hints=${ariaHintElements}`,\r\n `- role hints: ${formatTopCounts(interactiveRoleCounts, 8)}`,\r\n \"- listener scope: inline/on* handlers are detected directly; addEventListener handlers are inferred via cues.\",\r\n ].map((line) => truncateInline(line, 250));\r\n\r\n const branchDigest = collectDomBranchDigest();\r\n const pageBlueprint = [\r\n `- nodes: total=${allElements.length}, scanned=${sampledElements.length}, visible=${visibleElements}, max-depth=${maxDepth}${allElements.length > sampledElements.length ? \", sampling=on\" : \"\"}`,\r\n `- tag density: ${formatTopCounts(tagCounts, 10)}`,\r\n `- role density: ${formatTopCounts(roleCounts, 8)}`,\r\n `- layout density: display(${formatTopCounts(displayCounts, 6)}), position(${formatTopCounts(positionCounts, 4)})`,\r\n `- branch digest: ${branchDigest.length > 0 ? branchDigest.join(\" || \") : \"none\"}`,\r\n ].map((line) => truncateInline(line, 260));\r\n\r\n return {\r\n links: links.slice(0, MAX_LINKS),\r\n interactables,\r\n interactionSignals,\r\n pageBlueprint,\r\n };\r\n};\r\n\r\nexport const buildPageContextSummary = (\r\n input: PageContextSummaryInput,\r\n maxChars: number = MAX_CONTEXT_SUMMARY_CHARS,\r\n): string => {\r\n const sections = [\r\n formatSection(\"Meta\", [\r\n `- URL: ${input.url || \"unknown\"}`,\r\n `- Title: ${input.title || \"unknown\"}`,\r\n `- Lang: ${input.lang || \"unknown\"}`,\r\n ]),\r\n formatSection(\"Headings\", input.headings),\r\n formatSection(\"Landmark Snapshot\", input.landmarks),\r\n formatSection(\"Interaction Signals\", input.interactionSignals),\r\n formatSection(\"Compressed Page Blueprint\", input.pageBlueprint),\r\n formatSection(\"Top Links\", input.links),\r\n formatSection(\"Top Interactables\", input.interactables),\r\n formatSection(\"Main Content Snippets\", input.textSnippets),\r\n formatSection(\"OuterHTML Skeleton\", [\r\n `- ${input.outerHtmlDigest || \"unavailable\"}`,\r\n ]),\r\n ];\r\n\r\n return truncate(sections.join(\"\\n\\n\"), maxChars);\r\n};\r\n\r\nexport const clearPageContextCache = (): void => {\r\n pageContextCache.clear();\r\n cacheHydrated = false;\r\n if (typeof sessionStorage !== \"undefined\") {\r\n sessionStorage.removeItem(PAGE_CONTEXT_CACHE_KEY);\r\n }\r\n};\r\n\r\nexport const getCachedPageContexts = (): CachedPageContextEntry[] => {\r\n hydrateCacheFromStorage();\r\n return Array.from(pageContextCache.values()).sort(\r\n (a, b) => b.capturedAt - a.capturedAt,\r\n );\r\n};\r\n\r\nexport const getPageContext = (): PageContext => {\r\n if (typeof window === \"undefined\" || typeof document === \"undefined\") {\r\n return {\r\n links: [],\r\n interactables: [],\r\n summary: \"\",\r\n };\r\n }\r\n\r\n hydrateCacheFromStorage();\r\n const url = canonicalUrl(window.location.href);\r\n const cached = pageContextCache.get(url);\r\n if (cached) {\r\n console.info(`[Autic] context cache hit url=${url}`);\r\n return {\r\n links: cached.links,\r\n interactables: cached.interactables,\r\n summary: buildSummaryWithHistory(cached),\r\n };\r\n }\r\n\r\n console.info(`[Autic] context cache miss url=${url}`);\r\n\r\n const snapshot = collectPageSignalSnapshot();\r\n const headings = Array.from(document.querySelectorAll(\"h1, h2, h3\"))\r\n .filter((element) => isVisible(element))\r\n .map((element) =>\r\n `- ${truncateInline(normalizeWhitespace(element.textContent || \"\"), 120)}`,\r\n )\r\n .filter((line) => line !== \"- \")\r\n .slice(0, MAX_HEADINGS);\r\n\r\n const summary = buildPageContextSummary({\r\n url,\r\n title: document.title,\r\n lang: document.documentElement.lang,\r\n headings,\r\n landmarks: collectLandmarkSnapshot(),\r\n links: snapshot.links,\r\n interactables: snapshot.interactables,\r\n interactionSignals: snapshot.interactionSignals,\r\n pageBlueprint: snapshot.pageBlueprint,\r\n textSnippets: collectTextSnippets(),\r\n outerHtmlDigest: buildOuterHtmlDigest(),\r\n });\r\n\r\n const entry: CachedPageContextEntry = {\r\n url,\r\n summary,\r\n links: snapshot.links,\r\n interactables: snapshot.interactables,\r\n capturedAt: Date.now(),\r\n version: PAGE_CONTEXT_CACHE_VERSION,\r\n };\r\n\r\n pageContextCache.set(url, entry);\r\n pruneOldestCacheEntries();\r\n persistCacheToStorage();\r\n console.info(\r\n `[Autic] context cache stored url=${url} size=${pageContextCache.size}`,\r\n );\r\n\r\n return {\r\n links: entry.links,\r\n interactables: entry.interactables,\r\n summary: buildSummaryWithHistory(entry),\r\n };\r\n};\r\n","/**\r\n * Tunable parameters for page context collection.\r\n *\r\n * Adjust these values to control how much information the agent receives\r\n * about the current page. Lower values reduce token usage (and latency);\r\n * higher values give the LLM more detail to work with.\r\n */\r\n\r\n/** Maximum number of links to include in the context. */\r\nexport const MAX_LINKS = 20;\r\n\r\n/** Maximum number of interactable elements to include. */\r\nexport const MAX_INTERACTABLES = 24;\r\n\r\n/** Maximum number of headings (h1-h3) to include. */\r\nexport const MAX_HEADINGS = 10;\r\n\r\n/** Maximum number of main-content text snippets. */\r\nexport const MAX_TEXT_SNIPPETS = 4;\r\n\r\n/** Maximum character length for the outer-HTML skeleton digest. */\r\nexport const MAX_OUTER_HTML_DIGEST = 760;\r\n\r\n/** Maximum number of pages kept in the in-memory context cache. */\r\nexport const MAX_CACHED_PAGES = 20;\r\n\r\n/** Maximum number of DOM elements scanned per page. */\r\nexport const MAX_PAGE_SCAN_ELEMENTS = 2000;\r\n\r\n/** Maximum number of event-handler hints collected per element. */\r\nexport const MAX_EVENT_HINTS_PER_ELEMENT = 4;\r\n\r\n/** Maximum top-level DOM branches sampled for the branch digest. */\r\nexport const MAX_BRANCH_SAMPLES = 4;\r\n\r\n/** Maximum tree depth for each branch digest sample. */\r\nexport const MAX_BRANCH_DEPTH = 2;\r\n\r\n/** Maximum character length for the full context summary. */\r\nexport const MAX_CONTEXT_SUMMARY_CHARS = 3400;\r\n\r\n/** Maximum character length for context summary + recent page history. */\r\nexport const MAX_CONTEXT_WITH_HISTORY_CHARS = 4200;\r\n","import { getPageContext } from \"./context\";\r\nimport { COLORS } from \"../styles/constants\";\r\n\r\nconst AGENT_CURSOR_ID = \"auticbot-agent-cursor\";\r\nconst CURSOR_STORAGE_KEY = \"auticbot_agent_cursor_state\";\r\nexport const CURSOR_MOVE_DURATION_MS = 900;\r\nexport const SCROLL_DURATION_MS = 900;\r\nconst CURSOR_EASING = \"cubic-bezier(0.4, 0, 0.2, 1)\";\r\nconst CURSOR_HOVER_RADIUS_PX = 14;\r\n\r\n// ── Pending Agent Resume State (survives page reloads) ──────────────\r\n\r\nconst RESUME_STORAGE_KEY = \"bulut_agent_resume\";\r\nconst RESUME_TTL_MS = 60_000; // 1 minute\r\n\r\nexport interface PendingAgentResume {\r\n sessionId: string;\r\n projectId: string;\r\n model: string;\r\n voice: string;\r\n accessibilityMode: boolean;\r\n pendingToolCalls: Array<{\r\n call_id: string;\r\n tool: string;\r\n args: Record<string, unknown>;\r\n }>;\r\n completedResults: Array<{ call_id: string; result: string }>;\r\n savedAt: number;\r\n}\r\n\r\nexport const savePendingAgentResume = (\r\n state: Omit<PendingAgentResume, \"savedAt\">,\r\n): void => {\r\n if (typeof localStorage === \"undefined\") return;\r\n try {\r\n localStorage.setItem(\r\n RESUME_STORAGE_KEY,\r\n JSON.stringify({ ...state, savedAt: Date.now() }),\r\n );\r\n } catch {\r\n // localStorage may be full or blocked\r\n }\r\n};\r\n\r\nexport const getPendingAgentResume = (): PendingAgentResume | null => {\r\n if (typeof localStorage === \"undefined\") return null;\r\n const raw = localStorage.getItem(RESUME_STORAGE_KEY);\r\n if (!raw) return null;\r\n try {\r\n const parsed = JSON.parse(raw) as PendingAgentResume;\r\n if (Date.now() - parsed.savedAt > RESUME_TTL_MS) {\r\n clearPendingAgentResume();\r\n return null;\r\n }\r\n return parsed;\r\n } catch {\r\n clearPendingAgentResume();\r\n return null;\r\n }\r\n};\r\n\r\nexport const clearPendingAgentResume = (): void => {\r\n if (typeof localStorage === \"undefined\") return;\r\n localStorage.removeItem(RESUME_STORAGE_KEY);\r\n};\r\n\r\ninterface PersistedCursorState {\r\n url: string;\r\n x: number;\r\n y: number;\r\n visible: boolean;\r\n}\r\n\r\ntype InteractAction = \"move\" | \"click\" | \"type\" | \"submit\";\r\n\r\ninterface InteractToolCall {\r\n tool: \"interact\";\r\n action: InteractAction;\r\n selector?: string;\r\n text?: string;\r\n x?: number;\r\n y?: number;\r\n}\r\n\r\ninterface NavigateToolCall {\r\n tool: \"navigate\";\r\n url: string;\r\n}\r\n\r\ninterface GetPageContextToolCall {\r\n tool: \"getPageContext\";\r\n}\r\n\r\ninterface ScrollToolCall {\r\n tool: \"scroll\";\r\n selector: string;\r\n}\r\n\r\nexport type AgentToolCall =\r\n | InteractToolCall\r\n | NavigateToolCall\r\n | GetPageContextToolCall\r\n | ScrollToolCall;\r\n\r\nexport interface ParsedAgentResponse {\r\n reply: string;\r\n toolCalls: AgentToolCall[];\r\n}\r\n\r\ninterface JsonObject {\r\n [key: string]: unknown;\r\n}\r\n\r\ninterface ResolvedTarget {\r\n element?: HTMLElement;\r\n x: number;\r\n y: number;\r\n}\r\n\r\nconst isObject = (value: unknown): value is JsonObject =>\r\n typeof value === \"object\" && value !== null && !Array.isArray(value);\r\n\r\nconst asString = (value: unknown): string | undefined =>\r\n typeof value === \"string\" && value.trim() ? value.trim() : undefined;\r\n\r\nconst asNumber = (value: unknown): number | undefined =>\r\n typeof value === \"number\" && Number.isFinite(value) ? value : undefined;\r\n\r\nconst extractJsonCandidate = (raw: string): string => {\r\n const trimmed = raw.trim();\r\n const fencedMatch = trimmed.match(/```(?:json)?\\s*([\\s\\S]*?)\\s*```/i);\r\n if (fencedMatch?.[1]) {\r\n return fencedMatch[1].trim();\r\n }\r\n return trimmed;\r\n};\r\n\r\nconst extractFirstJsonObject = (input: string): string | null => {\r\n const start = input.indexOf(\"{\");\r\n if (start < 0) {\r\n return null;\r\n }\r\n\r\n let depth = 0;\r\n let inString = false;\r\n let isEscaped = false;\r\n\r\n for (let i = start; i < input.length; i += 1) {\r\n const char = input[i];\r\n\r\n if (inString) {\r\n if (isEscaped) {\r\n isEscaped = false;\r\n } else if (char === \"\\\\\") {\r\n isEscaped = true;\r\n } else if (char === '\"') {\r\n inString = false;\r\n }\r\n continue;\r\n }\r\n\r\n if (char === '\"') {\r\n inString = true;\r\n continue;\r\n }\r\n\r\n if (char === \"{\") {\r\n depth += 1;\r\n continue;\r\n }\r\n\r\n if (char === \"}\") {\r\n depth -= 1;\r\n if (depth === 0) {\r\n return input.slice(start, i + 1);\r\n }\r\n }\r\n }\r\n\r\n return null;\r\n};\r\n\r\nconst parseJsonFromRaw = (raw: string): unknown => {\r\n const candidate = extractJsonCandidate(raw);\r\n try {\r\n return JSON.parse(candidate);\r\n } catch {\r\n const objectCandidate = extractFirstJsonObject(candidate);\r\n if (!objectCandidate) {\r\n return null;\r\n }\r\n try {\r\n return JSON.parse(objectCandidate);\r\n } catch {\r\n return null;\r\n }\r\n }\r\n};\r\n\r\nconst sanitizeToolCalls = (value: unknown): AgentToolCall[] => {\r\n if (!Array.isArray(value)) {\r\n return [];\r\n }\r\n\r\n const toolCalls: AgentToolCall[] = [];\r\n\r\n for (const item of value) {\r\n if (!isObject(item)) {\r\n continue;\r\n }\r\n\r\n if (item.tool === \"interact\") {\r\n const action = asString(item.action) as InteractAction | undefined;\r\n if (!action || ![\"move\", \"click\", \"type\", \"submit\"].includes(action)) {\r\n continue;\r\n }\r\n\r\n toolCalls.push({\r\n tool: \"interact\",\r\n action,\r\n selector: asString(item.selector),\r\n text: typeof item.text === \"string\" ? item.text : undefined,\r\n x: asNumber(item.x),\r\n y: asNumber(item.y),\r\n });\r\n continue;\r\n }\r\n\r\n if (item.tool === \"navigate\") {\r\n const url = asString(item.url);\r\n if (!url) {\r\n continue;\r\n }\r\n\r\n toolCalls.push({\r\n tool: \"navigate\",\r\n url,\r\n });\r\n continue;\r\n }\r\n\r\n if (item.tool === \"getPageContext\") {\r\n toolCalls.push({\r\n tool: \"getPageContext\",\r\n });\r\n continue;\r\n }\r\n\r\n if (item.tool === \"scroll\") {\r\n const selector = asString(item.selector);\r\n if (!selector) {\r\n continue;\r\n }\r\n\r\n toolCalls.push({\r\n tool: \"scroll\",\r\n selector,\r\n });\r\n }\r\n }\r\n\r\n return toolCalls;\r\n};\r\n\r\nexport const parseAgentResponse = (raw: string): ParsedAgentResponse => {\r\n const parsed = parseJsonFromRaw(raw);\r\n if (!isObject(parsed)) {\r\n return {\r\n reply: raw.trim(),\r\n toolCalls: [],\r\n };\r\n }\r\n\r\n const reply = asString(parsed.reply) || \"\";\r\n const toolCalls = sanitizeToolCalls(parsed.tool_calls ?? parsed.toolCalls);\r\n\r\n return {\r\n reply,\r\n toolCalls,\r\n };\r\n};\r\n\r\nexport const clamp = (value: number, min: number, max: number): number =>\r\n Math.min(max, Math.max(min, value));\r\n\r\nexport const easeInOutCubic = (progress: number): number => {\r\n if (progress < 0.5) {\r\n return 4 * progress * progress * progress;\r\n }\r\n return 1 - Math.pow(-2 * progress + 2, 3) / 2;\r\n};\r\n\r\nexport const easeInOutSine = (progress: number): number =>\r\n -(Math.cos(Math.PI * progress) - 1) / 2;\r\n\r\nexport const isRectOutsideViewport = (\r\n rect: Pick<DOMRect, \"top\" | \"bottom\">,\r\n viewportHeight: number,\r\n): boolean => rect.top < 0 || rect.bottom > viewportHeight;\r\n\r\nexport const computeCenteredScrollTop = (\r\n currentScrollY: number,\r\n rectTop: number,\r\n rectHeight: number,\r\n viewportHeight: number,\r\n maxScrollTop: number,\r\n): number => {\r\n const desired =\r\n currentScrollY + rectTop - (viewportHeight / 2 - rectHeight / 2);\r\n return clamp(desired, 0, Math.max(0, maxScrollTop));\r\n};\r\n\r\nexport const animateWindowScrollTo = async (\r\n targetY: number,\r\n durationMs: number = SCROLL_DURATION_MS,\r\n): Promise<void> => {\r\n if (typeof window === \"undefined\") {\r\n return;\r\n }\r\n\r\n const startY = window.scrollY;\r\n const delta = targetY - startY;\r\n if (Math.abs(delta) < 1) {\r\n return;\r\n }\r\n\r\n await new Promise<void>((resolve) => {\r\n const raf =\r\n window.requestAnimationFrame ||\r\n ((callback: FrameRequestCallback) => window.setTimeout(() => callback(performance.now()), 16));\r\n\r\n const startTime = performance.now();\r\n\r\n const step = (now: number) => {\r\n const elapsed = now - startTime;\r\n const progress = clamp(elapsed / durationMs, 0, 1);\r\n const eased = easeInOutSine(progress);\r\n window.scrollTo(0, startY + delta * eased);\r\n\r\n if (progress < 1) {\r\n raf(step);\r\n } else {\r\n resolve();\r\n }\r\n };\r\n\r\n raf(step);\r\n });\r\n};\r\n\r\nconst getPersistedCursorState = (): PersistedCursorState | null => {\r\n if (typeof localStorage === \"undefined\") {\r\n return null;\r\n }\r\n\r\n try {\r\n const raw = localStorage.getItem(CURSOR_STORAGE_KEY);\r\n if (!raw) {\r\n return null;\r\n }\r\n\r\n const parsed = JSON.parse(raw) as Partial<PersistedCursorState>;\r\n if (\r\n typeof parsed.url !== \"string\" ||\r\n typeof parsed.x !== \"number\" ||\r\n !Number.isFinite(parsed.x) ||\r\n typeof parsed.y !== \"number\" ||\r\n !Number.isFinite(parsed.y)\r\n ) {\r\n return null;\r\n }\r\n\r\n return {\r\n url: parsed.url,\r\n x: parsed.x,\r\n y: parsed.y,\r\n visible: parsed.visible !== false,\r\n };\r\n } catch {\r\n return null;\r\n }\r\n};\r\n\r\nconst persistCursorState = (x: number, y: number, visible: boolean) => {\r\n if (typeof localStorage === \"undefined\") {\r\n return;\r\n }\r\n\r\n try {\r\n const payload: PersistedCursorState = {\r\n url: window.location.href,\r\n x,\r\n y,\r\n visible,\r\n };\r\n localStorage.setItem(CURSOR_STORAGE_KEY, JSON.stringify(payload));\r\n } catch {\r\n // No-op: localStorage may be unavailable or blocked.\r\n }\r\n};\r\n\r\nconst setCursorPosition = (cursor: HTMLElement, x: number, y: number) => {\r\n cursor.style.left = `${x}px`;\r\n cursor.style.top = `${y}px`;\r\n};\r\n\r\nconst getCursorPosition = (cursor: HTMLElement): { x: number; y: number } => ({\r\n x: Number.parseFloat(cursor.style.left) || 0,\r\n y: Number.parseFloat(cursor.style.top) || 0,\r\n});\r\n\r\nconst setCursorVisibility = (cursor: HTMLElement, visible: boolean) => {\r\n cursor.style.opacity = visible ? \"1\" : \"0\";\r\n};\r\n\r\nlet cursorHoverTrackingInitialized = false;\r\nconst initializeCursorHoverTracking = () => {\r\n if (cursorHoverTrackingInitialized) {\r\n return;\r\n }\r\n cursorHoverTrackingInitialized = true;\r\n\r\n document.addEventListener(\"mousemove\", (event) => {\r\n const cursor = document.getElementById(AGENT_CURSOR_ID);\r\n if (!(cursor instanceof HTMLElement)) {\r\n return;\r\n }\r\n\r\n if (cursor.style.opacity !== \"1\") {\r\n return;\r\n }\r\n\r\n const { x, y } = getCursorPosition(cursor);\r\n const pointerX = event.pageX;\r\n const pointerY = event.pageY;\r\n const distance = Math.hypot(pointerX - x, pointerY - y);\r\n\r\n if (distance <= CURSOR_HOVER_RADIUS_PX) {\r\n setCursorVisibility(cursor, false);\r\n persistCursorState(x, y, false);\r\n }\r\n });\r\n};\r\n\r\nconst applyStoredCursorStateForCurrentUrl = (cursor: HTMLElement) => {\r\n const stored = getPersistedCursorState();\r\n if (!stored || stored.url !== window.location.href) {\r\n return;\r\n }\r\n\r\n setCursorPosition(cursor, stored.x, stored.y);\r\n setCursorVisibility(cursor, stored.visible);\r\n};\r\n\r\nconst ensureCursor = (): HTMLElement => {\r\n const existing = document.getElementById(AGENT_CURSOR_ID);\r\n if (existing) {\r\n // Keep cursor color in sync with the current theme\r\n existing.style.background = COLORS.primary;\r\n initializeCursorHoverTracking();\r\n return existing as HTMLElement;\r\n }\r\n\r\n const cursor = document.createElement(\"div\");\r\n cursor.id = AGENT_CURSOR_ID;\r\n cursor.style.position = \"absolute\";\r\n cursor.style.left = \"0px\";\r\n cursor.style.top = \"0px\";\r\n cursor.style.opacity = \"0\";\r\n const width = 25;\r\n cursor.style.width = `${width}px`;\r\n cursor.style.height = `${width}px`;\r\n cursor.style.borderRadius = \"50%\";\r\n const baseColor = COLORS.primary;\r\n cursor.style.background = baseColor;\r\n const border = 25 * 16 / 100;\r\n cursor.style.border = `${border}px solid #ffffff`;\r\n cursor.style.boxShadow = \"0px 0px 10px rgba(0, 11, 26, 0.5)\";\r\n cursor.style.boxSizing = \"border-box\";\r\n cursor.style.zIndex = \"2147483647\";\r\n cursor.style.pointerEvents = \"none\";\r\n cursor.style.transform = \"translate(-50%, -50%)\";\r\n cursor.style.transition = `left ${CURSOR_MOVE_DURATION_MS}ms ${CURSOR_EASING}, top ${CURSOR_MOVE_DURATION_MS}ms ${CURSOR_EASING}, opacity 150ms ease-out`;\r\n document.body.appendChild(cursor);\r\n initializeCursorHoverTracking();\r\n applyStoredCursorStateForCurrentUrl(cursor);\r\n console.info(`[Autic] cursor created color=${baseColor} duration=${CURSOR_MOVE_DURATION_MS}ms`);\r\n return cursor;\r\n};\r\n\r\nconst moveCursor = async (x: number, y: number) => {\r\n const cursor = ensureCursor();\r\n setCursorPosition(cursor, x, y);\r\n setCursorVisibility(cursor, true);\r\n persistCursorState(x, y, true);\r\n await new Promise((resolve) => setTimeout(resolve, CURSOR_MOVE_DURATION_MS));\r\n};\r\n\r\nconst getElementCenter = (element: HTMLElement): { x: number; y: number } => {\r\n const rect = element.getBoundingClientRect();\r\n return {\r\n x: rect.left + window.scrollX + rect.width / 2,\r\n y: rect.top + window.scrollY + rect.height / 2,\r\n };\r\n};\r\n\r\nconst CONTAINS_SELECTOR_PATTERN = /^(.*?):contains\\((['\"])(.*?)\\2\\)\\s*$/;\r\n\r\nconst findElementBySelector = (selector: string): Element | null => {\r\n try {\r\n return document.querySelector(selector);\r\n } catch (error) {\r\n const containsMatch = selector.match(CONTAINS_SELECTOR_PATTERN);\r\n if (!containsMatch) {\r\n console.warn(`AuticBot selector invalid: ${selector}`, error);\r\n return null;\r\n }\r\n\r\n const baseSelector = containsMatch[1]?.trim() || \"*\";\r\n const expectedText = containsMatch[3]?.trim() || \"\";\r\n if (!expectedText) {\r\n console.warn(`AuticBot selector contains empty text: ${selector}`);\r\n return null;\r\n }\r\n\r\n try {\r\n const candidates = document.querySelectorAll(baseSelector);\r\n for (const candidate of candidates) {\r\n if (candidate.textContent?.includes(expectedText)) {\r\n return candidate;\r\n }\r\n }\r\n return null;\r\n } catch (fallbackError) {\r\n console.warn(`AuticBot selector fallback invalid: ${selector}`, fallbackError);\r\n return null;\r\n }\r\n }\r\n};\r\n\r\nconst resolveTarget = (call: InteractToolCall): ResolvedTarget | null => {\r\n if (call.selector) {\r\n const selected = findElementBySelector(call.selector);\r\n\r\n if (selected instanceof HTMLElement) {\r\n const center = getElementCenter(selected);\r\n return {\r\n element: selected,\r\n x: center.x,\r\n y: center.y,\r\n };\r\n }\r\n console.warn(`AuticBot interact: selector not found: ${call.selector}`);\r\n }\r\n\r\n if (typeof call.x === \"number\" && typeof call.y === \"number\") {\r\n return {\r\n x: call.x,\r\n y: call.y,\r\n };\r\n }\r\n\r\n console.warn(\"AuticBot interact: missing target selector or coordinates.\", call);\r\n return null;\r\n};\r\n\r\nconst dispatchMouseEvent = (\r\n element: HTMLElement,\r\n type: string,\r\n x: number,\r\n y: number,\r\n) => {\r\n element.dispatchEvent(\r\n new MouseEvent(type, {\r\n bubbles: true,\r\n cancelable: true,\r\n view: window,\r\n clientX: x - window.scrollX,\r\n clientY: y - window.scrollY,\r\n }),\r\n );\r\n};\r\n\r\nconst typeIntoElement = (element: HTMLElement, text: string) => {\r\n const tagName = element.tagName.toUpperCase();\r\n if (tagName === \"INPUT\" || tagName === \"TEXTAREA\") {\r\n (element as HTMLInputElement).focus();\r\n (element as HTMLInputElement).value = text;\r\n element.dispatchEvent(new Event(\"input\", { bubbles: true }));\r\n element.dispatchEvent(new Event(\"change\", { bubbles: true }));\r\n return;\r\n }\r\n\r\n if (element.isContentEditable) {\r\n element.focus();\r\n element.textContent = text;\r\n element.dispatchEvent(new Event(\"input\", { bubbles: true }));\r\n return;\r\n }\r\n\r\n console.warn(\r\n \"AuticBot interact: type action requires input, textarea, or contenteditable target.\",\r\n );\r\n};\r\n\r\nconst submitElement = (element: HTMLElement) => {\r\n if (element.tagName === \"FORM\") {\r\n (element as HTMLFormElement).requestSubmit();\r\n return;\r\n }\r\n\r\n if (element.tagName === \"BUTTON\" && (element as HTMLButtonElement).form) {\r\n (element as HTMLButtonElement).form?.requestSubmit();\r\n return;\r\n }\r\n\r\n const parentForm = element.closest(\"form\");\r\n if (parentForm) {\r\n parentForm.requestSubmit();\r\n return;\r\n }\r\n\r\n console.warn(\"AuticBot interact: submit action requires a form target.\");\r\n};\r\n\r\nconst slowScrollElementIntoView = async (element: HTMLElement): Promise<void> => {\r\n await slowScrollElementIntoViewWithMode(element, false);\r\n};\r\n\r\nconst slowScrollElementIntoViewWithMode = async (\r\n element: HTMLElement,\r\n forceCenter: boolean,\r\n): Promise<void> => {\r\n const rect = element.getBoundingClientRect();\r\n const viewportHeight = window.innerHeight;\r\n\r\n if (!forceCenter && !isRectOutsideViewport(rect, viewportHeight)) {\r\n return;\r\n }\r\n\r\n const maxScrollTop = Math.max(\r\n 0,\r\n Math.max(document.body.scrollHeight, document.documentElement.scrollHeight) - viewportHeight,\r\n );\r\n const targetY = computeCenteredScrollTop(\r\n window.scrollY,\r\n rect.top,\r\n rect.height,\r\n viewportHeight,\r\n maxScrollTop,\r\n );\r\n\r\n await animateWindowScrollTo(targetY, SCROLL_DURATION_MS);\r\n};\r\n\r\nconst executeScroll = async (call: ScrollToolCall) => {\r\n const selected = findElementBySelector(call.selector);\r\n if (!(selected instanceof HTMLElement)) {\r\n console.warn(`AuticBot scroll: selector not found: ${call.selector}`);\r\n return;\r\n }\r\n\r\n await slowScrollElementIntoViewWithMode(selected, true);\r\n const center = getElementCenter(selected);\r\n await moveCursor(center.x, center.y);\r\n};\r\n\r\nconst executeInteract = async (call: InteractToolCall) => {\r\n const target = resolveTarget(call);\r\n if (!target) {\r\n return;\r\n }\r\n\r\n if (call.action === \"click\" && target.element) {\r\n await slowScrollElementIntoView(target.element);\r\n const center = getElementCenter(target.element);\r\n target.x = center.x;\r\n target.y = center.y;\r\n }\r\n\r\n await moveCursor(target.x, target.y);\r\n\r\n if (call.action === \"move\") {\r\n return;\r\n }\r\n\r\n if (!target.element) {\r\n console.warn(\"AuticBot interact: target element not available for action.\", call.action);\r\n return;\r\n }\r\n\r\n if (call.action === \"click\") {\r\n dispatchMouseEvent(target.element, \"pointerdown\", target.x, target.y);\r\n dispatchMouseEvent(target.element, \"mousedown\", target.x, target.y);\r\n dispatchMouseEvent(target.element, \"pointerup\", target.x, target.y);\r\n dispatchMouseEvent(target.element, \"mouseup\", target.x, target.y);\r\n target.element.click();\r\n return;\r\n }\r\n\r\n if (call.action === \"type\") {\r\n typeIntoElement(target.element, call.text ?? \"\");\r\n return;\r\n }\r\n\r\n submitElement(target.element);\r\n};\r\n\r\nconst isSamePageNavigation = (targetUrl: string): boolean => {\r\n try {\r\n const current = new URL(window.location.href);\r\n const target = new URL(targetUrl);\r\n return current.origin === target.origin && current.pathname === target.pathname;\r\n } catch {\r\n return false;\r\n }\r\n};\r\n\r\n/**\r\n * Find the best matching link element for a target URL.\r\n * Supports exact href match, partial path/query/hash match,\r\n * and text-content match for framework <Link> components.\r\n */\r\nconst findMatchingLinkForTarget = (targetUrl: string): HTMLElement | null => {\r\n let parsedTarget: URL | null = null;\r\n try {\r\n parsedTarget = new URL(targetUrl, window.location.href);\r\n } catch {\r\n // will fall through to text-based matching\r\n }\r\n\r\n const allLinks = Array.from(\r\n document.querySelectorAll('a[href], [role=\"link\"][href], [data-href]'),\r\n ) as HTMLElement[];\r\n\r\n // 1. Exact href match\r\n for (const el of allLinks) {\r\n if (el instanceof HTMLAnchorElement && el.href === parsedTarget?.href) {\r\n return el;\r\n }\r\n }\r\n\r\n if (parsedTarget) {\r\n // 2. Match by pathname + search + hash (ignoring origin)\r\n for (const el of allLinks) {\r\n if (!(el instanceof HTMLAnchorElement)) continue;\r\n try {\r\n const elUrl = new URL(el.href, window.location.href);\r\n if (\r\n elUrl.pathname === parsedTarget.pathname &&\r\n elUrl.search === parsedTarget.search &&\r\n elUrl.hash === parsedTarget.hash\r\n ) {\r\n return el;\r\n }\r\n } catch {\r\n continue;\r\n }\r\n }\r\n\r\n // 3. Match by pathname only (query/hash may differ)\r\n for (const el of allLinks) {\r\n if (!(el instanceof HTMLAnchorElement)) continue;\r\n try {\r\n const elUrl = new URL(el.href, window.location.href);\r\n if (elUrl.pathname === parsedTarget.pathname) {\r\n return el;\r\n }\r\n } catch {\r\n continue;\r\n }\r\n }\r\n\r\n // 4. Partial href attribute match (covers relative paths, query strings)\r\n const rawUrl = targetUrl.replace(/^\\//, \"\");\r\n for (const el of allLinks) {\r\n const href = el.getAttribute(\"href\") || el.getAttribute(\"data-href\") || \"\";\r\n if (href && (href === targetUrl || href === rawUrl || href === `/${rawUrl}`)) {\r\n return el;\r\n }\r\n }\r\n }\r\n\r\n // 5. Text-content match (for framework <Link> or <button> navigations)\r\n const urlSegments = targetUrl\r\n .replace(/^https?:\\/\\/[^/]+/, \"\")\r\n .replace(/[?#].*$/, \"\")\r\n .split(\"/\")\r\n .filter(Boolean);\r\n const lastSegment = urlSegments[urlSegments.length - 1] || \"\";\r\n\r\n if (lastSegment) {\r\n // Also search query param values (e.g., ?tab=interact → \"interact\")\r\n let searchTerms = [lastSegment];\r\n if (parsedTarget) {\r\n for (const [, value] of parsedTarget.searchParams.entries()) {\r\n if (value) searchTerms.push(value);\r\n }\r\n if (parsedTarget.hash) {\r\n searchTerms.push(parsedTarget.hash.replace(/^#/, \"\"));\r\n }\r\n }\r\n searchTerms = searchTerms.map((t) => t.toLowerCase());\r\n\r\n // Look across all clickable elements\r\n const clickables = Array.from(\r\n document.querySelectorAll(\r\n 'a, button, [role=\"link\"], [role=\"tab\"], [role=\"button\"], [data-tab], [onclick]',\r\n ),\r\n ) as HTMLElement[];\r\n\r\n for (const el of clickables) {\r\n const text = (el.textContent || \"\").trim().toLowerCase();\r\n const ariaLabel = (el.getAttribute(\"aria-label\") || \"\").toLowerCase();\r\n const dataTab = (el.getAttribute(\"data-tab\") || \"\").toLowerCase();\r\n for (const term of searchTerms) {\r\n if (\r\n text === term ||\r\n ariaLabel === term ||\r\n dataTab === term ||\r\n text.includes(term)\r\n ) {\r\n return el;\r\n }\r\n }\r\n }\r\n }\r\n\r\n return null;\r\n};\r\n\r\nconst executeNavigate = async (call: NavigateToolCall): Promise<boolean> => {\r\n try {\r\n const targetUrl = call.url;\r\n let resolvedUrl: string;\r\n try {\r\n resolvedUrl = new URL(targetUrl, window.location.href).href;\r\n } catch {\r\n resolvedUrl = targetUrl;\r\n }\r\n\r\n const matchingElement = findMatchingLinkForTarget(targetUrl);\r\n\r\n if (matchingElement) {\r\n console.log(\"AuticBot navigate: clicking element\", resolvedUrl, matchingElement.tagName);\r\n await slowScrollElementIntoView(matchingElement);\r\n\r\n const center = getElementCenter(matchingElement);\r\n await moveCursor(center.x, center.y);\r\n\r\n matchingElement.dispatchEvent(new MouseEvent(\"pointerdown\", { bubbles: true, view: window }));\r\n matchingElement.dispatchEvent(new MouseEvent(\"mousedown\", { bubbles: true, view: window }));\r\n matchingElement.dispatchEvent(new MouseEvent(\"pointerup\", { bubbles: true, view: window }));\r\n matchingElement.dispatchEvent(new MouseEvent(\"mouseup\", { bubbles: true, view: window }));\r\n matchingElement.click();\r\n\r\n return !isSamePageNavigation(resolvedUrl);\r\n }\r\n\r\n // 6. Fallback: direct browser navigation (query param, hash, or full URL)\r\n console.log(\"AuticBot navigate: no matching element found, using direct navigation\", resolvedUrl);\r\n\r\n // Hash-only navigation\r\n try {\r\n const parsed = new URL(resolvedUrl);\r\n if (\r\n parsed.origin === window.location.origin &&\r\n parsed.pathname === window.location.pathname &&\r\n parsed.hash\r\n ) {\r\n window.location.hash = parsed.hash;\r\n return false;\r\n }\r\n } catch { /* continue */ }\r\n\r\n // Query-param or same-origin navigation via History API\r\n try {\r\n const parsed = new URL(resolvedUrl);\r\n if (parsed.origin === window.location.origin) {\r\n // Use pushState + popstate to trigger SPA routers\r\n const newPath = parsed.pathname + parsed.search + parsed.hash;\r\n window.history.pushState({}, \"\", newPath);\r\n window.dispatchEvent(new PopStateEvent(\"popstate\", { state: {} }));\r\n return false;\r\n }\r\n } catch { /* continue */ }\r\n\r\n // Cross-origin: full page navigation\r\n window.location.href = resolvedUrl;\r\n return true;\r\n } catch (error) {\r\n console.warn(\"AuticBot navigate: error\", call.url, error);\r\n return false;\r\n }\r\n};\r\n\r\nconst executeGetPageContext = async () => {\r\n const context = getPageContext();\r\n console.info(\r\n `[Autic] getPageContext tool executed links=${context.links.length} interactables=${context.interactables.length} summary_len=${context.summary.length}`,\r\n );\r\n};\r\n\r\nexport const executeToolCalls = async (toolCalls: AgentToolCall[]) => {\r\n for (const toolCall of toolCalls) {\r\n if (toolCall.tool === \"interact\") {\r\n await executeInteract(toolCall);\r\n continue;\r\n }\r\n\r\n if (toolCall.tool === \"scroll\") {\r\n await executeScroll(toolCall);\r\n continue;\r\n }\r\n\r\n if (toolCall.tool === \"getPageContext\") {\r\n await executeGetPageContext();\r\n continue;\r\n }\r\n\r\n if (toolCall.tool === \"navigate\") {\r\n const terminalNavigation = await executeNavigate(toolCall);\r\n if (terminalNavigation) {\r\n break;\r\n }\r\n }\r\n }\r\n};\r\n\r\n// ── Agent-mode tool execution (returns results) ─────────────────────\r\n\r\nexport type ToolCallWithId = AgentToolCall & {\r\n call_id: string;\r\n};\r\n\r\nexport interface ToolCallResult {\r\n call_id: string;\r\n result: string;\r\n}\r\n\r\n/**\r\n * Execute a single tool call and return a result string.\r\n * Used by the agent loop to feed results back into the LLM.\r\n */\r\nexport const executeSingleToolCall = async (\r\n call: ToolCallWithId,\r\n): Promise<ToolCallResult> => {\r\n const callId = call.call_id;\r\n try {\r\n if (call.tool === \"interact\") {\r\n await executeInteract(call);\r\n return {\r\n call_id: callId,\r\n result: `Etkileşim başarılı: ${call.action}`,\r\n };\r\n }\r\n\r\n if (call.tool === \"scroll\") {\r\n await executeScroll(call);\r\n return {\r\n call_id: callId,\r\n result: \"Öğeye kaydırma başarılı.\",\r\n };\r\n }\r\n\r\n if (call.tool === \"getPageContext\") {\r\n const context = getPageContext();\r\n return {\r\n call_id: callId,\r\n result: context.summary,\r\n };\r\n }\r\n\r\n if (call.tool === \"navigate\") {\r\n await executeNavigate(call);\r\n // Wait for navigation / SPA routing to settle\r\n await new Promise((resolve) => setTimeout(resolve, 1500));\r\n const context = getPageContext();\r\n return {\r\n call_id: callId,\r\n result: `Navigasyon tamamlandı. Şu anki sayfa: ${window.location.href}\\nSayfa bağlamı: ${context.summary}`,\r\n };\r\n }\r\n\r\n return { call_id: callId, result: \"Bilinmeyen araç.\" };\r\n } catch (error) {\r\n const msg = error instanceof Error ? error.message : String(error);\r\n console.warn(`[Autic] Tool execution error: ${call.tool}`, error);\r\n return { call_id: callId, result: `Hata: ${msg}` };\r\n }\r\n};\r\n\r\nconst restoreCursorFromStorageForCurrentUrl = () => {\r\n if (typeof document === \"undefined\" || typeof window === \"undefined\") {\r\n return;\r\n }\r\n\r\n const stored = getPersistedCursorState();\r\n if (!stored || stored.url !== window.location.href) {\r\n return;\r\n }\r\n\r\n ensureCursor();\r\n};\r\n\r\nif (typeof document !== \"undefined\") {\r\n if (document.readyState === \"loading\") {\r\n document.addEventListener(\"DOMContentLoaded\", restoreCursorFromStorageForCurrentUrl, {\r\n once: true,\r\n });\r\n } else {\r\n restoreCursorFromStorageForCurrentUrl();\r\n }\r\n}\r\n","import {\r\n savePendingAgentResume,\r\n clearPendingAgentResume,\r\n type PendingAgentResume,\r\n} from \"../agent/tools\";\r\n\r\nexport type ChatRole = \"system\" | \"user\" | \"assistant\";\r\n\r\nexport interface ChatMessage {\r\n role: ChatRole;\r\n content: string;\r\n}\r\n\r\ninterface ApiErrorBody {\r\n detail?: string;\r\n error?: string;\r\n message?: string;\r\n}\r\n\r\ninterface SseEventPayload {\r\n type?: string;\r\n session_id?: string;\r\n user_text?: string;\r\n assistant_text?: string;\r\n delta?: string;\r\n audio?: string;\r\n format?: string;\r\n mime_type?: string;\r\n sample_rate?: number;\r\n error?: string;\r\n}\r\n\r\ninterface TtsWsEventPayload {\r\n type?: string;\r\n request_id?: string;\r\n seq?: number;\r\n audio?: string;\r\n format?: string;\r\n mime_type?: string;\r\n sample_rate?: number;\r\n error?: string;\r\n retryable?: boolean;\r\n last_seq?: number;\r\n}\r\n\r\ninterface SttWsEventPayload {\r\n type?: string;\r\n session_id?: string;\r\n seq?: number;\r\n text?: string;\r\n error?: string;\r\n retryable?: boolean;\r\n}\r\n\r\nexport type AudioStreamState = \"rendering\" | \"playing\" | \"done\" | \"fallback\";\r\nexport const TTS_WS_RETRY_DELAYS_MS = [250, 750, 1500];\r\n\r\nconst normalizeBaseUrl = (baseUrl: string): string => {\r\n const trimmed = baseUrl.trim().replace(/\\/+$/, \"\");\r\n if (/^https?:\\/\\//i.test(trimmed)) {\r\n return trimmed;\r\n }\r\n // Treat host-only values like \"api.bulut.lu\" as HTTPS absolute URLs.\r\n return `https://${trimmed}`;\r\n};\r\nconst toWebSocketUrl = (baseUrl: string, path: string): string => {\r\n const normalized = normalizeBaseUrl(baseUrl);\r\n const url = new URL(normalized);\r\n url.protocol = url.protocol === \"https:\" ? \"wss:\" : \"ws:\";\r\n url.pathname = `${url.pathname.replace(/\\/$/, \"\")}${path}`;\r\n url.search = \"\";\r\n url.hash = \"\";\r\n return url.toString();\r\n};\r\n\r\nconst createRequestId = (): string => {\r\n if (typeof crypto !== \"undefined\" && \"randomUUID\" in crypto) {\r\n return crypto.randomUUID();\r\n }\r\n return `tts-${Date.now()}-${Math.random().toString(16).slice(2)}`;\r\n};\r\n\r\nexport const parseTtsWsEventPayload = (\r\n value: unknown,\r\n): TtsWsEventPayload | null => {\r\n try {\r\n if (typeof value !== \"string\") {\r\n return null;\r\n }\r\n return JSON.parse(value) as TtsWsEventPayload;\r\n } catch {\r\n return null;\r\n }\r\n};\r\n\r\nexport const parseSttWsEventPayload = (\r\n value: unknown,\r\n): SttWsEventPayload | null => {\r\n try {\r\n if (typeof value !== \"string\") {\r\n return null;\r\n }\r\n return JSON.parse(value) as SttWsEventPayload;\r\n } catch {\r\n return null;\r\n }\r\n};\r\n\r\nexport const shouldAcceptAudioSeq = (\r\n incomingSeq: number,\r\n highestSeqSeen: number,\r\n): boolean => incomingSeq > highestSeqSeen;\r\n\r\nexport const shouldFallbackToSse = (error: unknown): boolean => {\r\n if (typeof error === \"object\" && error !== null && \"retryable\" in error) {\r\n return Boolean((error as { retryable?: boolean }).retryable);\r\n }\r\n return true;\r\n};\r\n\r\nconst parseErrorBody = async (response: Response): Promise<string> => {\r\n try {\r\n const data = (await response.json()) as ApiErrorBody;\r\n const detail = data.detail;\r\n if (typeof detail === \"string\") return detail;\r\n if (detail && typeof detail === \"object\") return JSON.stringify(detail);\r\n return data.error || data.message || response.statusText;\r\n } catch {\r\n return response.statusText;\r\n }\r\n};\r\n\r\nconst sleep = (ms: number): Promise<void> =>\r\n new Promise((resolve) => {\r\n setTimeout(resolve, ms);\r\n });\r\n\r\nexport const base64ToUint8Array = (base64: string): Uint8Array<ArrayBuffer> => {\r\n // Strip potential data URI prefix if present\r\n const cleanBase64 = base64.replace(/^data:audio\\/\\w+;base64,/, \"\");\r\n const binaryString = atob(cleanBase64);\r\n const bytes = new Uint8Array(binaryString.length) as Uint8Array<ArrayBuffer>;\r\n for (let i = 0; i < binaryString.length; i += 1) {\r\n bytes[i] = binaryString.charCodeAt(i);\r\n }\r\n return bytes;\r\n};\r\n\r\nconst blobToBase64 = async (blob: Blob): Promise<string> => {\r\n const bytes = new Uint8Array(await blob.arrayBuffer());\r\n const chunkSize = 0x8000;\r\n let binary = \"\";\r\n for (let i = 0; i < bytes.length; i += chunkSize) {\r\n binary += String.fromCharCode(...bytes.subarray(i, i + chunkSize));\r\n }\r\n return btoa(binary);\r\n};\r\n\r\nconst createWavHeader = (\r\n length: number,\r\n sampleRate: number = 16000,\r\n): Uint8Array<ArrayBuffer> => {\r\n const buffer = new ArrayBuffer(44);\r\n const view = new DataView(buffer);\r\n const channels = 1;\r\n\r\n // RIFF chunk descriptor\r\n view.setUint32(0, 0x52494646, false); // \"RIFF\"\r\n view.setUint32(4, 36 + length, true); // file length - 8\r\n view.setUint32(8, 0x57415645, false); // \"WAVE\"\r\n\r\n // fmt sub-chunk\r\n view.setUint32(12, 0x666d7420, false); // \"fmt \"\r\n view.setUint32(16, 16, true); // Subchunk1Size (16 for PCM)\r\n view.setUint16(20, 1, true); // AudioFormat (1 for PCM)\r\n view.setUint16(22, channels, true); // NumChannels\r\n view.setUint32(24, sampleRate, true); // SampleRate\r\n view.setUint32(28, sampleRate * channels * 2, true); // ByteRate\r\n view.setUint16(32, channels * 2, true); // BlockAlign\r\n view.setUint16(34, 16, true); // BitsPerSample\r\n\r\n // data sub-chunk\r\n view.setUint32(36, 0x64617461, false); // \"data\"\r\n view.setUint32(40, length, true); // Subchunk2Size\r\n\r\n return new Uint8Array(buffer) as Uint8Array<ArrayBuffer>;\r\n};\r\nconst waitForPlaybackEnd = async (\r\n audioElement: HTMLAudioElement,\r\n): Promise<void> => {\r\n if (audioElement.ended) {\r\n return;\r\n }\r\n\r\n await new Promise<void>((resolve, reject) => {\r\n const watchdog = window.setInterval(() => {\r\n if (!audioElement.ended) {\r\n console.info(\"[Bulut] playback watchdog: still playing...\");\r\n }\r\n }, 30000);\r\n\r\n const onEnded = () => {\r\n cleanup();\r\n resolve();\r\n };\r\n\r\n const onError = () => {\r\n cleanup();\r\n reject(new Error(\"Ses oynatma hatası oluştu.\"));\r\n };\r\n\r\n const cleanup = () => {\r\n window.clearInterval(watchdog);\r\n audioElement.removeEventListener(\"ended\", onEnded);\r\n audioElement.removeEventListener(\"error\", onError);\r\n };\r\n\r\n audioElement.addEventListener(\"ended\", onEnded);\r\n audioElement.addEventListener(\"error\", onError);\r\n });\r\n};\r\n\r\n\r\n\r\nconst playBufferedAudio = async (\r\n chunks: Uint8Array<ArrayBuffer>[],\r\n mimeType: string,\r\n sampleRate: number = 16000,\r\n onAudioStateChange?: (state: AudioStreamState) => void,\r\n): Promise<void> => {\r\n if (chunks.length === 0) {\r\n onAudioStateChange?.(\"done\");\r\n return;\r\n }\r\n\r\n // Debug info\r\n const totalBytes = chunks.reduce((acc, c) => acc + c.byteLength, 0);\r\n console.log(`[Bulut] Playing buffered audio: ${chunks.length} chunks, ${totalBytes} bytes, type=${mimeType}`);\r\n\r\n onAudioStateChange?.(\"fallback\");\r\n\r\n const blobParts: ArrayBuffer[] = chunks.map((chunk) => {\r\n const copied = new Uint8Array(chunk.byteLength) as Uint8Array<ArrayBuffer>;\r\n copied.set(chunk);\r\n return copied.buffer;\r\n });\r\n\r\n // Verify magic numbers and detect MIME type\r\n let detectedMime = mimeType;\r\n if (chunks.length > 0 && chunks[0].length >= 4) {\r\n const header = Array.from(chunks[0].slice(0, 4))\r\n .map(b => b.toString(16).padStart(2, '0').toUpperCase())\r\n .join(' ');\r\n console.log(`[Bulut] Audio header (hex): ${header}`);\r\n\r\n // Magic number detection\r\n if (header.startsWith(\"49 44 33\")) { // ID3\r\n detectedMime = \"audio/mpeg\";\r\n } else if (header.startsWith(\"FF F3\") || header.startsWith(\"FF F2\")) { // MP3 Sync\r\n detectedMime = \"audio/mpeg\";\r\n } else if (header.startsWith(\"52 49 46 46\")) { // RIFF (WAV)\r\n detectedMime = \"audio/wav\";\r\n } else if (header.startsWith(\"1A 45 DF A3\")) { // EBML (WebM)\r\n detectedMime = \"audio/webm\";\r\n }\r\n }\r\n\r\n // Ensure valid MIME type\r\n // Ensure valid MIME type or wrap raw PCM\r\n let safeMimeType = detectedMime && detectedMime.includes(\"/\") ? detectedMime : \"audio/mpeg\";\r\n let finalBlobParts: BlobPart[] = blobParts;\r\n\r\n if (mimeType === \"audio/pcm\") {\r\n // Wrap raw PCM in WAV container\r\n const totalLength = chunks.reduce((acc, c) => acc + c.byteLength, 0);\r\n const header = createWavHeader(totalLength, sampleRate);\r\n finalBlobParts = [header.buffer, ...blobParts];\r\n safeMimeType = \"audio/wav\";\r\n console.log(`[Bulut] Wrapped raw PCM in WAV (rate=${sampleRate})`);\r\n }\r\n\r\n console.log(`[Bulut] Creating blob with type: ${safeMimeType} (original: ${mimeType})`);\r\n const blob = new Blob(finalBlobParts, { type: safeMimeType });\r\n\r\n const audioElement = new Audio();\r\n const objectUrl = URL.createObjectURL(blob);\r\n\r\n try {\r\n audioElement.preload = \"auto\";\r\n audioElement.autoplay = true;\r\n // Some browsers need this\r\n audioElement.setAttribute(\"playsinline\", \"true\");\r\n audioElement.src = objectUrl;\r\n\r\n await audioElement.play();\r\n onAudioStateChange?.(\"playing\");\r\n await waitForPlaybackEnd(audioElement);\r\n onAudioStateChange?.(\"done\");\r\n } catch (err) {\r\n console.error(`[Bulut] Playback failed: ${err}`, { mimeType: safeMimeType, size: blob.size });\r\n onAudioStateChange?.(\"done\"); // Signal done to unblock UI even on error\r\n throw err;\r\n } finally {\r\n audioElement.pause();\r\n audioElement.removeAttribute(\"src\");\r\n audioElement.load();\r\n URL.revokeObjectURL(objectUrl);\r\n }\r\n};\r\n\r\nexport interface StreamController {\r\n stop: () => void;\r\n done: Promise<void>;\r\n}\r\n\r\nexport const parseSseEventPayload = (eventBlock: string): SseEventPayload | null => {\r\n const dataLines = eventBlock\r\n .split(/\\r?\\n/)\r\n .map((line) => line.trim())\r\n .filter((line) => line.startsWith(\"data:\"))\r\n .map((line) => line.slice(5).trimStart());\r\n\r\n if (dataLines.length === 0) {\r\n return null;\r\n }\r\n\r\n const dataStr = dataLines.join(\"\\n\");\r\n if (dataStr === \"[DONE]\") {\r\n return { type: \"done\" };\r\n }\r\n\r\n try {\r\n return JSON.parse(dataStr) as SseEventPayload;\r\n } catch (error) {\r\n console.warn(\"Error parsing SSE chunk:\", error);\r\n return null;\r\n }\r\n};\r\n\r\nexport const isAudioSsePayload = (\r\n payload: SseEventPayload,\r\n): payload is SseEventPayload & { audio: string } =>\r\n typeof payload.audio === \"string\" &&\r\n (payload.type === undefined || payload.type === \"audio\");\r\n\r\n// ── Separated Endpoint Helpers ──────────────────────────────────────\r\n\r\nexport async function transcribeAudio(\r\n baseUrl: string,\r\n file: File,\r\n projectId: string,\r\n sessionId: string | null,\r\n language: string,\r\n onRequestSent?: () => void,\r\n): Promise<{ text: string; session_id: string }> {\r\n const url = `${normalizeBaseUrl(baseUrl)}/chat/stt`;\r\n const formData = new FormData();\r\n formData.append(\"file\", file);\r\n formData.append(\"project_id\", projectId);\r\n if (sessionId) formData.append(\"session_id\", sessionId);\r\n formData.append(\"language\", language);\r\n\r\n const responsePromise = fetch(url, { method: \"POST\", body: formData });\r\n onRequestSent?.();\r\n const response = await responsePromise;\r\n if (!response.ok) {\r\n throw new Error(await parseErrorBody(response));\r\n }\r\n return response.json();\r\n}\r\n\r\nexport interface SttWsResult {\r\n text: string;\r\n session_id: string;\r\n}\r\n\r\nexport interface SttWsEvents {\r\n onRequestSent?: () => void;\r\n onSessionId?: (sessionId: string) => void;\r\n onPartial?: (payload: { seq: number; text: string }) => void;\r\n}\r\n\r\nexport interface SttWsController {\r\n pushChunk: (chunk: Blob) => Promise<void>;\r\n stop: () => Promise<SttWsResult>;\r\n cancel: () => void;\r\n}\r\n\r\nexport const startSttWebSocketStream = (\r\n baseUrl: string,\r\n config: {\r\n projectId: string;\r\n sessionId: string | null;\r\n language?: string;\r\n mimeType?: string;\r\n },\r\n events: SttWsEvents = {},\r\n): SttWsController => {\r\n const wsUrl = toWebSocketUrl(baseUrl, \"/chat/stt/ws\");\r\n console.info(\"[Bulut] STT WS connecting to\", wsUrl);\r\n const socket = new WebSocket(wsUrl);\r\n let seq = 0;\r\n let finalText = \"\";\r\n let finalSessionId = config.sessionId || \"\";\r\n let stopped = false;\r\n let settled = false;\r\n // All chunk sends and the final stop are chained through sendQueue\r\n // so the \"stop\" message always follows all enqueued chunks.\r\n let sendQueue: Promise<void> = Promise.resolve();\r\n\r\n let resolveStart: (() => void) | null = null;\r\n let rejectStart: ((error: Error & { retryable?: boolean }) => void) | null = null;\r\n const startPromise = new Promise<void>((resolve, reject) => {\r\n resolveStart = resolve;\r\n rejectStart = reject;\r\n });\r\n\r\n let resolveDone: ((result: SttWsResult) => void) | null = null;\r\n let rejectDone: ((error: Error & { retryable?: boolean }) => void) | null = null;\r\n const donePromise = new Promise<SttWsResult>((resolve, reject) => {\r\n resolveDone = resolve;\r\n rejectDone = reject;\r\n });\r\n\r\n const rejectAll = (error: Error & { retryable?: boolean }) => {\r\n if (settled) return;\r\n settled = true;\r\n console.warn(\"[Bulut] STT WS rejected:\", error.message);\r\n rejectStart?.(error);\r\n rejectDone?.(error);\r\n };\r\n\r\n const resolveDoneIfPossible = () => {\r\n if (settled) return;\r\n if (!finalText.trim() || !finalSessionId) return;\r\n settled = true;\r\n resolveStart?.();\r\n resolveDone?.({\r\n text: finalText.trim(),\r\n session_id: finalSessionId,\r\n });\r\n };\r\n\r\n socket.onopen = () => {\r\n console.info(\"[Bulut] STT WS connected, sending start\");\r\n events.onRequestSent?.();\r\n socket.send(\r\n JSON.stringify({\r\n type: \"start\",\r\n project_id: config.projectId,\r\n session_id: config.sessionId || undefined,\r\n language: config.language || \"tr\",\r\n mime_type: config.mimeType || \"audio/webm\",\r\n }),\r\n );\r\n };\r\n\r\n socket.onmessage = (event) => {\r\n const payload = parseSttWsEventPayload(String(event.data));\r\n if (!payload) return;\r\n\r\n if (payload.type === \"start_ack\" && typeof payload.session_id === \"string\") {\r\n console.info(\"[Bulut] STT WS start_ack received, session:\", payload.session_id);\r\n finalSessionId = payload.session_id;\r\n events.onSessionId?.(payload.session_id);\r\n resolveStart?.();\r\n return;\r\n }\r\n\r\n if (payload.type === \"partial\" && typeof payload.text === \"string\") {\r\n events.onPartial?.({\r\n seq: typeof payload.seq === \"number\" ? payload.seq : 0,\r\n text: payload.text,\r\n });\r\n return;\r\n }\r\n\r\n if (payload.type === \"final\" && typeof payload.text === \"string\") {\r\n console.info(\"[Bulut] STT WS final text received:\", payload.text.slice(0, 80));\r\n finalText = payload.text;\r\n if (typeof payload.session_id === \"string\") {\r\n finalSessionId = payload.session_id;\r\n events.onSessionId?.(payload.session_id);\r\n }\r\n return;\r\n }\r\n\r\n if (payload.type === \"done\") {\r\n console.info(\"[Bulut] STT WS done\");\r\n resolveDoneIfPossible();\r\n socket.close();\r\n return;\r\n }\r\n\r\n if (payload.type === \"error\") {\r\n console.error(\"[Bulut] STT WS server error:\", payload.error);\r\n const err = buildError(payload.error || \"stt_ws_error\", payload.retryable !== false);\r\n rejectAll(err);\r\n socket.close();\r\n }\r\n };\r\n\r\n socket.onerror = (ev) => {\r\n console.error(\"[Bulut] STT WS transport error\", ev);\r\n rejectAll(buildError(\"stt_ws_transport_error\", true));\r\n };\r\n\r\n socket.onclose = (ev) => {\r\n console.info(\"[Bulut] STT WS closed code=%d reason=%s\", ev.code, ev.reason);\r\n if (settled) return;\r\n if (finalText && finalSessionId) {\r\n resolveDoneIfPossible();\r\n return;\r\n }\r\n rejectAll(buildError(\"stt_ws_closed_before_done\", true));\r\n };\r\n\r\n return {\r\n pushChunk: (chunk: Blob): Promise<void> => {\r\n if (stopped || chunk.size === 0) return Promise.resolve();\r\n // Chain the entire operation (wait for connection, base64-encode,\r\n // send) into sendQueue so that a later stop() is guaranteed to\r\n // follow all previously-enqueued chunks.\r\n sendQueue = sendQueue.then(async () => {\r\n if (stopped) return;\r\n await startPromise;\r\n if (stopped) return;\r\n const audio = await blobToBase64(chunk);\r\n seq += 1;\r\n if (stopped || socket.readyState !== WebSocket.OPEN) return;\r\n console.debug(\"[Bulut] STT WS sending chunk seq=%d size=%d\", seq, chunk.size);\r\n socket.send(JSON.stringify({ type: \"chunk\", seq, audio }));\r\n });\r\n return sendQueue;\r\n },\r\n stop: (): Promise<SttWsResult> => {\r\n console.info(\"[Bulut] STT WS stop requested, draining %d pending chunks\", seq);\r\n // Chain after all pending pushChunk operations so the server\r\n // always receives every chunk before the stop message.\r\n sendQueue = sendQueue.then(async () => {\r\n await startPromise;\r\n if (stopped) return;\r\n if (socket.readyState === WebSocket.OPEN) {\r\n console.info(\"[Bulut] STT WS sending stop after seq=%d\", seq);\r\n socket.send(JSON.stringify({ type: \"stop\" }));\r\n }\r\n });\r\n return donePromise;\r\n },\r\n cancel: () => {\r\n stopped = true;\r\n try {\r\n socket.close();\r\n } catch {\r\n // no-op\r\n }\r\n },\r\n };\r\n};\r\n\r\ninterface TtsCollectResult {\r\n chunks: Uint8Array<ArrayBuffer>[];\r\n mimeType: string;\r\n sampleRate: number;\r\n}\r\n\r\nconst buildError = (message: string, retryable: boolean = true): Error & { retryable: boolean } => {\r\n const error = new Error(message) as Error & { retryable: boolean };\r\n error.retryable = retryable;\r\n return error;\r\n};\r\n\r\nconst collectTtsViaSse = async (\r\n baseUrl: string,\r\n assistantText: string,\r\n voice: string,\r\n accessibilityMode: boolean,\r\n isStopped: () => boolean,\r\n setReader: (reader: ReadableStreamDefaultReader<Uint8Array> | undefined) => void,\r\n): Promise<TtsCollectResult> => {\r\n const ttsFormData = new FormData();\r\n ttsFormData.append(\"text\", assistantText);\r\n ttsFormData.append(\"voice\", voice);\r\n ttsFormData.append(\"accessibility_mode\", String(accessibilityMode));\r\n\r\n const ttsResponse = await fetch(`${normalizeBaseUrl(baseUrl)}/chat/tts`, {\r\n method: \"POST\",\r\n body: ttsFormData,\r\n });\r\n\r\n if (!ttsResponse.ok) {\r\n throw buildError(await parseErrorBody(ttsResponse), false);\r\n }\r\n\r\n const reader = ttsResponse.body?.getReader();\r\n if (!reader) {\r\n throw buildError(\"TTS response body is not readable\", false);\r\n }\r\n\r\n setReader(reader);\r\n\r\n const chunks: Uint8Array<ArrayBuffer>[] = [];\r\n let mimeType = \"audio/mpeg\";\r\n let sampleRate = 16000;\r\n const decoder = new TextDecoder();\r\n let buffer = \"\";\r\n\r\n while (true) {\r\n if (isStopped()) {\r\n break;\r\n }\r\n\r\n const { done, value } = await reader.read();\r\n if (done) {\r\n break;\r\n }\r\n\r\n buffer += decoder.decode(value, { stream: true });\r\n const blocks = buffer.split(/\\r?\\n\\r?\\n/);\r\n buffer = blocks.pop() || \"\";\r\n\r\n for (const block of blocks) {\r\n const payload = parseSseEventPayload(block);\r\n if (!payload) {\r\n continue;\r\n }\r\n\r\n if (isAudioSsePayload(payload)) {\r\n const format = payload.format || \"mp3\";\r\n mimeType = payload.mime_type || (format === \"webm\" ? \"audio/webm\" : \"audio/mpeg\");\r\n chunks.push(base64ToUint8Array(payload.audio));\r\n if (payload.sample_rate) {\r\n sampleRate = payload.sample_rate;\r\n }\r\n }\r\n }\r\n }\r\n\r\n reader.releaseLock();\r\n setReader(undefined);\r\n\r\n return { chunks, mimeType, sampleRate };\r\n};\r\n\r\nconst collectTtsViaWebSocket = async (\r\n baseUrl: string,\r\n assistantText: string,\r\n voice: string,\r\n accessibilityMode: boolean,\r\n isStopped: () => boolean,\r\n setSocket: (socket: WebSocket | null) => void,\r\n): Promise<TtsCollectResult> => {\r\n const wsUrl = toWebSocketUrl(baseUrl, \"/chat/tts/ws\");\r\n const requestId = createRequestId();\r\n const chunks: Uint8Array<ArrayBuffer>[] = [];\r\n let mimeType = \"audio/mpeg\";\r\n let sampleRate = 16000;\r\n let highestSeqSeen = 0;\r\n\r\n const connectOnce = (): Promise<void> =>\r\n new Promise((resolve, reject) => {\r\n if (isStopped()) {\r\n reject(buildError(\"stream_stopped\", false));\r\n return;\r\n }\r\n\r\n let done = false;\r\n let finalError: (Error & { retryable?: boolean }) | null = null;\r\n const socket = new WebSocket(wsUrl);\r\n setSocket(socket);\r\n\r\n const finalize = (\r\n mode: \"resolve\" | \"reject\",\r\n error?: Error & { retryable?: boolean },\r\n ) => {\r\n socket.onopen = null;\r\n socket.onmessage = null;\r\n socket.onerror = null;\r\n socket.onclose = null;\r\n setSocket(null);\r\n if (mode === \"resolve\") {\r\n resolve();\r\n return;\r\n }\r\n reject(error || buildError(\"tts_ws_closed\", true));\r\n };\r\n\r\n socket.onopen = () => {\r\n console.info(\r\n `[Bulut] TTS WS connected request_id=${requestId} resume_seq=${highestSeqSeen}`,\r\n );\r\n socket.send(\r\n JSON.stringify({\r\n type: \"start\",\r\n request_id: requestId,\r\n text: assistantText,\r\n voice,\r\n accessibility_mode: accessibilityMode,\r\n last_seq: highestSeqSeen,\r\n }),\r\n );\r\n };\r\n\r\n socket.onmessage = (event) => {\r\n const payload = parseTtsWsEventPayload(String(event.data));\r\n if (!payload) {\r\n console.warn(\"[Bulut] TTS WS invalid JSON payload\");\r\n return;\r\n }\r\n\r\n if (payload.type === \"audio\" && typeof payload.audio === \"string\") {\r\n const seq = typeof payload.seq === \"number\" ? payload.seq : 0;\r\n if (shouldAcceptAudioSeq(seq, highestSeqSeen)) {\r\n chunks.push(base64ToUint8Array(payload.audio));\r\n highestSeqSeen = seq;\r\n if (payload.mime_type) {\r\n mimeType = payload.mime_type;\r\n }\r\n if (typeof payload.sample_rate === \"number\") {\r\n sampleRate = payload.sample_rate;\r\n }\r\n } else {\r\n console.info(\r\n `[Bulut] TTS WS duplicate chunk ignored request_id=${requestId} seq=${seq} seen=${highestSeqSeen}`,\r\n );\r\n }\r\n\r\n if (socket.readyState === WebSocket.OPEN) {\r\n socket.send(\r\n JSON.stringify({\r\n type: \"ack\",\r\n request_id: requestId,\r\n last_seq: highestSeqSeen,\r\n }),\r\n );\r\n }\r\n return;\r\n }\r\n\r\n if (payload.type === \"done\") {\r\n const streamLastSeq =\r\n typeof payload.last_seq === \"number\" ? payload.last_seq : highestSeqSeen;\r\n if (streamLastSeq > highestSeqSeen) {\r\n finalError = buildError(\"tts_ws_sequence_gap\", true);\r\n done = false;\r\n socket.close();\r\n return;\r\n }\r\n done = true;\r\n socket.close();\r\n return;\r\n }\r\n\r\n if (payload.type === \"error\") {\r\n finalError = buildError(payload.error || \"tts_ws_error\", payload.retryable !== false);\r\n done = false;\r\n socket.close();\r\n }\r\n };\r\n\r\n socket.onerror = () => {\r\n if (!finalError) {\r\n finalError = buildError(\"tts_ws_transport_error\", true);\r\n }\r\n };\r\n\r\n socket.onclose = () => {\r\n if (isStopped()) {\r\n finalize(\"reject\", buildError(\"stream_stopped\", false));\r\n return;\r\n }\r\n if (done) {\r\n finalize(\"resolve\");\r\n return;\r\n }\r\n finalize(\"reject\", finalError || buildError(\"tts_ws_closed_before_done\", true));\r\n };\r\n });\r\n\r\n for (let attempt = 0; attempt <= TTS_WS_RETRY_DELAYS_MS.length; attempt += 1) {\r\n if (attempt > 0) {\r\n const delay = TTS_WS_RETRY_DELAYS_MS[attempt - 1];\r\n console.warn(\r\n `[Bulut] TTS WS retry attempt=${attempt} delay_ms=${delay} last_seq=${highestSeqSeen}`,\r\n );\r\n await sleep(delay);\r\n }\r\n\r\n try {\r\n await connectOnce();\r\n return { chunks, mimeType, sampleRate };\r\n } catch (error) {\r\n const retryable =\r\n shouldFallbackToSse(error);\r\n const message = error instanceof Error ? error.message : String(error);\r\n console.warn(\r\n `[Bulut] TTS WS attempt failed attempt=${attempt} retryable=${retryable} error=${message}`,\r\n );\r\n if (!retryable || attempt === TTS_WS_RETRY_DELAYS_MS.length) {\r\n throw error;\r\n }\r\n }\r\n }\r\n\r\n throw buildError(\"tts_ws_exhausted\", true);\r\n};\r\n\r\n// ── Agent-mode Types ────────────────────────────────────────────────\r\n\r\nexport interface AgentToolCallInfo {\r\n call_id: string;\r\n tool: string;\r\n args: Record<string, unknown>;\r\n}\r\n\r\nexport interface AgentVoiceChatEvents {\r\n onSttRequestSent?: () => void;\r\n onTranscription?: (data: {\r\n session_id: string;\r\n user_text: string;\r\n }) => void;\r\n onAssistantDelta?: (delta: string) => void;\r\n onAssistantDone?: (assistantText: string) => void;\r\n onAudioStateChange?: (state: AudioStreamState) => void;\r\n onError?: (error: string) => void;\r\n /** Called when the agent requests tool execution on the frontend. */\r\n onToolCalls?: (calls: AgentToolCallInfo[]) => void;\r\n /** Called after each tool has been executed with the result. */\r\n onToolResult?: (callId: string, toolName: string, result: string) => void;\r\n /** Called at the start of each agent iteration. */\r\n onIteration?: (iteration: number, maxIterations: number) => void;\r\n /** Called when the backend confirms / creates a session ID. */\r\n onSessionId?: (sessionId: string) => void;\r\n /**\r\n * Called when the agent emits a reply text followed by tool calls.\r\n * This text is spoken aloud before the tools run so the user hears\r\n * every piece of the conversation, not just the final reply.\r\n */\r\n onIntermediateReply?: (text: string) => void;\r\n}\r\n\r\n/**\r\n * Standalone TTS helper: synthesize + play a text snippet.\r\n * Uses WebSocket TTS with SSE fallback, same as the main stream functions.\r\n */\r\nexport const speakText = async (\r\n baseUrl: string,\r\n text: string,\r\n voice: string,\r\n accessibilityMode: boolean,\r\n onAudioStateChange?: (state: AudioStreamState) => void,\r\n): Promise<void> => {\r\n const trimmed = text.trim();\r\n if (!trimmed) return;\r\n\r\n console.info(`[Bulut] speakText start (${trimmed.length} chars)`);\r\n onAudioStateChange?.(\"rendering\");\r\n let ttsResult: TtsCollectResult;\r\n\r\n const neverStopped = () => false;\r\n\r\n try {\r\n ttsResult = await collectTtsViaWebSocket(\r\n baseUrl, trimmed, voice, accessibilityMode,\r\n neverStopped,\r\n () => {},\r\n );\r\n } catch {\r\n ttsResult = await collectTtsViaSse(\r\n baseUrl, trimmed, voice, accessibilityMode,\r\n neverStopped,\r\n () => {},\r\n );\r\n }\r\n\r\n if (ttsResult.chunks.length > 0) {\r\n await playBufferedAudio(\r\n ttsResult.chunks, ttsResult.mimeType, ttsResult.sampleRate,\r\n onAudioStateChange,\r\n );\r\n } else {\r\n onAudioStateChange?.(\"done\");\r\n }\r\n};\r\n\r\n// ── Agent Voice Chat Stream (STT → Agent WS → TTS) ─────────────────\r\n\r\nexport const agentVoiceChatStream = (\r\n baseUrl: string,\r\n audioFile: File,\r\n projectId: string,\r\n sessionId: string | null,\r\n config: {\r\n model: string;\r\n voice: string;\r\n pageContext?: string;\r\n accessibilityMode?: boolean;\r\n },\r\n events: AgentVoiceChatEvents,\r\n executeTool: (call: AgentToolCallInfo) => Promise<{ call_id: string; result: string }>,\r\n): StreamController => {\r\n let isStopped = false;\r\n let activeSocket: WebSocket | null = null;\r\n let activeReader: ReadableStreamDefaultReader<Uint8Array> | undefined;\r\n let errorEmitted = false;\r\n\r\n const donePromise = new Promise<void>(async (resolve, reject) => {\r\n try {\r\n // ── 1. STT ────────────────────────────────────────────────\r\n if (isStopped) return resolve();\r\n const sttResult = await transcribeAudio(\r\n baseUrl,\r\n audioFile,\r\n projectId,\r\n sessionId,\r\n \"tr\",\r\n events.onSttRequestSent,\r\n );\r\n\r\n const currentSessionId = sttResult.session_id;\r\n let effectiveSessionId = currentSessionId;\r\n const userText = sttResult.text;\r\n\r\n events.onTranscription?.({\r\n session_id: currentSessionId,\r\n user_text: userText,\r\n });\r\n\r\n if (isStopped) return resolve();\r\n\r\n // ── 2. Agent loop via WebSocket ───────────────────────────\r\n const assistantText = await new Promise<string>((agentResolve, agentReject) => {\r\n if (isStopped) { agentResolve(\"\"); return; }\r\n\r\n const wsUrl = toWebSocketUrl(baseUrl, \"/chat/agent/ws\");\r\n const socket = new WebSocket(wsUrl);\r\n activeSocket = socket;\r\n\r\n let finalReply = \"\";\r\n let resolved = false;\r\n let accumulatedDelta = \"\";\r\n\r\n const finish = (reply: string) => {\r\n if (resolved) return;\r\n resolved = true;\r\n agentResolve(reply);\r\n };\r\n\r\n const fail = (error: Error) => {\r\n if (resolved) return;\r\n resolved = true;\r\n agentReject(error);\r\n };\r\n\r\n socket.onopen = () => {\r\n console.info(\"[Bulut] Agent WS connected\");\r\n socket.send(JSON.stringify({\r\n type: \"start\",\r\n project_id: projectId,\r\n session_id: currentSessionId,\r\n user_text: userText,\r\n model: config.model,\r\n page_context: config.pageContext,\r\n accessibility_mode: config.accessibilityMode,\r\n }));\r\n };\r\n\r\n socket.onmessage = async (event) => {\r\n let data: Record<string, unknown>;\r\n try {\r\n data = JSON.parse(String(event.data));\r\n } catch {\r\n console.warn(\"[Bulut] Agent WS invalid JSON\");\r\n return;\r\n }\r\n\r\n const msgType = data.type as string;\r\n\r\n if (msgType === \"session\" && typeof data.session_id === \"string\") {\r\n effectiveSessionId = data.session_id as string;\r\n events.onSessionId?.(effectiveSessionId);\r\n return;\r\n }\r\n\r\n if (msgType === \"iteration\") {\r\n events.onIteration?.(\r\n data.iteration as number,\r\n data.max_iterations as number,\r\n );\r\n return;\r\n }\r\n\r\n if (msgType === \"reply_delta\" && typeof data.delta === \"string\") {\r\n accumulatedDelta += data.delta;\r\n events.onAssistantDelta?.(data.delta);\r\n return;\r\n }\r\n\r\n if (msgType === \"tool_calls\" && Array.isArray(data.calls)) {\r\n const calls = data.calls as AgentToolCallInfo[];\r\n\r\n // Speak accumulated text before running tools\r\n if (accumulatedDelta.trim()) {\r\n events.onIntermediateReply?.(accumulatedDelta.trim());\r\n }\r\n accumulatedDelta = \"\";\r\n\r\n events.onToolCalls?.(calls);\r\n\r\n const results: { call_id: string; result: string }[] = [];\r\n for (const call of calls) {\r\n // Save resume state before navigate in case of full-page reload\r\n const isNavigate = call.tool === \"navigate\";\r\n if (isNavigate) {\r\n savePendingAgentResume({\r\n sessionId: effectiveSessionId,\r\n projectId,\r\n model: config.model,\r\n voice: config.voice,\r\n accessibilityMode: Boolean(config.accessibilityMode),\r\n pendingToolCalls: calls.map((c) => ({\r\n call_id: c.call_id,\r\n tool: c.tool,\r\n args: c.args,\r\n })),\r\n completedResults: [...results],\r\n });\r\n }\r\n\r\n const result = await executeTool(call);\r\n\r\n // If we reach here, no full-page reload happened\r\n if (isNavigate) {\r\n clearPendingAgentResume();\r\n }\r\n\r\n events.onToolResult?.(call.call_id, call.tool, result.result);\r\n results.push(result);\r\n }\r\n\r\n if (socket.readyState === WebSocket.OPEN) {\r\n socket.send(JSON.stringify({\r\n type: \"tool_results\",\r\n results,\r\n }));\r\n }\r\n return;\r\n }\r\n\r\n if (msgType === \"agent_done\") {\r\n finalReply = (data.final_reply as string) || \"\";\r\n events.onAssistantDone?.(finalReply);\r\n if (typeof data.session_id === \"string\") {\r\n events.onSessionId?.(data.session_id as string);\r\n }\r\n finish(finalReply);\r\n return;\r\n }\r\n\r\n if (msgType === \"error\") {\r\n const errMsg = (data.error as string) || \"Agent error\";\r\n errorEmitted = true;\r\n events.onError?.(errMsg);\r\n fail(new Error(errMsg));\r\n return;\r\n }\r\n };\r\n\r\n socket.onerror = () => {\r\n console.error(\"[Bulut] Agent WS error\");\r\n errorEmitted = true;\r\n events.onError?.(\"Agent WebSocket connection error\");\r\n fail(new Error(\"Agent WebSocket connection error\"));\r\n };\r\n\r\n socket.onclose = () => {\r\n console.info(\"[Bulut] Agent WS closed\");\r\n finish(finalReply);\r\n };\r\n });\r\n\r\n activeSocket = null;\r\n\r\n // ── 3. TTS ────────────────────────────────────────────────\r\n if (isStopped || !assistantText) {\r\n return resolve();\r\n }\r\n\r\n console.info(\r\n `[Bulut] TTS start mode=agent voice=${config.voice}`,\r\n );\r\n\r\n events.onAudioStateChange?.(\"rendering\");\r\n let ttsResult: TtsCollectResult;\r\n\r\n try {\r\n ttsResult = await collectTtsViaWebSocket(\r\n baseUrl,\r\n assistantText,\r\n config.voice,\r\n Boolean(config.accessibilityMode),\r\n () => isStopped,\r\n (socket) => { activeSocket = socket; },\r\n );\r\n } catch (wsError) {\r\n if (isStopped) return resolve();\r\n console.warn(\r\n `[Bulut] TTS WS failed, falling back to SSE: ${wsError instanceof Error ? wsError.message : String(wsError)}`,\r\n );\r\n ttsResult = await collectTtsViaSse(\r\n baseUrl,\r\n assistantText,\r\n config.voice,\r\n Boolean(config.accessibilityMode),\r\n () => isStopped,\r\n (reader) => { activeReader = reader; },\r\n );\r\n }\r\n\r\n if (!isStopped && ttsResult.chunks.length > 0) {\r\n await playBufferedAudio(\r\n ttsResult.chunks,\r\n ttsResult.mimeType,\r\n ttsResult.sampleRate,\r\n events.onAudioStateChange,\r\n );\r\n } else {\r\n events.onAudioStateChange?.(\"done\");\r\n }\r\n\r\n resolve();\r\n } catch (err) {\r\n // Only emit onError if it hasn't been emitted already by the WS handler\r\n if (!errorEmitted) {\r\n const msg = err instanceof Error ? err.message : String(err);\r\n events.onError?.(msg);\r\n }\r\n reject(err);\r\n } finally {\r\n activeReader?.cancel().catch(() => { });\r\n if (activeSocket && activeSocket.readyState <= WebSocket.OPEN) {\r\n activeSocket.close();\r\n }\r\n activeSocket = null;\r\n }\r\n });\r\n\r\n return {\r\n stop: () => {\r\n isStopped = true;\r\n if (activeReader) {\r\n activeReader.cancel().catch(() => { });\r\n }\r\n if (activeSocket && activeSocket.readyState <= WebSocket.OPEN) {\r\n activeSocket.close();\r\n }\r\n },\r\n done: donePromise,\r\n };\r\n};\r\n\r\n// ── Agent Text Chat Stream (no STT, Agent WS → TTS) ────────────────\r\n\r\nexport const agentTextChatStream = (\r\n baseUrl: string,\r\n userText: string,\r\n projectId: string,\r\n sessionId: string | null,\r\n config: {\r\n model: string;\r\n voice: string;\r\n pageContext?: string;\r\n accessibilityMode?: boolean;\r\n },\r\n events: AgentVoiceChatEvents,\r\n executeTool: (call: AgentToolCallInfo) => Promise<{ call_id: string; result: string }>,\r\n): StreamController => {\r\n let isStopped = false;\r\n let activeSocket: WebSocket | null = null;\r\n let activeReader: ReadableStreamDefaultReader<Uint8Array> | undefined;\r\n let errorEmitted = false;\r\n\r\n const donePromise = new Promise<void>(async (resolve, reject) => {\r\n try {\r\n if (isStopped) return resolve();\r\n\r\n // ── 1. Agent loop via WebSocket ───────────────────────────\r\n const assistantText = await new Promise<string>((agentResolve, agentReject) => {\r\n if (isStopped) { agentResolve(\"\"); return; }\r\n\r\n const wsUrl = toWebSocketUrl(baseUrl, \"/chat/agent/ws\");\r\n const socket = new WebSocket(wsUrl);\r\n activeSocket = socket;\r\n\r\n let finalReply = \"\";\r\n let resolved = false;\r\n let effectiveSessionId = sessionId || \"\";\r\n let accumulatedDelta = \"\";\r\n\r\n const finish = (reply: string) => {\r\n if (resolved) return;\r\n resolved = true;\r\n agentResolve(reply);\r\n };\r\n\r\n const fail = (error: Error) => {\r\n if (resolved) return;\r\n resolved = true;\r\n agentReject(error);\r\n };\r\n\r\n socket.onopen = () => {\r\n socket.send(JSON.stringify({\r\n type: \"start\",\r\n project_id: projectId,\r\n session_id: sessionId,\r\n user_text: userText,\r\n model: config.model,\r\n page_context: config.pageContext,\r\n accessibility_mode: config.accessibilityMode,\r\n }));\r\n };\r\n\r\n socket.onmessage = async (event) => {\r\n let data: Record<string, unknown>;\r\n try {\r\n data = JSON.parse(String(event.data));\r\n } catch { return; }\r\n\r\n const msgType = data.type as string;\r\n\r\n if (msgType === \"session\" && typeof data.session_id === \"string\") {\r\n effectiveSessionId = data.session_id as string;\r\n events.onSessionId?.(effectiveSessionId);\r\n return;\r\n }\r\n\r\n if (msgType === \"iteration\") {\r\n events.onIteration?.(\r\n data.iteration as number,\r\n data.max_iterations as number,\r\n );\r\n return;\r\n }\r\n\r\n if (msgType === \"reply_delta\" && typeof data.delta === \"string\") {\r\n accumulatedDelta += data.delta;\r\n events.onAssistantDelta?.(data.delta);\r\n return;\r\n }\r\n\r\n if (msgType === \"tool_calls\" && Array.isArray(data.calls)) {\r\n const calls = data.calls as AgentToolCallInfo[];\r\n\r\n // Speak accumulated text before running tools\r\n if (accumulatedDelta.trim()) {\r\n events.onIntermediateReply?.(accumulatedDelta.trim());\r\n }\r\n accumulatedDelta = \"\";\r\n\r\n events.onToolCalls?.(calls);\r\n\r\n const results: { call_id: string; result: string }[] = [];\r\n for (const call of calls) {\r\n const isNavigate = call.tool === \"navigate\";\r\n if (isNavigate) {\r\n savePendingAgentResume({\r\n sessionId: effectiveSessionId,\r\n projectId,\r\n model: config.model,\r\n voice: config.voice,\r\n accessibilityMode: Boolean(config.accessibilityMode),\r\n pendingToolCalls: calls.map((c) => ({\r\n call_id: c.call_id,\r\n tool: c.tool,\r\n args: c.args,\r\n })),\r\n completedResults: [...results],\r\n });\r\n }\r\n\r\n const result = await executeTool(call);\r\n\r\n if (isNavigate) {\r\n clearPendingAgentResume();\r\n }\r\n\r\n events.onToolResult?.(call.call_id, call.tool, result.result);\r\n results.push(result);\r\n }\r\n\r\n if (socket.readyState === WebSocket.OPEN) {\r\n socket.send(JSON.stringify({\r\n type: \"tool_results\",\r\n results,\r\n }));\r\n }\r\n return;\r\n }\r\n\r\n if (msgType === \"agent_done\") {\r\n finalReply = (data.final_reply as string) || \"\";\r\n events.onAssistantDone?.(finalReply);\r\n if (typeof data.session_id === \"string\") {\r\n events.onSessionId?.(data.session_id as string);\r\n }\r\n finish(finalReply);\r\n return;\r\n }\r\n\r\n if (msgType === \"error\") {\r\n const errMsg = (data.error as string) || \"Agent error\";\r\n errorEmitted = true;\r\n events.onError?.(errMsg);\r\n fail(new Error(errMsg));\r\n return;\r\n }\r\n };\r\n\r\n socket.onerror = () => {\r\n errorEmitted = true;\r\n events.onError?.(\"Agent WebSocket error\");\r\n fail(new Error(\"Agent WebSocket error\"));\r\n };\r\n socket.onclose = () => finish(finalReply);\r\n });\r\n\r\n activeSocket = null;\r\n\r\n // ── 2. TTS ────────────────────────────────────────────────\r\n if (isStopped || !assistantText) return resolve();\r\n\r\n events.onAudioStateChange?.(\"rendering\");\r\n let ttsResult: TtsCollectResult;\r\n\r\n try {\r\n ttsResult = await collectTtsViaWebSocket(\r\n baseUrl, assistantText, config.voice, Boolean(config.accessibilityMode),\r\n () => isStopped,\r\n (socket) => { activeSocket = socket; },\r\n );\r\n } catch (wsError) {\r\n if (isStopped) return resolve();\r\n ttsResult = await collectTtsViaSse(\r\n baseUrl, assistantText, config.voice, Boolean(config.accessibilityMode),\r\n () => isStopped,\r\n (reader) => { activeReader = reader; },\r\n );\r\n }\r\n\r\n if (!isStopped && ttsResult.chunks.length > 0) {\r\n await playBufferedAudio(\r\n ttsResult.chunks, ttsResult.mimeType, ttsResult.sampleRate,\r\n events.onAudioStateChange,\r\n );\r\n } else {\r\n events.onAudioStateChange?.(\"done\");\r\n }\r\n\r\n resolve();\r\n } catch (err) {\r\n if (!errorEmitted) {\r\n const msg = err instanceof Error ? err.message : String(err);\r\n events.onError?.(msg);\r\n }\r\n reject(err);\r\n } finally {\r\n activeReader?.cancel().catch(() => { });\r\n if (activeSocket && activeSocket.readyState <= WebSocket.OPEN) {\r\n activeSocket.close();\r\n }\r\n activeSocket = null;\r\n }\r\n });\r\n\r\n return {\r\n stop: () => {\r\n isStopped = true;\r\n if (activeReader) activeReader.cancel().catch(() => { });\r\n if (activeSocket && activeSocket.readyState <= WebSocket.OPEN) {\r\n activeSocket.close();\r\n }\r\n },\r\n done: donePromise,\r\n };\r\n};\r\n\r\n// ── Agent Resume Stream (after page navigation reload) ──────────────\r\n//\r\n// When a navigate tool causes a full-page reload, the agent WS is lost.\r\n// This function opens a new WS with {type: \"resume\"}, sends the\r\n// completed tool results (including the navigate result with the new\r\n// page context), and continues the agent loop from where it left off.\r\n\r\nexport const agentResumeStream = (\r\n baseUrl: string,\r\n resumeState: PendingAgentResume,\r\n pageContext: string,\r\n events: AgentVoiceChatEvents,\r\n executeTool: (call: AgentToolCallInfo) => Promise<{ call_id: string; result: string }>,\r\n): StreamController => {\r\n let isStopped = false;\r\n let activeSocket: WebSocket | null = null;\r\n let activeReader: ReadableStreamDefaultReader<Uint8Array> | undefined;\r\n let errorEmitted = false;\r\n\r\n // Build tool results for the calls that were pending when the page reloaded.\r\n // Navigate results include the new page context; other tools that couldn't\r\n // execute get a descriptive skip message.\r\n const allResults = [...resumeState.completedResults];\r\n for (const tc of resumeState.pendingToolCalls) {\r\n if (allResults.some((r) => r.call_id === tc.call_id)) continue;\r\n if (tc.tool === \"navigate\") {\r\n allResults.push({\r\n call_id: tc.call_id,\r\n result: `Navigasyon tamamlandı. Şu anki sayfa: ${typeof window !== \"undefined\" ? window.location.href : \"\"}\\nSayfa bağlamı: ${pageContext}`,\r\n });\r\n } else {\r\n allResults.push({\r\n call_id: tc.call_id,\r\n result: \"Sayfa yeniden yüklendi, bu araç çalıştırılamadı.\",\r\n });\r\n }\r\n }\r\n\r\n const donePromise = new Promise<void>(async (resolve, reject) => {\r\n try {\r\n if (isStopped) return resolve();\r\n\r\n let effectiveSessionId = resumeState.sessionId;\r\n\r\n const assistantText = await new Promise<string>((agentResolve, agentReject) => {\r\n if (isStopped) { agentResolve(\"\"); return; }\r\n\r\n const wsUrl = toWebSocketUrl(baseUrl, \"/chat/agent/ws\");\r\n const socket = new WebSocket(wsUrl);\r\n activeSocket = socket;\r\n\r\n let finalReply = \"\";\r\n let resolved = false;\r\n let accumulatedDelta = \"\";\r\n\r\n const finish = (reply: string) => {\r\n if (resolved) return;\r\n resolved = true;\r\n agentResolve(reply);\r\n };\r\n\r\n const fail = (error: Error) => {\r\n if (resolved) return;\r\n resolved = true;\r\n agentReject(error);\r\n };\r\n\r\n socket.onopen = () => {\r\n console.info(\"[Bulut] Agent WS resume connected\");\r\n socket.send(JSON.stringify({\r\n type: \"resume\",\r\n project_id: resumeState.projectId,\r\n session_id: resumeState.sessionId,\r\n model: resumeState.model,\r\n page_context: pageContext,\r\n accessibility_mode: resumeState.accessibilityMode,\r\n pending_tool_calls: resumeState.pendingToolCalls,\r\n tool_results: allResults,\r\n }));\r\n };\r\n\r\n socket.onmessage = async (event) => {\r\n let data: Record<string, unknown>;\r\n try {\r\n data = JSON.parse(String(event.data));\r\n } catch { return; }\r\n\r\n const msgType = data.type as string;\r\n\r\n if (msgType === \"session\" && typeof data.session_id === \"string\") {\r\n effectiveSessionId = data.session_id as string;\r\n events.onSessionId?.(effectiveSessionId);\r\n return;\r\n }\r\n\r\n if (msgType === \"iteration\") {\r\n events.onIteration?.(\r\n data.iteration as number,\r\n data.max_iterations as number,\r\n );\r\n return;\r\n }\r\n\r\n if (msgType === \"reply_delta\" && typeof data.delta === \"string\") {\r\n accumulatedDelta += data.delta;\r\n events.onAssistantDelta?.(data.delta);\r\n return;\r\n }\r\n\r\n if (msgType === \"tool_calls\" && Array.isArray(data.calls)) {\r\n const calls = data.calls as AgentToolCallInfo[];\r\n\r\n // Speak accumulated text before running tools\r\n if (accumulatedDelta.trim()) {\r\n events.onIntermediateReply?.(accumulatedDelta.trim());\r\n }\r\n accumulatedDelta = \"\";\r\n\r\n events.onToolCalls?.(calls);\r\n\r\n const results: { call_id: string; result: string }[] = [];\r\n for (const call of calls) {\r\n const isNavigate = call.tool === \"navigate\";\r\n if (isNavigate) {\r\n savePendingAgentResume({\r\n sessionId: effectiveSessionId,\r\n projectId: resumeState.projectId,\r\n model: resumeState.model,\r\n voice: resumeState.voice,\r\n accessibilityMode: resumeState.accessibilityMode,\r\n pendingToolCalls: calls.map((c) => ({\r\n call_id: c.call_id,\r\n tool: c.tool,\r\n args: c.args,\r\n })),\r\n completedResults: [...results],\r\n });\r\n }\r\n\r\n const result = await executeTool(call);\r\n\r\n if (isNavigate) {\r\n clearPendingAgentResume();\r\n }\r\n\r\n events.onToolResult?.(call.call_id, call.tool, result.result);\r\n results.push(result);\r\n }\r\n\r\n if (socket.readyState === WebSocket.OPEN) {\r\n socket.send(JSON.stringify({ type: \"tool_results\", results }));\r\n }\r\n return;\r\n }\r\n\r\n if (msgType === \"agent_done\") {\r\n finalReply = (data.final_reply as string) || \"\";\r\n events.onAssistantDone?.(finalReply);\r\n if (typeof data.session_id === \"string\") {\r\n events.onSessionId?.(data.session_id as string);\r\n }\r\n finish(finalReply);\r\n return;\r\n }\r\n\r\n if (msgType === \"error\") {\r\n const errMsg = (data.error as string) || \"Agent error\";\r\n errorEmitted = true;\r\n events.onError?.(errMsg);\r\n fail(new Error(errMsg));\r\n return;\r\n }\r\n };\r\n\r\n socket.onerror = () => {\r\n errorEmitted = true;\r\n events.onError?.(\"Agent WebSocket error\");\r\n fail(new Error(\"Agent WebSocket error\"));\r\n };\r\n\r\n socket.onclose = () => finish(finalReply);\r\n });\r\n\r\n activeSocket = null;\r\n\r\n // ── TTS ────────────────────────────────────────────────\r\n if (isStopped || !assistantText) return resolve();\r\n\r\n console.info(`[Bulut] TTS start mode=resume voice=${resumeState.voice}`);\r\n events.onAudioStateChange?.(\"rendering\");\r\n let ttsResult: TtsCollectResult;\r\n\r\n try {\r\n ttsResult = await collectTtsViaWebSocket(\r\n baseUrl, assistantText, resumeState.voice, Boolean(resumeState.accessibilityMode),\r\n () => isStopped,\r\n (socket) => { activeSocket = socket; },\r\n );\r\n } catch (wsError) {\r\n if (isStopped) return resolve();\r\n console.warn(\r\n `[Bulut] TTS WS failed, falling back to SSE: ${wsError instanceof Error ? wsError.message : String(wsError)}`,\r\n );\r\n ttsResult = await collectTtsViaSse(\r\n baseUrl, assistantText, resumeState.voice, Boolean(resumeState.accessibilityMode),\r\n () => isStopped,\r\n (reader) => { activeReader = reader; },\r\n );\r\n }\r\n\r\n if (!isStopped && ttsResult.chunks.length > 0) {\r\n await playBufferedAudio(\r\n ttsResult.chunks, ttsResult.mimeType, ttsResult.sampleRate,\r\n events.onAudioStateChange,\r\n );\r\n } else {\r\n events.onAudioStateChange?.(\"done\");\r\n }\r\n\r\n resolve();\r\n } catch (err) {\r\n if (!errorEmitted) {\r\n const msg = err instanceof Error ? err.message : String(err);\r\n events.onError?.(msg);\r\n }\r\n reject(err);\r\n } finally {\r\n activeReader?.cancel().catch(() => { });\r\n if (activeSocket && activeSocket.readyState <= WebSocket.OPEN) {\r\n activeSocket.close();\r\n }\r\n activeSocket = null;\r\n }\r\n });\r\n\r\n return {\r\n stop: () => {\r\n isStopped = true;\r\n if (activeReader) activeReader.cancel().catch(() => { });\r\n if (activeSocket && activeSocket.readyState <= WebSocket.OPEN) {\r\n activeSocket.close();\r\n }\r\n },\r\n done: donePromise,\r\n };\r\n};\r\n","import {\r\n completedSfxUrl,\r\n sentSfxUrl,\r\n thinkingSfxUrl,\r\n toolCallSfxUrl,\r\n} from \"../assets\";\r\n\r\nexport type SfxName = \"sent\" | \"thinking\" | \"toolCall\" | \"completed\";\r\n\r\nconst SFX_SOURCES: Record<SfxName, string> = {\r\n sent: sentSfxUrl,\r\n thinking: thinkingSfxUrl,\r\n toolCall: toolCallSfxUrl,\r\n completed: completedSfxUrl,\r\n};\r\n\r\nclass SfxManager {\r\n private queue: SfxName[] = [];\r\n private active = false;\r\n\r\n private playNow(name: SfxName): Promise<void> {\r\n return new Promise((resolve) => {\r\n if (typeof window === \"undefined\") {\r\n resolve();\r\n return;\r\n }\r\n\r\n const audio = new Audio(SFX_SOURCES[name]);\r\n audio.preload = \"auto\";\r\n\r\n let settled = false;\r\n const finalize = () => {\r\n if (settled) return;\r\n settled = true;\r\n audio.onended = null;\r\n audio.onerror = null;\r\n resolve();\r\n };\r\n\r\n audio.onended = finalize;\r\n audio.onerror = finalize;\r\n void audio.play().catch(() => finalize());\r\n });\r\n }\r\n\r\n private async drain(): Promise<void> {\r\n if (this.active) return;\r\n this.active = true;\r\n try {\r\n while (this.queue.length > 0) {\r\n const next = this.queue.shift();\r\n if (!next) continue;\r\n await this.playNow(next);\r\n }\r\n } finally {\r\n this.active = false;\r\n }\r\n }\r\n\r\n playCue(name: SfxName): void {\r\n if (typeof window === \"undefined\") return;\r\n this.queue.push(name);\r\n if (!this.active) {\r\n void this.drain();\r\n }\r\n }\r\n}\r\n\r\nconst sfxManager = new SfxManager();\r\n\r\nexport const playCue = (name: SfxName): void => {\r\n sfxManager.playCue(name);\r\n};\r\n\r\n","export default \"data:audio/mpeg;base64,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ciUlhGEjSloik0pFDiOCQk7CwkpfJTEhxVU13/NeLKirBnlTQsVMNkxBTUUzLjk5LjWqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqgABlZauxJiAl8OtGJtCUOXLbCYWJSp4mI7hkhQQtAm46D7OEuRPTCPY90Qp2BvbF9eSSLUC24sytUy5EiD4uHKLLq6isqsdOqI2D5KKhCNDRcouomkdOB4ugPmURCIhkZKLoG4Tq7rf/dXdbmxRFTiSaiaSaSZw4XQHzJMKREDoyMEaBticLutzYyuquv7q0qurq6ukl2HsoiERDIyUXQThOF3/+rJsNHxRj/XTZKlJ5k4ANeHGTRgGMwAAAaQAAAAgAAA0gAAABMNjKKxUsWXUBw0LCv0AyFRYW1pMgsJDMcYEltcEbDEBSri82XaTiygI8gmpKTiyxUVWKiweNCrP6xRsCios3F2VCwr//9uKijf//8WFakxBTUUzLjk5LjWqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqo=\"","export default \"data:audio/mpeg;base64,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qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqr/+rJsOxMAD/AAAGkAAAAIAAANIAAAAQAAAaQAAAAgAAA0gAAABExBTUUzLjk5LjWqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqkxBTUUzLjk5LjWqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqo=\"","export default \"data:audio/mpeg;base64,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qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqo=\"","export default \"data:audio/mpeg;base64,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\"","import { useEffect, useLayoutEffect, useRef, useState } from \"preact/hooks\";\r\nimport type { JSX } from \"preact\";\r\nimport type { BulutRuntimeConfig } from \"../index\";\r\nimport {\r\n agentTextChatStream,\r\n agentVoiceChatStream,\r\n agentResumeStream,\r\n startSttWebSocketStream,\r\n speakText,\r\n type AudioStreamState,\r\n type StreamController,\r\n type AgentToolCallInfo,\r\n type SttWsController,\r\n} from \"../api/client\";\r\nimport {\r\n executeSingleToolCall,\r\n parseAgentResponse,\r\n getPendingAgentResume,\r\n clearPendingAgentResume,\r\n type ToolCallWithId,\r\n} from \"../agent/tools\";\r\nimport { getPageContext } from \"../agent/context\";\r\nimport {\r\n WINDOW_WIDTH,\r\n WINDOW_HEIGHT,\r\n POSITION_BOTTOM,\r\n POSITION_RIGHT,\r\n COLORS,\r\n TRANSITIONS,\r\n BORDER_RADIUS,\r\n SHADOW,\r\n} from \"../styles/constants\";\r\nimport {\r\n closeIconContent,\r\n microphoneIconContent,\r\n stopIconContent,\r\n restartIconContent,\r\n logoContent,\r\n} from \"../assets\";\r\nimport { StreamingJsonParser } from \"../utils/streamingJson\";\r\nimport { playCue, type SfxName } from \"../audio/sfxManager\";\r\n\r\nimport { SvgIcon } from \"./SvgIcon\";\r\n\r\nexport interface ChatWindowHandle {\r\n startRecording: () => void;\r\n cancelRecording: () => void;\r\n stopTask: () => void;\r\n}\r\n\r\ninterface ChatWindowProps {\r\n onClose: () => void;\r\n config: BulutRuntimeConfig;\r\n accessibilityMode?: boolean;\r\n onAccessibilityToggle?: () => void;\r\n hidden?: boolean;\r\n actionsRef?: { current: ChatWindowHandle | null };\r\n onRecordingChange?: (recording: boolean) => void;\r\n onBusyChange?: (busy: boolean) => void;\r\n onPreviewChange?: (text: string | null) => void;\r\n}\r\n\r\ninterface Message {\r\n id: number;\r\n text: string;\r\n isUser: boolean;\r\n /** \"message\" (default) | \"tool\" for tool call indicators */\r\n type?: \"message\" | \"tool\";\r\n}\r\n\r\ntype RecordingMode = \"vad\" | \"press\";\r\n\r\ntype StorageLike = {\r\n removeItem: (key: string) => void;\r\n};\r\n\r\nconst STORAGE_KEY = \"bulut_chat_history\";\r\nconst TIMESTAMP_KEY = \"bulut_chat_timestamp\";\r\nconst SESSION_ID_KEY = \"bulut_session_id\";\r\nconst TTL_MS = 5 * 60 * 1000;\r\nconst VAD_THRESHOLD = 0.06;\r\nconst SILENCE_DURATION_MS = 500;\r\nexport const HOLD_THRESHOLD_MS = 250;\r\n\r\nconst STATUS_LABELS = {\r\n ready: \"Hazır\",\r\n loading: \"Yükleniyor\",\r\n listening: \"Dinliyor\",\r\n transcribing: \"Metne dönüştürülüyor\",\r\n thinking: \"Düşünüyor\",\r\n playingAudio: \"Ses oynatılıyor\",\r\n runningTools: \"Araç çalıştırılıyor\",\r\n} as const;\r\n\r\nexport const getGreetingText = (agentName: string): string =>\r\n `Merhaba, ben ${agentName}. Bu web sayfasında neler yapalım?`;\r\n\r\nexport interface StatusFlags {\r\n isBusy: boolean;\r\n isRecording: boolean;\r\n isTranscribing: boolean;\r\n isThinking: boolean;\r\n isRenderingAudio: boolean;\r\n isPlayingAudio: boolean;\r\n isRunningTools: boolean;\r\n}\r\n\r\nexport const resolveStatusText = (flags: StatusFlags): string => {\r\n if (flags.isRecording) return STATUS_LABELS.listening;\r\n if (flags.isRunningTools) return STATUS_LABELS.runningTools;\r\n if (flags.isPlayingAudio) return STATUS_LABELS.playingAudio;\r\n if (flags.isThinking) return STATUS_LABELS.thinking;\r\n if (flags.isTranscribing) return STATUS_LABELS.transcribing;\r\n if (flags.isBusy) return STATUS_LABELS.loading;\r\n return STATUS_LABELS.ready;\r\n};\r\n\r\nexport const formatDurationMs = (durationMs: number): string => {\r\n const totalSeconds = Math.max(0, Math.floor(durationMs / 1000));\r\n const minutes = Math.floor(totalSeconds / 60)\r\n .toString()\r\n .padStart(2, \"0\");\r\n const seconds = (totalSeconds % 60).toString().padStart(2, \"0\");\r\n return `${minutes}:${seconds}`;\r\n};\r\n\r\nexport const classifyMicGesture = (\r\n durationMs: number,\r\n thresholdMs: number = HOLD_THRESHOLD_MS,\r\n): \"tap\" | \"hold\" => (durationMs >= thresholdMs ? \"hold\" : \"tap\");\r\n\r\nexport const createInitialMessages = (agentName: string): Message[] => [\r\n {\r\n id: 1,\r\n text: getGreetingText(agentName),\r\n isUser: false,\r\n },\r\n];\r\n\r\nexport const clearPersistedChatState = (storage: StorageLike | null): void => {\r\n if (!storage) {\r\n return;\r\n }\r\n\r\n storage.removeItem(STORAGE_KEY);\r\n storage.removeItem(TIMESTAMP_KEY);\r\n storage.removeItem(SESSION_ID_KEY);\r\n};\r\n\r\nexport const scrollElementToBottom = (\r\n element: { scrollTop: number; scrollHeight: number } | null,\r\n): void => {\r\n if (!element) {\r\n return;\r\n }\r\n\r\n element.scrollTop = element.scrollHeight;\r\n};\r\n\r\nconst normalizeError = (error: unknown) => {\r\n if (error instanceof Error) {\r\n return error.message;\r\n }\r\n return \"Bilinmeyen hata\";\r\n};\r\n\r\nconst getNextMessageId = (messages: Message[]): number => {\r\n const maxId = messages.reduce((acc, message) => Math.max(acc, message.id), 0);\r\n return maxId + 1;\r\n};\r\n\r\nexport interface AssistantPayloadResolution {\r\n displayText: string;\r\n toolCalls: ReturnType<typeof parseAgentResponse>[\"toolCalls\"];\r\n}\r\n\r\nexport const resolveAssistantPayload = (\r\n assistantText: string,\r\n): AssistantPayloadResolution => {\r\n const parsed = parseAgentResponse(assistantText);\r\n return {\r\n displayText: parsed.reply || assistantText,\r\n toolCalls: parsed.toolCalls,\r\n };\r\n};\r\n\r\nexport const shouldAutoListenAfterAudio = (\r\n accessibilityMode: boolean,\r\n isRecording: boolean,\r\n isBusy: boolean,\r\n): boolean => accessibilityMode && !isRecording && !isBusy;\r\n\r\nexport const ChatWindow = ({\r\n onClose,\r\n config,\r\n accessibilityMode = false,\r\n onAccessibilityToggle,\r\n hidden = false,\r\n actionsRef,\r\n onRecordingChange,\r\n onBusyChange,\r\n onPreviewChange,\r\n}: ChatWindowProps) => {\r\n const [messages, setMessages] = useState<Message[]>(() => {\r\n if (typeof localStorage !== \"undefined\") {\r\n const saved = localStorage.getItem(STORAGE_KEY);\r\n const timestamp = localStorage.getItem(TIMESTAMP_KEY);\r\n\r\n if (saved && timestamp) {\r\n const timePassed = Date.now() - parseInt(timestamp, 10);\r\n if (timePassed < TTL_MS) {\r\n try {\r\n return JSON.parse(saved) as Message[];\r\n } catch {\r\n // Ignore parse error and continue with default.\r\n }\r\n } else {\r\n clearPersistedChatState(localStorage);\r\n }\r\n }\r\n }\r\n\r\n return createInitialMessages(config.agentName);\r\n });\r\n\r\n const [isBusy, setIsBusy] = useState(false);\r\n const [isRecording, setIsRecording] = useState(false);\r\n const [isTranscribing, setIsTranscribing] = useState(false);\r\n const [isThinking, setIsThinking] = useState(false);\r\n const [isRenderingAudio, setIsRenderingAudio] = useState(false);\r\n const [isPlayingAudio, setIsPlayingAudio] = useState(false);\r\n const [isRunningTools, setIsRunningTools] = useState(false);\r\n const [recordingDurationMs, setRecordingDurationMs] = useState(0);\r\n const [statusOverride, setStatusOverride] = useState<string | null>(null);\r\n\r\n const resolvedStatusText = resolveStatusText({\r\n isBusy,\r\n isRecording,\r\n isTranscribing,\r\n isThinking,\r\n isRenderingAudio,\r\n isPlayingAudio,\r\n isRunningTools,\r\n });\r\n const statusText = statusOverride ?? resolvedStatusText;\r\n\r\n const isBusyRef = useRef(isBusy);\r\n const isRecordingRef = useRef(isRecording);\r\n\r\n const nextMessageIdRef = useRef(getNextMessageId(messages));\r\n const recorderRef = useRef<MediaRecorder | null>(null);\r\n const streamRef = useRef<MediaStream | null>(null);\r\n const audioChunksRef = useRef<BlobPart[]>([]);\r\n const activeStreamControllerRef = useRef<StreamController | null>(null);\r\n const sessionIdRef = useRef<string | null>(\r\n typeof localStorage !== \"undefined\"\r\n ? (() => {\r\n const ts = localStorage.getItem(TIMESTAMP_KEY);\r\n if (ts && Date.now() - parseInt(ts, 10) < TTL_MS) {\r\n return localStorage.getItem(SESSION_ID_KEY);\r\n }\r\n return null;\r\n })()\r\n : null,\r\n );\r\n\r\n const silenceStartRef = useRef<number | null>(null);\r\n const vadIntervalRef = useRef<number | null>(null);\r\n const audioContextRef = useRef<AudioContext | null>(null);\r\n const sourceRef = useRef<MediaStreamAudioSourceNode | null>(null);\r\n\r\n const discardNextRecordingRef = useRef(false);\r\n\r\n const micPressStartRef = useRef<number | null>(null);\r\n const micHoldTimeoutRef = useRef<number | null>(null);\r\n const micHoldTriggeredRef = useRef(false);\r\n const recordingModeRef = useRef<RecordingMode | null>(null);\r\n const pendingStopAfterStartRef = useRef(false);\r\n const startRecordingPendingRef = useRef(false);\r\n\r\n const assistantMessageIdRef = useRef<number | null>(null);\r\n const assistantTextBufferRef = useRef(\"\");\r\n const transcriptionReceivedRef = useRef(false);\r\n const assistantDoneReceivedRef = useRef(false);\r\n\r\n const recordingStartedAtRef = useRef<number | null>(null);\r\n const recordingTimerIntervalRef = useRef<number | null>(null);\r\n\r\n const messagesContainerRef = useRef<HTMLDivElement | null>(null);\r\n const messagesContentRef = useRef<HTMLDivElement | null>(null);\r\n\r\n const pendingUserTextRef = useRef<string | null>(null);\r\n const pendingAssistantTextRef = useRef<string>(\"\");\r\n const streamingJsonParserRef = useRef<StreamingJsonParser | null>(null);\r\n const awaitingAssistantResponseRef = useRef(false);\r\n const activeSttWsRef = useRef<SttWsController | null>(null);\r\n const liveTranscriptionMessageIdRef = useRef<number | null>(null);\r\n const liveTranscriptionTextRef = useRef(\"\");\r\n const autoListenSuppressedRef = useRef(false);\r\n\r\n useEffect(() => {\r\n isBusyRef.current = isBusy;\r\n }, [isBusy]);\r\n\r\n useEffect(() => {\r\n isRecordingRef.current = isRecording;\r\n }, [isRecording]);\r\n\r\n // Report state changes to parent\r\n useEffect(() => { onRecordingChange?.(isRecording); }, [isRecording]);\r\n useEffect(() => { onBusyChange?.(isBusy); }, [isBusy]);\r\n\r\n // Derive and report preview text to parent\r\n useEffect(() => {\r\n if (!onPreviewChange) return;\r\n if (isRecording) {\r\n onPreviewChange(STATUS_LABELS.listening);\r\n return;\r\n }\r\n // When audio is rendering/playing, show the actual message text\r\n if (isRenderingAudio || isPlayingAudio) {\r\n const lastAssistant = [...messages].reverse().find(m => !m.isUser && m.type !== \"tool\");\r\n onPreviewChange(lastAssistant?.text ?? getGreetingText(config.agentName));\r\n return;\r\n }\r\n if (isBusy || isTranscribing || isThinking || isRunningTools) {\r\n const st = statusOverride ?? resolveStatusText({\r\n isBusy, isRecording, isTranscribing, isThinking,\r\n isRenderingAudio, isPlayingAudio, isRunningTools,\r\n });\r\n onPreviewChange(st);\r\n return;\r\n }\r\n // Show last assistant message (or greeting)\r\n const lastAssistant = [...messages].reverse().find(m => !m.isUser && m.type !== \"tool\");\r\n onPreviewChange(lastAssistant?.text ?? getGreetingText(config.agentName));\r\n }, [isRecording, isBusy, isTranscribing, isThinking, isRunningTools,\r\n isPlayingAudio, isRenderingAudio, statusOverride, messages]);\r\n\r\n const playSfx = (name: SfxName) => {\r\n playCue(name);\r\n };\r\n\r\n useEffect(() => {\r\n if (typeof localStorage !== \"undefined\") {\r\n localStorage.setItem(STORAGE_KEY, JSON.stringify(messages));\r\n localStorage.setItem(TIMESTAMP_KEY, Date.now().toString());\r\n }\r\n }, [messages]);\r\n\r\n const scrollMessagesToBottom = () => {\r\n scrollElementToBottom(messagesContainerRef.current);\r\n };\r\n\r\n useLayoutEffect(() => {\r\n scrollMessagesToBottom();\r\n }, [messages, statusText, isBusy, isRecording]);\r\n\r\n useEffect(() => {\r\n const content = messagesContentRef.current;\r\n if (!content || typeof ResizeObserver === \"undefined\") {\r\n return;\r\n }\r\n\r\n const observer = new ResizeObserver(() => {\r\n scrollMessagesToBottom();\r\n });\r\n\r\n observer.observe(content);\r\n return () => observer.disconnect();\r\n }, []);\r\n\r\n const stopRecordingTimer = () => {\r\n if (recordingTimerIntervalRef.current !== null) {\r\n window.clearInterval(recordingTimerIntervalRef.current);\r\n recordingTimerIntervalRef.current = null;\r\n }\r\n recordingStartedAtRef.current = null;\r\n };\r\n\r\n const startRecordingTimer = () => {\r\n stopRecordingTimer();\r\n recordingStartedAtRef.current = Date.now();\r\n setRecordingDurationMs(0);\r\n\r\n recordingTimerIntervalRef.current = window.setInterval(() => {\r\n const startedAt = recordingStartedAtRef.current;\r\n if (startedAt === null) {\r\n setRecordingDurationMs(0);\r\n return;\r\n }\r\n setRecordingDurationMs(Date.now() - startedAt);\r\n }, 200);\r\n };\r\n\r\n const resetProcessingFlags = () => {\r\n setIsTranscribing(false);\r\n setIsThinking(false);\r\n setIsRenderingAudio(false);\r\n setIsPlayingAudio(false);\r\n setIsRunningTools(false);\r\n setStatusOverride(null);\r\n assistantMessageIdRef.current = null;\r\n assistantTextBufferRef.current = \"\";\r\n transcriptionReceivedRef.current = false;\r\n assistantDoneReceivedRef.current = false;\r\n awaitingAssistantResponseRef.current = false;\r\n pendingUserTextRef.current = null;\r\n pendingAssistantTextRef.current = \"\";\r\n };\r\n\r\n const clearMicHoldTimeout = () => {\r\n if (micHoldTimeoutRef.current !== null) {\r\n window.clearTimeout(micHoldTimeoutRef.current);\r\n micHoldTimeoutRef.current = null;\r\n }\r\n };\r\n\r\n const cleanupVAD = () => {\r\n if (vadIntervalRef.current !== null) {\r\n clearInterval(vadIntervalRef.current);\r\n vadIntervalRef.current = null;\r\n }\r\n\r\n if (sourceRef.current) {\r\n sourceRef.current.disconnect();\r\n sourceRef.current = null;\r\n }\r\n\r\n if (audioContextRef.current) {\r\n audioContextRef.current.close().catch(() => {});\r\n audioContextRef.current = null;\r\n }\r\n\r\n silenceStartRef.current = null;\r\n };\r\n\r\n const stopStreamTracks = () => {\r\n if (!streamRef.current) {\r\n return;\r\n }\r\n\r\n streamRef.current.getTracks().forEach((track) => track.stop());\r\n streamRef.current = null;\r\n };\r\n\r\n const stopActiveStream = () => {\r\n if (!activeStreamControllerRef.current) {\r\n return;\r\n }\r\n\r\n activeStreamControllerRef.current.stop();\r\n activeStreamControllerRef.current = null;\r\n };\r\n\r\n const cancelActiveSttWs = () => {\r\n const activeSttWs = activeSttWsRef.current;\r\n activeSttWsRef.current = null;\r\n activeSttWs?.cancel();\r\n liveTranscriptionMessageIdRef.current = null;\r\n liveTranscriptionTextRef.current = \"\";\r\n };\r\n\r\n useEffect(\r\n () => () => {\r\n clearMicHoldTimeout();\r\n pendingStopAfterStartRef.current = false;\r\n\r\n stopActiveStream();\r\n cancelActiveSttWs();\r\n cleanupVAD();\r\n stopStreamTracks();\r\n stopRecordingTimer();\r\n\r\n const recorder = recorderRef.current;\r\n if (recorder) {\r\n recorder.ondataavailable = null;\r\n recorder.onstop = null;\r\n recorder.onerror = null;\r\n if (recorder.state !== \"inactive\") {\r\n recorder.stop();\r\n }\r\n recorderRef.current = null;\r\n }\r\n\r\n cancelActiveSttWs();\r\n },\r\n [],\r\n );\r\n\r\n // ── Resume agent loop after full-page navigation ────────────────\r\n useEffect(() => {\r\n const resumeState = getPendingAgentResume();\r\n if (!resumeState) return;\r\n\r\n clearPendingAgentResume();\r\n console.info(\"[Bulut] Resuming agent after navigation\");\r\n\r\n // Restore session ID from resume state\r\n if (resumeState.sessionId) {\r\n sessionIdRef.current = resumeState.sessionId;\r\n if (typeof localStorage !== \"undefined\") {\r\n localStorage.setItem(SESSION_ID_KEY, resumeState.sessionId);\r\n }\r\n }\r\n\r\n setIsBusy(true);\r\n setIsRunningTools(true);\r\n setStatusOverride(STATUS_LABELS.thinking);\r\n\r\n const freshPageContext = getPageContext().summary;\r\n\r\n const resumeToolExec = async (\r\n call: AgentToolCallInfo,\r\n ): Promise<{ call_id: string; result: string }> => {\r\n const toolCall: ToolCallWithId = {\r\n tool: call.tool as \"navigate\" | \"getPageContext\" | \"interact\" | \"scroll\",\r\n call_id: call.call_id,\r\n ...call.args,\r\n } as ToolCallWithId;\r\n return executeSingleToolCall(toolCall);\r\n };\r\n\r\n const controller = agentResumeStream(\r\n config.backendBaseUrl,\r\n resumeState,\r\n freshPageContext,\r\n {\r\n onSessionId: (sid) => {\r\n if (sid && sid !== sessionIdRef.current) {\r\n sessionIdRef.current = sid;\r\n if (typeof localStorage !== \"undefined\") {\r\n localStorage.setItem(SESSION_ID_KEY, sid);\r\n }\r\n }\r\n },\r\n onAssistantDelta: (delta) => {\r\n setIsRunningTools(false);\r\n setIsThinking(true);\r\n setStatusOverride(null);\r\n\r\n pendingAssistantTextRef.current += delta;\r\n\r\n if (assistantMessageIdRef.current === null) {\r\n assistantMessageIdRef.current = appendMessage(\r\n pendingAssistantTextRef.current,\r\n false,\r\n );\r\n } else {\r\n updateMessageText(\r\n assistantMessageIdRef.current,\r\n pendingAssistantTextRef.current,\r\n );\r\n }\r\n },\r\n onAssistantDone: (assistantText) => {\r\n playSfx(\"completed\");\r\n setStatusOverride(null);\r\n setIsThinking(false);\r\n setIsRenderingAudio(true);\r\n\r\n const finalDisplayText =\r\n assistantText || pendingAssistantTextRef.current;\r\n pendingAssistantTextRef.current = finalDisplayText;\r\n\r\n if (assistantMessageIdRef.current !== null) {\r\n updateMessageText(\r\n assistantMessageIdRef.current,\r\n finalDisplayText,\r\n );\r\n } else {\r\n assistantMessageIdRef.current = appendMessage(\r\n finalDisplayText,\r\n false,\r\n );\r\n }\r\n },\r\n onIntermediateReply: (text) => {\r\n void speakText(\r\n config.backendBaseUrl, text, config.voice,\r\n accessibilityMode, handleAudioStateChange,\r\n ).catch((err) => console.warn(\"[Bulut] intermediate TTS failed\", err));\r\n },\r\n onToolCalls: (calls) => {\r\n if (calls.length > 0) {\r\n playSfx(\"toolCall\");\r\n }\r\n setIsRunningTools(true);\r\n setStatusOverride(STATUS_LABELS.runningTools);\r\n\r\n for (const call of calls) {\r\n const toolLabel =\r\n call.tool === \"navigate\"\r\n ? `Sayfaya gidiliyor: ${call.args.url ?? \"\"}`\r\n : call.tool === \"getPageContext\"\r\n ? \"Sayfa bağlamı alınıyor…\"\r\n : call.tool === \"interact\"\r\n ? `Etkileşim: ${call.args.action ?? \"\"}`\r\n : call.tool === \"scroll\"\r\n ? \"Kaydırılıyor…\"\r\n : call.tool;\r\n\r\n appendMessage(`${toolLabel}`, false);\r\n setMessages((prev) => {\r\n const last = prev[prev.length - 1];\r\n if (last && !last.isUser) {\r\n return [\r\n ...prev.slice(0, -1),\r\n { ...last, type: \"tool\" as const },\r\n ];\r\n }\r\n return prev;\r\n });\r\n }\r\n\r\n assistantMessageIdRef.current = null;\r\n pendingAssistantTextRef.current = \"\";\r\n },\r\n onToolResult: () => {},\r\n onIteration: () => {\r\n playSfx(\"thinking\");\r\n setIsThinking(true);\r\n setStatusOverride(STATUS_LABELS.thinking);\r\n },\r\n onAudioStateChange: handleAudioStateChange,\r\n onError: (err) => {\r\n setStatusOverride(null);\r\n appendMessage(`Hata: ${err}`, false);\r\n },\r\n },\r\n resumeToolExec,\r\n );\r\n\r\n activeStreamControllerRef.current = controller;\r\n\r\n controller.done\r\n .catch(() => {})\r\n .finally(() => {\r\n setIsBusy(false);\r\n setIsRunningTools(false);\r\n setIsThinking(false);\r\n setIsRenderingAudio(false);\r\n setIsPlayingAudio(false);\r\n setStatusOverride(null);\r\n pendingAssistantTextRef.current = \"\";\r\n assistantMessageIdRef.current = null;\r\n activeStreamControllerRef.current = null;\r\n\r\n if (\r\n !autoListenSuppressedRef.current &&\r\n shouldAutoListenAfterAudio(\r\n accessibilityMode,\r\n isRecordingRef.current,\r\n isBusyRef.current,\r\n )\r\n ) {\r\n void startRecording(\"vad\");\r\n }\r\n });\r\n }, []); // eslint-disable-line react-hooks/exhaustive-deps\r\n\r\n const appendMessage = (text: string, isUser: boolean): number => {\r\n const id = nextMessageIdRef.current++;\r\n setMessages((previous) => [\r\n ...previous,\r\n {\r\n id,\r\n text,\r\n isUser,\r\n },\r\n ]);\r\n return id;\r\n };\r\n\r\n const updateMessageText = (id: number, text: string) => {\r\n setMessages((previous) =>\r\n previous.map((message) =>\r\n message.id === id ? { ...message, text } : message,\r\n ),\r\n );\r\n };\r\n\r\n const upsertLiveUserTranscription = (text: string) => {\r\n const normalized = text.trim();\r\n if (!normalized) {\r\n return;\r\n }\r\n liveTranscriptionTextRef.current = normalized;\r\n if (liveTranscriptionMessageIdRef.current === null) {\r\n liveTranscriptionMessageIdRef.current = appendMessage(normalized, true);\r\n return;\r\n }\r\n updateMessageText(liveTranscriptionMessageIdRef.current, normalized);\r\n };\r\n\r\n const clearLiveUserTranscriptionState = () => {\r\n liveTranscriptionMessageIdRef.current = null;\r\n liveTranscriptionTextRef.current = \"\";\r\n };\r\n\r\n const handleAudioStateChange = (state: AudioStreamState) => {\r\n if (state === \"rendering\") {\r\n setIsRenderingAudio(true);\r\n setIsPlayingAudio(false);\r\n return;\r\n }\r\n\r\n if (state === \"playing\") {\r\n setIsRenderingAudio(false);\r\n setIsPlayingAudio(true);\r\n return;\r\n }\r\n\r\n if (state === \"fallback\") {\r\n setIsRenderingAudio(true);\r\n setIsPlayingAudio(false);\r\n return;\r\n }\r\n\r\n if (state === \"done\") {\r\n setIsRenderingAudio(false);\r\n setIsPlayingAudio(false);\r\n return;\r\n }\r\n\r\n setIsRenderingAudio(false);\r\n setIsPlayingAudio(false);\r\n };\r\n\r\n const finalizeStreamCycle = () => {\r\n awaitingAssistantResponseRef.current = false;\r\n setStatusOverride(null);\r\n setIsBusy(false);\r\n setIsTranscribing(false);\r\n setIsThinking(false);\r\n setIsRenderingAudio(false);\r\n setIsPlayingAudio(false);\r\n setIsRunningTools(false);\r\n pendingUserTextRef.current = null;\r\n pendingAssistantTextRef.current = \"\";\r\n assistantMessageIdRef.current = null;\r\n if (activeStreamControllerRef.current) {\r\n activeStreamControllerRef.current = null;\r\n }\r\n if (\r\n !autoListenSuppressedRef.current &&\r\n shouldAutoListenAfterAudio(\r\n accessibilityMode,\r\n isRecordingRef.current,\r\n isBusyRef.current,\r\n )\r\n ) {\r\n console.info(\"[Bulut] chat-window auto-listen trigger after stream completion\");\r\n void startRecording(\"vad\");\r\n }\r\n };\r\n\r\n const runAgentForUserText = async (userText: string) => {\r\n if (!config.projectId) {\r\n appendMessage(\"Hata: Project ID yapılandırılmamış.\", false);\r\n return;\r\n }\r\n\r\n const normalizedUserText = userText.trim();\r\n if (!normalizedUserText) {\r\n appendMessage(\"Ses kaydı metne dönüştürülemedi. Lütfen tekrar deneyin.\", false);\r\n return;\r\n }\r\n\r\n setIsBusy(true);\r\n setIsTranscribing(false);\r\n setIsThinking(true);\r\n setIsRenderingAudio(false);\r\n setIsPlayingAudio(false);\r\n setIsRunningTools(false);\r\n setStatusOverride(STATUS_LABELS.thinking);\r\n awaitingAssistantResponseRef.current = true;\r\n\r\n try {\r\n pendingUserTextRef.current = normalizedUserText;\r\n upsertLiveUserTranscription(normalizedUserText);\r\n clearLiveUserTranscriptionState();\r\n\r\n stopActiveStream();\r\n const pageContext = getPageContext().summary;\r\n\r\n const handleToolExecution = async (\r\n call: AgentToolCallInfo,\r\n ): Promise<{ call_id: string; result: string }> => {\r\n const toolCall: ToolCallWithId = {\r\n tool: call.tool as\r\n | \"navigate\"\r\n | \"getPageContext\"\r\n | \"interact\"\r\n | \"scroll\",\r\n call_id: call.call_id,\r\n ...call.args,\r\n } as ToolCallWithId;\r\n return executeSingleToolCall(toolCall);\r\n };\r\n\r\n const controller = agentTextChatStream(\r\n config.backendBaseUrl,\r\n normalizedUserText,\r\n config.projectId,\r\n sessionIdRef.current,\r\n {\r\n model: config.model,\r\n voice: config.voice,\r\n pageContext,\r\n accessibilityMode,\r\n },\r\n {\r\n onSessionId: (sid) => {\r\n if (sid && sid !== sessionIdRef.current) {\r\n sessionIdRef.current = sid;\r\n if (typeof localStorage !== \"undefined\") {\r\n localStorage.setItem(SESSION_ID_KEY, sid);\r\n }\r\n }\r\n },\r\n onAssistantDelta: (delta) => {\r\n setIsTranscribing(false);\r\n setIsThinking(true);\r\n setIsRunningTools(false);\r\n if (awaitingAssistantResponseRef.current) {\r\n awaitingAssistantResponseRef.current = false;\r\n setStatusOverride(null);\r\n }\r\n\r\n pendingAssistantTextRef.current += delta;\r\n\r\n if (assistantMessageIdRef.current === null) {\r\n assistantMessageIdRef.current = appendMessage(\r\n pendingAssistantTextRef.current,\r\n false,\r\n );\r\n } else {\r\n updateMessageText(\r\n assistantMessageIdRef.current,\r\n pendingAssistantTextRef.current,\r\n );\r\n }\r\n },\r\n onAssistantDone: (assistantText) => {\r\n playSfx(\"completed\");\r\n awaitingAssistantResponseRef.current = false;\r\n setStatusOverride(null);\r\n setIsThinking(false);\r\n setIsRenderingAudio(true);\r\n\r\n const finalDisplayText = assistantText || pendingAssistantTextRef.current;\r\n pendingAssistantTextRef.current = finalDisplayText;\r\n\r\n if (assistantMessageIdRef.current !== null) {\r\n updateMessageText(\r\n assistantMessageIdRef.current,\r\n finalDisplayText,\r\n );\r\n } else {\r\n assistantMessageIdRef.current = appendMessage(\r\n finalDisplayText,\r\n false,\r\n );\r\n }\r\n },\r\n onIntermediateReply: (text) => {\r\n void speakText(\r\n config.backendBaseUrl, text, config.voice,\r\n accessibilityMode, handleAudioStateChange,\r\n ).catch((err) => console.warn(\"[Bulut] intermediate TTS failed\", err));\r\n },\r\n onToolCalls: (calls) => {\r\n if (calls.length > 0) {\r\n playSfx(\"toolCall\");\r\n }\r\n setIsRunningTools(true);\r\n setStatusOverride(STATUS_LABELS.runningTools);\r\n\r\n for (const call of calls) {\r\n const toolLabel =\r\n call.tool === \"navigate\"\r\n ? `Sayfaya gidiliyor: ${call.args.url ?? \"\"}`\r\n : call.tool === \"getPageContext\"\r\n ? \"Sayfa bağlamı alınıyor…\"\r\n : call.tool === \"interact\"\r\n ? `Etkileşim: ${call.args.action ?? \"\"}`\r\n : call.tool === \"scroll\"\r\n ? \"Kaydırılıyor…\"\r\n : call.tool;\r\n\r\n appendMessage(`${toolLabel}`, false);\r\n setMessages((prev) => {\r\n const last = prev[prev.length - 1];\r\n if (last && !last.isUser) {\r\n return [\r\n ...prev.slice(0, -1),\r\n { ...last, type: \"tool\" as const },\r\n ];\r\n }\r\n return prev;\r\n });\r\n }\r\n\r\n assistantMessageIdRef.current = null;\r\n pendingAssistantTextRef.current = \"\";\r\n },\r\n onToolResult: () => {},\r\n onIteration: () => {\r\n playSfx(\"thinking\");\r\n setIsThinking(true);\r\n setStatusOverride(STATUS_LABELS.thinking);\r\n },\r\n onAudioStateChange: handleAudioStateChange,\r\n onError: (err) => {\r\n awaitingAssistantResponseRef.current = false;\r\n setStatusOverride(null);\r\n appendMessage(`Hata: ${err}`, false);\r\n },\r\n },\r\n handleToolExecution,\r\n );\r\n\r\n activeStreamControllerRef.current = controller;\r\n await controller.done;\r\n } catch (error) {\r\n awaitingAssistantResponseRef.current = false;\r\n setStatusOverride(null);\r\n if (error instanceof Error) {\r\n appendMessage(`Hata: ${error.message}`, false);\r\n }\r\n } finally {\r\n finalizeStreamCycle();\r\n }\r\n };\r\n\r\n const handleAudioBlob = async (blob: Blob) => {\r\n if (!config.projectId) {\r\n appendMessage(\"Hata: Project ID yapılandırılmamış.\", false);\r\n return;\r\n }\r\n\r\n setIsBusy(true);\r\n setIsTranscribing(true);\r\n setIsThinking(false);\r\n setIsRenderingAudio(false);\r\n setIsPlayingAudio(false);\r\n setIsRunningTools(false);\r\n resetProcessingFlags(); // Start fresh\r\n setStatusOverride(STATUS_LABELS.thinking);\r\n awaitingAssistantResponseRef.current = true;\r\n\r\n try {\r\n const fileType = blob.type || \"audio/webm\";\r\n const extension = fileType.includes(\"ogg\")\r\n ? \"ogg\"\r\n : fileType.includes(\"wav\")\r\n ? \"wav\"\r\n : fileType.includes(\"mpeg\") || fileType.includes(\"mp3\")\r\n ? \"mp3\"\r\n : \"webm\";\r\n const file = new File([blob], `voice-input.${extension}`, {\r\n type: fileType,\r\n });\r\n\r\n stopActiveStream();\r\n\r\n const pageContext = getPageContext().summary;\r\n\r\n // Helper: bridge an AgentToolCallInfo to a ToolCallWithId\r\n const handleToolExecution = async (\r\n call: AgentToolCallInfo,\r\n ): Promise<{ call_id: string; result: string }> => {\r\n const toolCall: ToolCallWithId = {\r\n tool: call.tool as\r\n | \"navigate\"\r\n | \"getPageContext\"\r\n | \"interact\"\r\n | \"scroll\",\r\n call_id: call.call_id,\r\n ...call.args,\r\n } as ToolCallWithId;\r\n return executeSingleToolCall(toolCall);\r\n };\r\n\r\n const controller = agentVoiceChatStream(\r\n config.backendBaseUrl,\r\n file,\r\n config.projectId,\r\n sessionIdRef.current,\r\n {\r\n model: config.model,\r\n voice: config.voice,\r\n pageContext,\r\n accessibilityMode,\r\n },\r\n {\r\n onSttRequestSent: () => {\r\n playSfx(\"sent\");\r\n },\r\n onTranscription: (data) => {\r\n if (data.session_id && data.session_id !== sessionIdRef.current) {\r\n sessionIdRef.current = data.session_id;\r\n if (typeof localStorage !== \"undefined\") {\r\n localStorage.setItem(SESSION_ID_KEY, data.session_id);\r\n }\r\n }\r\n\r\n const normalized = data.user_text.trim();\r\n if (normalized) {\r\n const previousUserText = pendingUserTextRef.current;\r\n pendingUserTextRef.current = normalized;\r\n if (liveTranscriptionMessageIdRef.current !== null) {\r\n updateMessageText(liveTranscriptionMessageIdRef.current, normalized);\r\n clearLiveUserTranscriptionState();\r\n } else if (previousUserText !== normalized) {\r\n appendMessage(normalized, true);\r\n }\r\n }\r\n\r\n setIsTranscribing(false);\r\n setIsThinking(true);\r\n setStatusOverride(STATUS_LABELS.thinking);\r\n },\r\n onSessionId: (sid) => {\r\n if (sid && sid !== sessionIdRef.current) {\r\n sessionIdRef.current = sid;\r\n if (typeof localStorage !== \"undefined\") {\r\n localStorage.setItem(SESSION_ID_KEY, sid);\r\n }\r\n }\r\n },\r\n onAssistantDelta: (delta) => {\r\n setIsTranscribing(false);\r\n setIsThinking(true);\r\n setIsRunningTools(false);\r\n if (awaitingAssistantResponseRef.current) {\r\n awaitingAssistantResponseRef.current = false;\r\n setStatusOverride(null);\r\n }\r\n\r\n // Agent returns plain text (not JSON), stream it directly\r\n pendingAssistantTextRef.current += delta;\r\n\r\n if (assistantMessageIdRef.current === null) {\r\n assistantMessageIdRef.current = appendMessage(\r\n pendingAssistantTextRef.current,\r\n false,\r\n );\r\n } else {\r\n updateMessageText(\r\n assistantMessageIdRef.current,\r\n pendingAssistantTextRef.current,\r\n );\r\n }\r\n },\r\n onAssistantDone: (assistantText) => {\r\n playSfx(\"completed\");\r\n awaitingAssistantResponseRef.current = false;\r\n setStatusOverride(null);\r\n setIsThinking(false);\r\n setIsRenderingAudio(true);\r\n\r\n const finalDisplayText =\r\n assistantText || pendingAssistantTextRef.current;\r\n\r\n streamingJsonParserRef.current = null;\r\n pendingAssistantTextRef.current = finalDisplayText;\r\n\r\n if (assistantMessageIdRef.current !== null) {\r\n updateMessageText(\r\n assistantMessageIdRef.current,\r\n finalDisplayText,\r\n );\r\n } else {\r\n assistantMessageIdRef.current = appendMessage(\r\n finalDisplayText,\r\n false,\r\n );\r\n }\r\n },\r\n onIntermediateReply: (text) => {\r\n void speakText(\r\n config.backendBaseUrl, text, config.voice,\r\n accessibilityMode, handleAudioStateChange,\r\n ).catch((err) => console.warn(\"[Bulut] intermediate TTS failed\", err));\r\n },\r\n onToolCalls: (calls) => {\r\n if (calls.length > 0) {\r\n playSfx(\"toolCall\");\r\n }\r\n setIsRunningTools(true);\r\n setStatusOverride(STATUS_LABELS.runningTools);\r\n\r\n // Show each tool call as a small indicator message\r\n for (const call of calls) {\r\n const toolLabel =\r\n call.tool === \"navigate\"\r\n ? `Sayfaya gidiliyor: ${call.args.url ?? \"\"}`\r\n : call.tool === \"getPageContext\"\r\n ? \"Sayfa bağlamı alınıyor…\"\r\n : call.tool === \"interact\"\r\n ? `Etkileşim: ${call.args.action ?? \"\"}`\r\n : call.tool === \"scroll\"\r\n ? \"Kaydırılıyor…\"\r\n : call.tool;\r\n\r\n appendMessage(`${toolLabel}`, false);\r\n // Mark the tool message\r\n setMessages((prev) => {\r\n const last = prev[prev.length - 1];\r\n if (last && !last.isUser) {\r\n return [\r\n ...prev.slice(0, -1),\r\n { ...last, type: \"tool\" as const },\r\n ];\r\n }\r\n return prev;\r\n });\r\n }\r\n\r\n // Reset assistant message ref so next reply gets a new bubble\r\n assistantMessageIdRef.current = null;\r\n pendingAssistantTextRef.current = \"\";\r\n },\r\n onToolResult: (_callId, _toolName, _result) => {\r\n // Tool result sent back to agent automatically.\r\n // Could display detailed result here if needed.\r\n },\r\n onIteration: (_iteration, _maxIterations) => {\r\n // Agent started a new reasoning iteration\r\n playSfx(\"thinking\");\r\n setIsThinking(true);\r\n setStatusOverride(STATUS_LABELS.thinking);\r\n },\r\n onAudioStateChange: handleAudioStateChange,\r\n onError: (err) => {\r\n awaitingAssistantResponseRef.current = false;\r\n setStatusOverride(null);\r\n appendMessage(`Hata: ${err}`, false);\r\n },\r\n },\r\n handleToolExecution,\r\n );\r\n\r\n activeStreamControllerRef.current = controller;\r\n await controller.done;\r\n\r\n // Safety: Ensure messages are flushed if not already\r\n // (e.g. if audio 'done' event didn't fire for some reason or there was no audio)\r\n /* if (pendingUserTextRef.current || pendingAssistantTextRef.current) {\r\n // flushPendingMessages(); // Removed as we stream now\r\n } */\r\n } catch (error) {\r\n // Error already shown via onError callback — don't duplicate\r\n awaitingAssistantResponseRef.current = false;\r\n setStatusOverride(null);\r\n } finally {\r\n finalizeStreamCycle();\r\n }\r\n };\r\n\r\n const stopRecording = (options?: { discard?: boolean }) => {\r\n const recorder = recorderRef.current;\r\n if (!recorder || recorder.state === \"inactive\") {\r\n return;\r\n }\r\n\r\n if (options?.discard) {\r\n discardNextRecordingRef.current = true;\r\n }\r\n\r\n cleanupVAD();\r\n recorder.stop();\r\n };\r\n\r\n const setupVAD = (stream: MediaStream, recorder: MediaRecorder) => {\r\n const AudioCtx =\r\n window.AudioContext ||\r\n (window as Window & { webkitAudioContext?: typeof AudioContext })\r\n .webkitAudioContext;\r\n\r\n if (!AudioCtx) {\r\n return;\r\n }\r\n\r\n const context = new AudioCtx();\r\n audioContextRef.current = context;\r\n\r\n const analyser = context.createAnalyser();\r\n analyser.fftSize = 256;\r\n\r\n const source = context.createMediaStreamSource(stream);\r\n sourceRef.current = source;\r\n source.connect(analyser);\r\n\r\n const dataArray = new Uint8Array(analyser.frequencyBinCount);\r\n silenceStartRef.current = null;\r\n let speechDetected = false;\r\n\r\n vadIntervalRef.current = window.setInterval(() => {\r\n if (!isRecordingRef.current || recorder.state === \"inactive\") {\r\n cleanupVAD();\r\n return;\r\n }\r\n\r\n analyser.getByteFrequencyData(dataArray);\r\n\r\n let sum = 0;\r\n for (const value of dataArray) {\r\n sum += value;\r\n }\r\n const average = sum / dataArray.length;\r\n const volume = average / 255;\r\n\r\n if (volume < VAD_THRESHOLD) {\r\n if (silenceStartRef.current === null) {\r\n silenceStartRef.current = Date.now();\r\n return;\r\n }\r\n\r\n const silenceDuration = Date.now() - silenceStartRef.current;\r\n if (speechDetected && silenceDuration > SILENCE_DURATION_MS) {\r\n stopRecording();\r\n }\r\n return;\r\n }\r\n\r\n speechDetected = true;\r\n silenceStartRef.current = null;\r\n }, 50);\r\n };\r\n\r\n const startRecording = async (mode: RecordingMode) => {\r\n if (\r\n isBusyRef.current ||\r\n isRecordingRef.current ||\r\n startRecordingPendingRef.current\r\n ) {\r\n return;\r\n }\r\n\r\n setStatusOverride(STATUS_LABELS.listening);\r\n\r\n if (!navigator.mediaDevices?.getUserMedia) {\r\n setStatusOverride(null);\r\n appendMessage(\"Bu tarayıcıda mikrofon kullanılamıyor.\", false);\r\n return;\r\n }\r\n\r\n if (typeof MediaRecorder === \"undefined\") {\r\n setStatusOverride(null);\r\n appendMessage(\"Bu tarayıcıda MediaRecorder desteklenmiyor.\", false);\r\n return;\r\n }\r\n\r\n startRecordingPendingRef.current = true;\r\n\r\n try {\r\n const stream = await navigator.mediaDevices.getUserMedia({ audio: true });\r\n streamRef.current = stream;\r\n\r\n // Use low bitrate for speech — opus handles voice well at 16-24 kbps\r\n // and produces ~4-5x smaller payloads, speeding up the upload to fal.\r\n const recorderOptions: MediaRecorderOptions = {\r\n audioBitsPerSecond: 16_000,\r\n };\r\n\r\n // Prefer opus-in-ogg (smaller container) → opus-in-webm → browser default\r\n const preferredMimeTypes = [\r\n \"audio/ogg;codecs=opus\",\r\n \"audio/webm;codecs=opus\",\r\n \"audio/webm\",\r\n ];\r\n for (const mime of preferredMimeTypes) {\r\n if (MediaRecorder.isTypeSupported(mime)) {\r\n recorderOptions.mimeType = mime;\r\n break;\r\n }\r\n }\r\n\r\n const recorder = new MediaRecorder(stream, recorderOptions);\r\n recorderRef.current = recorder;\r\n audioChunksRef.current = [];\r\n clearLiveUserTranscriptionState();\r\n\r\n const sttMimeType = (recorder.mimeType || recorderOptions.mimeType || \"audio/webm\")\r\n .split(\";\")[0]\r\n .trim() || \"audio/webm\";\r\n\r\n const sttWsController = startSttWebSocketStream(\r\n config.backendBaseUrl,\r\n {\r\n projectId: config.projectId,\r\n sessionId: sessionIdRef.current,\r\n language: \"tr\",\r\n mimeType: sttMimeType,\r\n },\r\n {\r\n onRequestSent: () => {\r\n playSfx(\"sent\");\r\n },\r\n onSessionId: (sid) => {\r\n if (!sid || sid === sessionIdRef.current) {\r\n return;\r\n }\r\n sessionIdRef.current = sid;\r\n if (typeof localStorage !== \"undefined\") {\r\n localStorage.setItem(SESSION_ID_KEY, sid);\r\n }\r\n },\r\n onPartial: ({ text }) => {\r\n if (!text.trim()) {\r\n return;\r\n }\r\n upsertLiveUserTranscription(text);\r\n },\r\n },\r\n );\r\n activeSttWsRef.current = sttWsController;\r\n\r\n recorder.ondataavailable = (event) => {\r\n if (event.data.size > 0) {\r\n audioChunksRef.current.push(event.data);\r\n if (activeSttWsRef.current) {\r\n void activeSttWsRef.current.pushChunk(event.data).catch((error) => {\r\n console.warn(\r\n `[Bulut] STT WS chunk send failed: ${error instanceof Error ? error.message : String(error)}`,\r\n );\r\n });\r\n }\r\n }\r\n };\r\n\r\n recorder.onerror = () => {\r\n appendMessage(\"Mikrofon kaydı sırasında bir hata oluştu.\", false);\r\n };\r\n\r\n recorder.onstop = async () => {\r\n setIsRecording(false);\r\n isRecordingRef.current = false;\r\n recordingModeRef.current = null;\r\n stopRecordingTimer();\r\n\r\n cleanupVAD();\r\n stopStreamTracks();\r\n\r\n const shouldDiscard = discardNextRecordingRef.current;\r\n discardNextRecordingRef.current = false;\r\n\r\n const blob = new Blob(audioChunksRef.current, {\r\n type: recorder.mimeType || \"audio/webm\",\r\n });\r\n audioChunksRef.current = [];\r\n\r\n const currentSttWs = activeSttWsRef.current;\r\n activeSttWsRef.current = null;\r\n\r\n if (shouldDiscard) {\r\n currentSttWs?.cancel();\r\n clearLiveUserTranscriptionState();\r\n setStatusOverride(null);\r\n return;\r\n }\r\n\r\n if (blob.size === 0) {\r\n currentSttWs?.cancel();\r\n clearLiveUserTranscriptionState();\r\n setStatusOverride(null);\r\n appendMessage(\"Ses kaydı alınamadı. Lütfen tekrar deneyin.\", false);\r\n return;\r\n }\r\n\r\n setIsTranscribing(true);\r\n setStatusOverride(STATUS_LABELS.transcribing);\r\n\r\n try {\r\n if (currentSttWs) {\r\n const sttResult = await currentSttWs.stop();\r\n if (sttResult.session_id && sttResult.session_id !== sessionIdRef.current) {\r\n sessionIdRef.current = sttResult.session_id;\r\n if (typeof localStorage !== \"undefined\") {\r\n localStorage.setItem(SESSION_ID_KEY, sttResult.session_id);\r\n }\r\n }\r\n if (sttResult.text.trim()) {\r\n upsertLiveUserTranscription(sttResult.text);\r\n setStatusOverride(STATUS_LABELS.thinking);\r\n await runAgentForUserText(sttResult.text);\r\n return;\r\n }\r\n }\r\n } catch (error) {\r\n console.warn(\r\n `[Bulut] STT WS finalization failed, falling back to HTTP POST /chat/stt: ${error instanceof Error ? error.message : String(error)}`,\r\n );\r\n } finally {\r\n clearLiveUserTranscriptionState();\r\n }\r\n\r\n console.info(\"[Bulut] Using HTTP POST fallback for STT (streaming WS did not succeed)\");\r\n setStatusOverride(STATUS_LABELS.thinking);\r\n await handleAudioBlob(blob);\r\n };\r\n\r\n if (mode === \"vad\") {\r\n setupVAD(stream, recorder);\r\n }\r\n\r\n recorder.start(200);\r\n recordingModeRef.current = mode;\r\n setIsRecording(true);\r\n isRecordingRef.current = true;\r\n startRecordingTimer();\r\n\r\n if (pendingStopAfterStartRef.current) {\r\n pendingStopAfterStartRef.current = false;\r\n stopRecording();\r\n }\r\n } catch (error) {\r\n const errMsg = normalizeError(error);\r\n if (errMsg.toLowerCase().includes(\"permission\") || errMsg.toLowerCase().includes(\"denied\")) {\r\n autoListenSuppressedRef.current = true;\r\n }\r\n cancelActiveSttWs();\r\n setStatusOverride(null);\r\n appendMessage(`Mikrofon hatası: ${errMsg}`, false);\r\n cleanupVAD();\r\n stopStreamTracks();\r\n pendingStopAfterStartRef.current = false;\r\n setIsRecording(false);\r\n isRecordingRef.current = false;\r\n stopRecordingTimer();\r\n } finally {\r\n if (!isRecordingRef.current && !isBusyRef.current) {\r\n setStatusOverride(null);\r\n }\r\n startRecordingPendingRef.current = false;\r\n }\r\n };\r\n\r\n const resetMicGesture = () => {\r\n micPressStartRef.current = null;\r\n micHoldTriggeredRef.current = false;\r\n clearMicHoldTimeout();\r\n };\r\n\r\n const handleMicPointerDown = (\r\n event: JSX.TargetedPointerEvent<HTMLButtonElement>,\r\n ) => {\r\n event.preventDefault();\r\n\r\n if (isBusyRef.current) {\r\n return;\r\n }\r\n\r\n if (isRecordingRef.current) {\r\n // In VAD mode, tapping the button cancels; in press mode, it sends\r\n if (recordingModeRef.current === \"vad\") {\r\n stopRecording({ discard: true });\r\n } else {\r\n stopRecording();\r\n }\r\n return;\r\n }\r\n\r\n micPressStartRef.current = Date.now();\r\n micHoldTriggeredRef.current = false;\r\n clearMicHoldTimeout();\r\n\r\n if (event.currentTarget.setPointerCapture) {\r\n try {\r\n event.currentTarget.setPointerCapture(event.pointerId);\r\n } catch {\r\n // No-op.\r\n }\r\n }\r\n\r\n micHoldTimeoutRef.current = window.setTimeout(() => {\r\n if (\r\n micPressStartRef.current === null ||\r\n isBusyRef.current ||\r\n isRecordingRef.current\r\n ) {\r\n return;\r\n }\r\n\r\n micHoldTriggeredRef.current = true;\r\n void startRecording(\"press\");\r\n }, HOLD_THRESHOLD_MS);\r\n };\r\n\r\n const handleMicPointerUp = (\r\n event: JSX.TargetedPointerEvent<HTMLButtonElement>,\r\n ) => {\r\n event.preventDefault();\r\n\r\n if (event.currentTarget.releasePointerCapture) {\r\n try {\r\n event.currentTarget.releasePointerCapture(event.pointerId);\r\n } catch {\r\n // No-op.\r\n }\r\n }\r\n\r\n const startedAt = micPressStartRef.current;\r\n const wasHold = micHoldTriggeredRef.current;\r\n resetMicGesture();\r\n\r\n if (startedAt === null) {\r\n return;\r\n }\r\n\r\n if (wasHold) {\r\n if (isRecordingRef.current) {\r\n stopRecording();\r\n } else if (startRecordingPendingRef.current) {\r\n pendingStopAfterStartRef.current = true;\r\n }\r\n return;\r\n }\r\n\r\n const duration = Date.now() - startedAt;\r\n if (classifyMicGesture(duration) === \"tap\") {\r\n void startRecording(\"vad\");\r\n }\r\n };\r\n\r\n const handleMicPointerCancel = (\r\n event: JSX.TargetedPointerEvent<HTMLButtonElement>,\r\n ) => {\r\n handleMicPointerUp(event);\r\n };\r\n\r\n const handleRestart = () => {\r\n resetMicGesture();\r\n pendingStopAfterStartRef.current = false;\r\n\r\n stopActiveStream();\r\n cancelActiveSttWs();\r\n\r\n if (recorderRef.current && recorderRef.current.state !== \"inactive\") {\r\n stopRecording({ discard: true });\r\n } else {\r\n discardNextRecordingRef.current = false;\r\n cleanupVAD();\r\n stopStreamTracks();\r\n }\r\n\r\n stopRecordingTimer();\r\n setRecordingDurationMs(0);\r\n\r\n clearPersistedChatState(\r\n typeof localStorage !== \"undefined\" ? localStorage : null,\r\n );\r\n\r\n sessionIdRef.current = null;\r\n const initialMessages = createInitialMessages(config.agentName);\r\n nextMessageIdRef.current = getNextMessageId(initialMessages);\r\n setMessages(initialMessages);\r\n\r\n setIsBusy(false);\r\n isBusyRef.current = false;\r\n setIsRecording(false);\r\n isRecordingRef.current = false;\r\n resetProcessingFlags();\r\n };\r\n\r\n // Auto-listen when accessibility mode is activated (initial trigger)\r\n useEffect(() => {\r\n if (!accessibilityMode || autoListenSuppressedRef.current) return;\r\n const timer = window.setTimeout(() => {\r\n if (!isRecordingRef.current && !isBusyRef.current && !startRecordingPendingRef.current && !autoListenSuppressedRef.current) {\r\n void startRecording(\"vad\");\r\n }\r\n }, 500);\r\n return () => window.clearTimeout(timer);\r\n }, [accessibilityMode]); // eslint-disable-line react-hooks/exhaustive-deps\r\n\r\n const stopTask = () => {\r\n stopActiveStream();\r\n cancelActiveSttWs();\r\n stopRecording({ discard: true });\r\n cleanupVAD();\r\n stopStreamTracks();\r\n resetProcessingFlags();\r\n setIsBusy(false);\r\n };\r\n\r\n // Expose recording actions to parent via actionsRef\r\n if (actionsRef) {\r\n actionsRef.current = {\r\n startRecording: () => {\r\n autoListenSuppressedRef.current = false;\r\n void startRecording(\"vad\");\r\n },\r\n cancelRecording: () => {\r\n cancelActiveSttWs();\r\n const recorder = recorderRef.current;\r\n if (recorder && recorder.state !== \"inactive\") {\r\n stopRecording({ discard: true });\r\n } else {\r\n cleanupVAD();\r\n stopStreamTracks();\r\n }\r\n },\r\n stopTask,\r\n };\r\n }\r\n\r\n const windowStyle: { [key: string]: string } = {\r\n position: \"fixed\",\r\n bottom: `${POSITION_BOTTOM}px`,\r\n right: `${POSITION_RIGHT}px`,\r\n width: `${WINDOW_WIDTH}px`,\r\n maxHeight: `${WINDOW_HEIGHT}px`,\r\n backgroundColor: \"hsla(0, 0%, 100%, 1)\",\r\n borderRadius: BORDER_RADIUS.window,\r\n display: hidden ? \"none\" : \"flex\",\r\n flexDirection: \"column\",\r\n overflow: \"hidden\",\r\n zIndex: \"10000\",\r\n animation: hidden ? \"none\" : `slideIn ${TRANSITIONS.medium}`,\r\n boxShadow: SHADOW,\r\n fontFamily: \"\\\"Geist\\\", sans-serif\",\r\n };\r\n\r\n const headerStyle: { [key: string]: string } = {\r\n padding: \"14px 16px\",\r\n display: \"flex\",\r\n justifyContent: \"space-between\",\r\n alignItems: \"center\",\r\n };\r\n\r\n const headerActionsStyle: { [key: string]: string } = {\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n gap: \"6px\",\r\n };\r\n\r\n const headerButtonStyle: { [key: string]: string } = {\r\n background: \"none\",\r\n border: \"none\",\r\n cursor: \"pointer\",\r\n padding: \"4px\",\r\n borderRadius: \"6px\",\r\n color: COLORS.text,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n transition: `color ${TRANSITIONS.fast}, background-color ${TRANSITIONS.fast}`,\r\n };\r\n\r\n const messagesContainerStyle: { [key: string]: string } = {\r\n padding: \"0px 16px\",\r\n overflowY: \"auto\",\r\n flex: \"1\",\r\n minHeight: \"0\",\r\n };\r\n\r\n const messagesListStyle: { [key: string]: string } = {\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n gap: \"16px\",\r\n };\r\n\r\n const messageStyle = (isUser: boolean): JSX.CSSProperties => ({\r\n maxWidth: \"84%\",\r\n padding: isUser ? \"9px 14px\" : \"0px 0px\",\r\n borderRadius: BORDER_RADIUS.message,\r\n fontSize: \"14px\",\r\n lineHeight: \"140%\",\r\n wordWrap: \"break-word\",\r\n whiteSpace: \"pre-wrap\",\r\n alignSelf: isUser ? \"flex-end\" : \"flex-start\",\r\n backgroundColor: isUser ? COLORS.messageUser : \"\",\r\n color: isUser ? COLORS.messageUserText : \"hsla(215, 100%, 5%, 1)\",\r\n });\r\n\r\n const footerStyle: { [key: string]: string } = {\r\n padding: \"10px 12px\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"space-between\",\r\n gap: \"8px\",\r\n };\r\n\r\n const statusPanelStyle: { [key: string]: string } = {\r\n flex: \"1\",\r\n minHeight: \"34px\",\r\n borderRadius: \"10px\",\r\n color: COLORS.text,\r\n fontSize: \"14px\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n padding: \"0 10px\",\r\n whiteSpace: \"nowrap\",\r\n overflow: \"hidden\",\r\n textOverflow: \"ellipsis\",\r\n opacity: \"0.7\",\r\n };\r\n\r\n const footerActionsStyle: { [key: string]: string } = {\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n gap: \"8px\",\r\n flexShrink: \"0\",\r\n };\r\n\r\n const recordingTimerStyle: { [key: string]: string } = {\r\n minWidth: \"46px\",\r\n fontSize: \"12px\",\r\n fontWeight: \"700\",\r\n color: COLORS.text,\r\n textAlign: \"right\",\r\n };\r\n\r\n const micFooterButtonStyle: { [key: string]: string } = {\r\n width: \"37px\",\r\n height: \"37px\",\r\n borderRadius: \"999px\",\r\n background: \"transparent\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n cursor: \"pointer\",\r\n color: \"#ffffff\",\r\n border: \"1px solid hsla(215, 100%, 5%, 0.5)\",\r\n transition: `transform ${TRANSITIONS.fast}`,\r\n };\r\n\r\n const isVadRecording = isRecording && recordingModeRef.current === \"vad\";\r\n const showStopButton = isBusy && !isRecording;\r\n const disableMicControl = isBusy;\r\n\r\n return (\r\n <div className=\"bulut-chat-window\" style={windowStyle}>\r\n <style>{`\r\n @keyframes slideIn {\r\n from {\r\n opacity: 0;\r\n transform: translateY(10px);\r\n }\r\n to {\r\n opacity: 1;\r\n transform: translateY(0);\r\n }\r\n }\r\n\r\n .bulut-header-btn:hover:not(:disabled) {\r\n color: ${COLORS.text};\r\n }\r\n\r\n .bulut-footer-btn:hover:not(:disabled) {\r\n transform: scale(1.04);\r\n }\r\n\r\n .bulut-header-btn:disabled,\r\n .bulut-footer-btn:disabled {\r\n cursor: not-allowed;\r\n opacity: 0.5;\r\n transform: none;\r\n }\r\n\r\n @keyframes bulut-dots {\r\n 0% { content: '.'; }\r\n 33% { content: '..'; }\r\n 66% { content: '...'; }\r\n }\r\n\r\n .bulut-status-dots::after {\r\n content: '.';\r\n animation: bulut-dots 1.2s steps(1) infinite;\r\n display: inline-block;\r\n min-width: 12px;\r\n text-align: left;\r\n }\r\n\r\n /* Mobile: full-screen chat window */\r\n @media (max-width: 600px) {\r\n .bulut-chat-window {\r\n top: 0 !important;\r\n left: 0 !important;\r\n right: 0 !important;\r\n bottom: 0 !important;\r\n width: 100% !important;\r\n max-height: 100% !important;\r\n height: 100% !important;\r\n border-radius: 0 !important;\r\n }\r\n .bulut-close-btn {\r\n width: 40px !important;\r\n height: 40px !important;\r\n padding: 8px !important;\r\n }\r\n .bulut-close-btn svg {\r\n width: 26px !important;\r\n height: 26px !important;\r\n }\r\n }\r\n `}</style>\r\n\r\n <div style={headerStyle}>\r\n <SvgIcon\r\n src={logoContent}\r\n title=\"Bulut Logo\"\r\n style={{ maxWidth: \"80px\", height: \"auto\" }}\r\n stripColors={false}\r\n />\r\n <div style={headerActionsStyle}>\r\n <button\r\n type=\"button\"\r\n className=\"bulut-header-btn\"\r\n style={headerButtonStyle}\r\n onClick={handleRestart}\r\n aria-label=\"Sohbeti yeniden başlat\"\r\n title=\"Sohbeti yeniden başlat\"\r\n >\r\n <SvgIcon src={restartIconContent} width={22} />\r\n </button>\r\n\r\n <button\r\n type=\"button\"\r\n className=\"bulut-header-btn bulut-close-btn\"\r\n style={{\r\n ...headerButtonStyle,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n }}\r\n onClick={onClose}\r\n aria-label=\"Sohbeti kapat\"\r\n title=\"Sohbeti kapat\"\r\n >\r\n <SvgIcon\r\n fill-opacity={\"0\"}\r\n stroke={\"currentColor\"}\r\n src={closeIconContent}\r\n width={22}\r\n />\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div style={messagesContainerStyle} ref={messagesContainerRef}>\r\n <div style={messagesListStyle} ref={messagesContentRef}>\r\n {messages.map((message) => (\r\n <div\r\n key={message.id}\r\n style={\r\n message.type === \"tool\"\r\n ? {\r\n padding: \"9px 14px\",\r\n fontSize: \"14px\",\r\n lineHeight: \"1.4\",\r\n color: \"hsla(215, 100%, 5%, 1)\",\r\n fontWeight: 600,\r\n backgroundColor: \"hsla(215, 100%, 5%, 0.05)\",\r\n borderRadius: \"10px\",\r\n alignSelf: \"flex-start\",\r\n maxWidth: \"84%\",\r\n }\r\n : messageStyle(message.isUser)\r\n }\r\n >\r\n {message.text}\r\n </div>\r\n ))}\r\n </div>\r\n </div>\r\n\r\n <div style={footerStyle}>\r\n <div style={{ ...statusPanelStyle, transition: \"opacity 0.2s ease-out\" }}>\r\n {statusText !== STATUS_LABELS.ready ? (\r\n <span className=\"bulut-status-dots\" title={statusText}>\r\n {statusText}\r\n </span>\r\n ) : onAccessibilityToggle ? (\r\n <div\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n gap: \"8px\",\r\n }}\r\n >\r\n <span\r\n style={{\r\n fontSize: \"12px\",\r\n opacity: \"0.6\",\r\n whiteSpace: \"nowrap\",\r\n }}\r\n >\r\n Erişilebilirlik\r\n </span>\r\n <button\r\n type=\"button\"\r\n onClick={onAccessibilityToggle}\r\n aria-label={\r\n accessibilityMode\r\n ? \"Erişilebilirlik modunu kapat\"\r\n : \"Erişilebilirlik modunu aç\"\r\n }\r\n style={{\r\n width: \"36px\",\r\n height: \"20px\",\r\n borderRadius: \"10px\",\r\n border: \"none\",\r\n cursor: \"pointer\",\r\n padding: \"2px\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n backgroundColor: accessibilityMode\r\n ? COLORS.primary\r\n : \"hsla(215, 10%, 75%, 1)\",\r\n transition: `background-color ${TRANSITIONS.fast}`,\r\n flexShrink: \"0\",\r\n }}\r\n >\r\n <span\r\n style={{\r\n width: \"16px\",\r\n height: \"16px\",\r\n borderRadius: \"50%\",\r\n backgroundColor: \"#ffffff\",\r\n display: \"block\",\r\n transition: `transform ${TRANSITIONS.fast}`,\r\n transform: accessibilityMode\r\n ? \"translateX(16px)\"\r\n : \"translateX(0)\",\r\n boxShadow: \"0 1px 3px rgba(0,0,0,0.2)\",\r\n }}\r\n />\r\n </button>\r\n </div>\r\n ) : null}\r\n </div>\r\n\r\n <div style={footerActionsStyle}>\r\n {isRecording ? (\r\n <span style={recordingTimerStyle}>\r\n {formatDurationMs(recordingDurationMs)}\r\n </span>\r\n ) : null}\r\n {showStopButton ? (\r\n <button\r\n type=\"button\"\r\n className=\"bulut-footer-btn\"\r\n style={micFooterButtonStyle}\r\n onClick={stopTask}\r\n aria-label=\"Görevi durdur\"\r\n title=\"Görevi durdur\"\r\n >\r\n <SvgIcon\r\n fill-opacity={\"0\"}\r\n stroke={\"hsla(215, 100%, 5%, 1)\"}\r\n src={stopIconContent}\r\n width={22}\r\n />\r\n </button>\r\n ) : (\r\n <button\r\n type=\"button\"\r\n className=\"bulut-footer-btn\"\r\n style={micFooterButtonStyle}\r\n onPointerDown={handleMicPointerDown}\r\n onPointerUp={handleMicPointerUp}\r\n onPointerCancel={handleMicPointerCancel}\r\n disabled={disableMicControl}\r\n aria-label={isVadRecording ? \"Kaydı iptal et\" : isRecording ? \"Kaydı durdur\" : \"Kaydı başlat\"}\r\n title={\r\n isVadRecording\r\n ? \"Kaydı iptal et\"\r\n : isRecording\r\n ? \"Kaydı durdur\"\r\n : \"Dokun: VAD, Basılı tut: bırakınca gönder\"\r\n }\r\n >\r\n <SvgIcon\r\n fill-opacity={\"0\"}\r\n stroke={\"hsla(215, 100%, 5%, 1)\"}\r\n src={isVadRecording ? closeIconContent : microphoneIconContent}\r\n width={22}\r\n />\r\n </button>\r\n )}\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","export default \"<svg width=\\\"2420\\\" height=\\\"438\\\" viewBox=\\\"0 0 2420 438\\\" fill=\\\"none\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\">\\r\\n<path d=\\\"M251.823 0C313.458 0 366.34 37.767 388.932 91.5918C409.253 75.8883 434.678 66.5567 462.264 66.5566C528.885 66.5567 582.893 120.989 582.893 188.134C582.893 188.786 582.885 189.436 582.875 190.086C648.144 193.552 700 247.572 700 313.704C700 382.074 644.575 437.5 576.204 437.5H123.796C55.4255 437.5 7.42386e-05 382.074 0 313.704C0 250.475 47.4025 198.32 108.608 190.833C104.967 177.844 103.019 164.138 103.019 149.975C103.019 67.1461 169.641 0.000357483 251.823 0ZM234.696 141.93C218.117 134.066 199 146.158 199 164.507C199 174.32 204.744 183.225 213.684 187.271L336.761 242.985C337.971 243.533 338.748 244.738 338.748 246.066C338.748 247.394 337.971 248.6 336.761 249.147L213.684 304.861C204.744 308.908 199 317.812 199 327.625C199 345.974 218.117 358.066 234.696 350.202L364.672 288.554C375.142 283.588 381.815 273.036 381.815 261.448V230.684C381.815 219.096 375.142 208.544 364.672 203.578L234.696 141.93ZM413.877 296.146C402.078 296.146 392.513 305.711 392.513 317.511C392.513 329.31 402.078 338.875 413.877 338.875H526.636C538.435 338.875 548 329.31 548 317.511C548 305.711 538.435 296.146 526.636 296.146H413.877Z\\\" fill=\\\"#000B1A\\\"/>\\r\\n<path d=\\\"M2420 424.954H2343.35C2307.08 424.954 2278.64 416.094 2258.04 398.373C2237.43 380.652 2227.13 352.216 2227.13 313.065V55.2871H2319.86V302.556C2319.86 318.217 2323.15 328.726 2329.75 334.083C2336.75 339.028 2348.29 341.501 2364.36 341.501H2420V424.954ZM2420 191.903H2178.29V115.25H2420V191.903Z\\\" fill=\\\"#000B1A\\\"/>\\r\\n<path d=\\\"M1923.18 431.136C1894.33 431.136 1870.22 425.779 1850.85 415.064C1831.89 403.937 1817.68 389.101 1808.2 370.555C1799.13 352.01 1794.6 331.198 1794.6 308.12V115.25H1887.32V277.211C1887.32 301.938 1893.3 320.071 1905.25 331.61C1917.2 342.738 1937.81 348.301 1967.07 348.301C1997.56 348.301 2018.79 342.325 2030.74 330.374C2043.1 318.011 2049.28 298.641 2049.28 272.266L2061.03 271.648L2067.83 330.374H2050.52C2048.05 347.683 2041.87 363.962 2031.98 379.21C2022.5 394.458 2008.69 407.028 1990.56 416.918C1972.84 426.397 1950.38 431.136 1923.18 431.136ZM2142.01 424.955H2055.47V329.138L2049.28 326.047V115.25H2142.01V424.955Z\\\" fill=\\\"#000B1A\\\"/>\\r\\n<path d=\\\"M1734.32 424.955H1641.59V10.7793H1734.32V424.955Z\\\" fill=\\\"#000B1A\\\"/>\\r\\n<path d=\\\"M1362.98 431.136C1334.13 431.136 1310.03 425.779 1290.66 415.064C1271.7 403.937 1257.48 389.101 1248 370.555C1238.94 352.01 1234.4 331.198 1234.4 308.12V115.25H1327.13V277.211C1327.13 301.938 1333.1 320.071 1345.06 331.61C1357.01 342.738 1377.61 348.301 1406.87 348.301C1437.37 348.301 1458.59 342.325 1470.54 330.374C1482.91 318.011 1489.09 298.641 1489.09 272.266L1500.83 271.648L1507.63 330.374H1490.33C1487.85 347.683 1481.67 363.962 1471.78 379.21C1462.3 394.458 1448.5 407.028 1430.36 416.918C1412.64 426.397 1390.18 431.136 1362.98 431.136ZM1581.82 424.955H1495.27V329.138L1489.09 326.047V115.25H1581.82V424.955Z\\\" fill=\\\"#000B1A\\\"/>\\r\\n<path d=\\\"M1035.12 431.137C999.27 431.137 971.04 423.513 950.434 408.264C930.241 392.604 917.259 369.526 911.49 339.029H894.181L900.981 272.266H912.726C912.726 289.987 916.023 304.411 922.617 315.538C929.623 326.253 939.719 334.084 952.907 339.029C966.507 343.974 983.198 346.447 1002.98 346.447C1023.17 346.447 1039.66 343.974 1052.43 339.029C1065.21 334.084 1074.69 326.047 1080.87 314.92C1087.05 303.793 1090.14 288.957 1090.14 270.412C1090.14 251.042 1087.05 236 1080.87 225.285C1074.69 214.158 1065.21 206.122 1052.43 201.177C1039.66 196.231 1023.38 193.758 1003.6 193.758C973.513 193.758 950.847 199.322 935.598 210.449C920.35 221.576 912.726 240.533 912.726 267.321H900.981V197.467H917.671C923.029 171.504 935.392 150.28 954.762 133.796C974.543 117.311 1002.77 109.069 1039.45 109.069C1070.36 109.069 1096.53 115.663 1117.96 128.85C1139.39 142.038 1155.67 160.789 1166.79 185.104C1178.33 209.007 1184.1 237.443 1184.1 270.412C1184.1 302.969 1178.33 331.405 1166.79 355.72C1155.67 379.622 1138.98 398.168 1116.72 411.355C1094.47 424.543 1067.27 431.137 1035.12 431.137ZM905.926 424.955H820V10.7793H912.726V325.429L905.926 333.465V424.955Z\\\" fill=\\\"#000B1A\\\"/>\\r\\n</svg>\\r\\n\"","export default \"<svg width=\\\"50\\\" height=\\\"50\\\" viewBox=\\\"0 0 50 50\\\" fill=\\\"none\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\">\\r\\n<path d=\\\"M31.4571 10.4169C30.714 10.783 30.4083 11.6822 30.7744 12.4254C31.1405 13.1685 32.0397 13.4742 32.7829 13.1081L32.12 11.7625L31.4571 10.4169ZM44.3 28.2275C44.3 27.3991 43.6284 26.7275 42.8 26.7275C41.9716 26.7275 41.3 27.3991 41.3 28.2275H42.8H44.3ZM26.0607 0.911874C25.4749 0.326088 24.5251 0.326088 23.9393 0.911874C23.3536 1.49766 23.3536 2.44741 23.9393 3.03319L25 1.97253L26.0607 0.911874ZM33.9 10.8725L34.9607 11.9332C35.5464 11.3474 35.5464 10.3977 34.9607 9.81187L33.9 10.8725ZM23.9393 18.7119C23.3536 19.2977 23.3536 20.2474 23.9393 20.8332C24.5251 21.419 25.4749 21.419 26.0607 20.8332L25 19.7725L23.9393 18.7119ZM32.12 11.7625C32.7829 13.1081 32.7838 13.1077 32.7848 13.1072C32.7851 13.107 32.7861 13.1065 32.7868 13.1062C32.7882 13.1055 32.7896 13.1048 32.791 13.1041C32.794 13.1026 32.7971 13.101 32.8005 13.0993C32.8071 13.0959 32.8146 13.0921 32.8229 13.0878C32.8393 13.0792 32.859 13.0686 32.8813 13.0561C32.9252 13.0315 32.9828 12.9974 33.0478 12.9543C33.1597 12.8798 33.3709 12.728 33.5596 12.493C33.7406 12.2674 34.0582 11.7606 33.9356 11.0758C33.8134 10.3931 33.3372 10.002 33.0232 9.81189C32.4374 9.45724 31.5535 9.27046 30.4249 9.14527C29.2187 9.01147 27.4833 8.92753 25 8.92753V10.4275V11.9275C27.4317 11.9275 29.0439 12.0105 30.0942 12.127C31.2222 12.2521 31.5039 12.3991 31.4694 12.3782C31.4309 12.3549 31.0768 12.1307 30.9826 11.6044C30.888 11.0761 31.1396 10.7153 31.2201 10.6149C31.3083 10.5051 31.3846 10.4575 31.3868 10.4561C31.3968 10.4494 31.4058 10.444 31.4148 10.439C31.4196 10.4363 31.4253 10.4332 31.4321 10.4296C31.4355 10.4278 31.4393 10.4259 31.4434 10.4238C31.4455 10.4228 31.4477 10.4217 31.4499 10.4205C31.4511 10.4199 31.4523 10.4194 31.4535 10.4188C31.4541 10.4185 31.455 10.418 31.4553 10.4179C31.4562 10.4174 31.4571 10.4169 32.12 11.7625ZM25 10.4275V8.92753C21.1828 8.92753 17.4514 10.0595 14.2775 12.1802L15.1109 13.4274L15.9442 14.6746C18.6247 12.8835 21.7762 11.9275 25 11.9275V10.4275ZM15.1109 13.4274L14.2775 12.1802C11.1036 14.3009 8.6299 17.3151 7.16913 20.8417L8.55495 21.4158L9.94077 21.9898C11.1745 19.0114 13.2637 16.4656 15.9442 14.6746L15.1109 13.4274ZM8.55495 21.4158L7.16913 20.8417C5.70836 24.3684 5.32616 28.2489 6.07085 31.9928L7.54203 31.7001L9.01321 31.4075C8.38427 28.2456 8.70706 24.9682 9.94077 21.9898L8.55495 21.4158ZM7.54203 31.7001L6.07085 31.9928C6.81555 35.7366 8.65369 39.1755 11.3528 41.8747L12.4135 40.814L13.4742 39.7534C11.1946 37.4738 9.64215 34.5694 9.01321 31.4075L7.54203 31.7001ZM12.4135 40.814L11.3528 41.8747C14.052 44.5738 17.4909 46.412 21.2348 47.1567L21.5274 45.6855L21.82 44.2143C18.6581 43.5854 15.7538 42.033 13.4742 39.7534L12.4135 40.814ZM21.5274 45.6855L21.2348 47.1567C24.9786 47.9014 28.8592 47.5192 32.3858 46.0584L31.8118 44.6726L31.2377 43.2868C28.2593 44.5205 24.9819 44.8433 21.82 44.2143L21.5274 45.6855ZM31.8118 44.6726L32.3858 46.0584C35.9124 44.5976 38.9267 42.1239 41.0474 38.95L39.8002 38.1167L38.553 37.2833C36.7619 39.9638 34.2162 42.0531 31.2377 43.2868L31.8118 44.6726ZM39.8002 38.1167L41.0474 38.95C43.1681 35.7762 44.3 32.0447 44.3 28.2275H42.8H41.3C41.3 31.4514 40.344 34.6028 38.553 37.2833L39.8002 38.1167ZM25 1.97253L23.9393 3.03319L32.8393 11.9332L33.9 10.8725L34.9607 9.81187L26.0607 0.911874L25 1.97253ZM33.9 10.8725L32.8393 9.81187L23.9393 18.7119L25 19.7725L26.0607 20.8332L34.9607 11.9332L33.9 10.8725Z\\\" fill=\\\"hsla(215, 100%, 5%, 1)\\\"/>\\r\\n</svg>\\r\\n\"","import { useState, useEffect, useRef, useCallback } from \"preact/hooks\";\r\nimport \"./globals.css\";\r\nimport { render } from \"preact\";\r\nimport { ChatButton } from \"./components/ChatButton\";\r\nimport {\r\n ChatWindow,\r\n type ChatWindowHandle,\r\n} from \"./components/ChatWindow\";\r\nimport { COLORS } from \"./styles/constants\";\r\n\r\nexport type BulutVoice = \"alloy\" | \"zeynep\" | \"ali\";\r\n\r\nexport interface BulutOptions {\r\n containerId?: string;\r\n backendBaseUrl?: string;\r\n projectId?: string;\r\n}\r\n\r\nexport interface BulutRuntimeConfig {\r\n backendBaseUrl: string;\r\n projectId: string;\r\n model: string;\r\n voice: BulutVoice;\r\n baseColor: string;\r\n agentName: string;\r\n}\r\n\r\n/** Default LLM model — keep in sync with backend config.DEFAULT_LLM_MODEL */\r\nconst DEFAULT_LLM_MODEL = \"x-ai/grok-4.1-fast\";\r\n\r\nconst DEFAULT_AGENT_NAME = \"Bulut\";\r\n\r\nconst DEFAULT_CONFIG: BulutRuntimeConfig = {\r\n backendBaseUrl: \"https://api.bulut.lu\",\r\n projectId: \"\", // Must be provided\r\n model: DEFAULT_LLM_MODEL,\r\n voice: \"alloy\",\r\n baseColor: COLORS.primary,\r\n agentName: DEFAULT_AGENT_NAME,\r\n};\r\n\r\nconst isValidHexColor = (value: string): boolean =>\r\n /^#([0-9a-fA-F]{3}|[0-9a-fA-F]{6})$/.test(value);\r\n\r\nconst normalizeHexColor = (value: string): string => {\r\n const trimmed = value.trim();\r\n if (!isValidHexColor(trimmed)) {\r\n return DEFAULT_CONFIG.baseColor;\r\n }\r\n if (trimmed.length === 4) {\r\n const r = trimmed[1];\r\n const g = trimmed[2];\r\n const b = trimmed[3];\r\n return `#${r}${r}${g}${g}${b}${b}`.toLowerCase();\r\n }\r\n return trimmed.toLowerCase();\r\n};\r\n\r\nconst shadeHexColor = (hexColor: string, amount: number): string => {\r\n const normalized = normalizeHexColor(hexColor);\r\n const raw = normalized.slice(1);\r\n const toChannel = (start: number): number => parseInt(raw.slice(start, start + 2), 16);\r\n const clamp = (value: number): number => Math.max(0, Math.min(255, Math.round(value)));\r\n const adjust = (channel: number): number =>\r\n amount < 0 ? channel * (1 + amount) : channel + (255 - channel) * amount;\r\n const toHex = (channel: number): string => clamp(channel).toString(16).padStart(2, \"0\");\r\n\r\n const r = adjust(toChannel(0));\r\n const g = adjust(toChannel(2));\r\n const b = adjust(toChannel(4));\r\n\r\n return `#${toHex(r)}${toHex(g)}${toHex(b)}`;\r\n};\r\n\r\nconst applyTheme = (baseColor: string): void => {\r\n const normalized = normalizeHexColor(baseColor);\r\n COLORS.primary = normalized;\r\n COLORS.primaryHover = shadeHexColor(normalized, -0.15);\r\n COLORS.messageUser = normalized;\r\n};\r\n\r\ninterface RemoteProjectConfig {\r\n base_color: string;\r\n model: string;\r\n agent_name: string;\r\n voice: string;\r\n}\r\n\r\nconst fetchRemoteConfig = async (\r\n baseUrl: string,\r\n projectId: string,\r\n): Promise<RemoteProjectConfig | null> => {\r\n try {\r\n const url = baseUrl.replace(/\\/+$/, \"\");\r\n const res = await fetch(`${url}/projects/${projectId}/config`);\r\n if (!res.ok) return null;\r\n return (await res.json()) as RemoteProjectConfig;\r\n } catch {\r\n return null;\r\n }\r\n};\r\n\r\nconst resolveRuntimeConfig = (\r\n options: BulutOptions,\r\n): BulutRuntimeConfig => ({\r\n backendBaseUrl: options.backendBaseUrl || DEFAULT_CONFIG.backendBaseUrl,\r\n projectId: options.projectId || DEFAULT_CONFIG.projectId,\r\n model: DEFAULT_CONFIG.model,\r\n voice: DEFAULT_CONFIG.voice,\r\n baseColor: DEFAULT_CONFIG.baseColor,\r\n agentName: DEFAULT_CONFIG.agentName,\r\n});\r\n\r\ninterface BulutWidgetProps {\r\n config: BulutRuntimeConfig;\r\n}\r\n\r\nconst ACCESSIBILITY_MODE_KEY = \"bulut_accessibility_mode_enabled\";\r\nconst GEIST_FONT_FAMILY = \"Geist\";\r\nconst GEIST_STYLESHEET_ID = \"bulut-geist-font-stylesheet\";\r\nconst GEIST_STYLESHEET_URL =\r\n \"https://fonts.googleapis.com/css2?family=Geist:wght@100..900&display=swap\";\r\n\r\nconst ensureGeistStylesheet = (): void => {\r\n if (typeof document === \"undefined\") {\r\n return;\r\n }\r\n if (document.getElementById(GEIST_STYLESHEET_ID)) {\r\n return;\r\n }\r\n const link = document.createElement(\"link\");\r\n link.id = GEIST_STYLESHEET_ID;\r\n link.rel = \"stylesheet\";\r\n link.href = GEIST_STYLESHEET_URL;\r\n document.head.appendChild(link);\r\n};\r\n\r\nconst BulutWidget = ({ config }: BulutWidgetProps) => {\r\n // Live config that merges remote settings over initial config\r\n const [liveConfig, setLiveConfig] = useState<BulutRuntimeConfig>(config);\r\n const [configReady, setConfigReady] = useState(false);\r\n\r\n // Fetch remote project config on mount — widget stays hidden until done\r\n useEffect(() => {\r\n if (!config.projectId) {\r\n setConfigReady(true);\r\n return;\r\n }\r\n let cancelled = false;\r\n\r\n fetchRemoteConfig(config.backendBaseUrl, config.projectId).then((remote) => {\r\n if (cancelled) return;\r\n if (remote) {\r\n const merged: BulutRuntimeConfig = {\r\n ...config,\r\n baseColor: normalizeHexColor(remote.base_color || config.baseColor),\r\n model: remote.model || config.model,\r\n agentName: remote.agent_name || config.agentName,\r\n voice: (\r\n remote.voice === \"alloy\" || remote.voice === \"zeynep\" || remote.voice === \"ali\"\r\n ? remote.voice\r\n : config.voice\r\n ) as BulutVoice,\r\n };\r\n applyTheme(merged.baseColor);\r\n setLiveConfig(merged);\r\n }\r\n setConfigReady(true);\r\n });\r\n\r\n return () => { cancelled = true; };\r\n }, [config]);\r\n\r\n // Check localStorage for persisted state\r\n const [isOpen, setIsOpen] = useState(() => {\r\n if (typeof localStorage !== \"undefined\") {\r\n return localStorage.getItem(\"bulut_panel_open\") === \"true\";\r\n }\r\n return false;\r\n });\r\n\r\n const [showBubble, setShowBubble] = useState(false);\r\n const [isAccessibilityEnabled, setIsAccessibilityEnabled] = useState(() => {\r\n if (typeof localStorage === \"undefined\") {\r\n return false;\r\n }\r\n return localStorage.getItem(ACCESSIBILITY_MODE_KEY) === \"true\";\r\n });\r\n\r\n // State reported by ChatWindow\r\n const [isRecording, setIsRecording] = useState(false);\r\n const [isBusy, setIsBusy] = useState(false);\r\n const [previewMessage, setPreviewMessage] = useState<string | null>(null);\r\n const [previewDismissed, setPreviewDismissed] = useState(false);\r\n\r\n // Ref for delegating recording to ChatWindow\r\n const chatActionsRef = useRef<ChatWindowHandle | null>(null);\r\n\r\n const handlePreviewChange = useCallback((text: string | null) => {\r\n setPreviewMessage(text);\r\n if (text !== null) setPreviewDismissed(false);\r\n }, []);\r\n\r\n // Show welcome bubble once for 5 seconds\r\n useEffect(() => {\r\n if (isAccessibilityEnabled) {\r\n setShowBubble(false);\r\n return;\r\n }\r\n if (isOpen) return;\r\n if (typeof localStorage !== \"undefined\") {\r\n if (localStorage.getItem(\"bulut_bubble_shown\") === \"true\") return;\r\n }\r\n\r\n setShowBubble(true);\r\n const timer = setTimeout(() => {\r\n setShowBubble(false);\r\n if (typeof localStorage !== \"undefined\") {\r\n localStorage.setItem(\"bulut_bubble_shown\", \"true\");\r\n }\r\n }, 5000);\r\n return () => clearTimeout(timer);\r\n }, [isOpen, isAccessibilityEnabled]);\r\n\r\n const toggleWidget = () => {\r\n const newState = !isOpen;\r\n setIsOpen(newState);\r\n setShowBubble(false);\r\n if (typeof localStorage !== \"undefined\") {\r\n localStorage.setItem(\"bulut_panel_open\", String(newState));\r\n }\r\n };\r\n\r\n const toggleAccessibilityMode = () => {\r\n const next = !isAccessibilityEnabled;\r\n setIsAccessibilityEnabled(next);\r\n if (typeof localStorage !== \"undefined\") {\r\n localStorage.setItem(ACCESSIBILITY_MODE_KEY, String(next));\r\n }\r\n console.info(`[Bulut] accessibility mode toggled enabled=${next}`);\r\n };\r\n\r\n const handleClose = () => {\r\n setIsOpen(false);\r\n if (typeof localStorage !== \"undefined\") {\r\n localStorage.setItem(\"bulut_panel_open\", \"false\");\r\n }\r\n console.info(\"Bulut chat window closed.\");\r\n };\r\n\r\n // Close on escape key\r\n useEffect(() => {\r\n const handleEscape = (e: KeyboardEvent) => {\r\n if (e.key === \"Escape\" && isOpen) {\r\n setIsOpen(false);\r\n if (typeof localStorage !== \"undefined\") {\r\n localStorage.setItem(\"bulut_panel_open\", \"false\");\r\n }\r\n }\r\n };\r\n\r\n document.addEventListener(\"keydown\", handleEscape);\r\n return () => document.removeEventListener(\"keydown\", handleEscape);\r\n }, [isOpen]);\r\n\r\n if (!configReady) return null;\r\n\r\n return (\r\n <>\r\n {!isOpen && (\r\n <ChatButton\r\n onMicClick={() => chatActionsRef.current?.startRecording()}\r\n onCancelRecording={() => chatActionsRef.current?.cancelRecording()}\r\n onStopTask={() => chatActionsRef.current?.stopTask()}\r\n isRecording={isRecording}\r\n isBusy={isBusy}\r\n showBubble={showBubble}\r\n onBubbleClick={() => {\r\n setShowBubble(false);\r\n toggleWidget();\r\n }}\r\n previewMessage={previewDismissed ? null : previewMessage}\r\n onPreviewClick={() => toggleWidget()}\r\n onPreviewClose={() => setPreviewDismissed(true)}\r\n />\r\n )}\r\n <ChatWindow\r\n onClose={handleClose}\r\n config={liveConfig}\r\n accessibilityMode={isAccessibilityEnabled}\r\n onAccessibilityToggle={toggleAccessibilityMode}\r\n hidden={!isOpen}\r\n actionsRef={chatActionsRef}\r\n onRecordingChange={setIsRecording}\r\n onBusyChange={setIsBusy}\r\n onPreviewChange={handlePreviewChange}\r\n />\r\n </>\r\n );\r\n};\r\n\r\nconst SHADOW_STYLE = `\r\n :host {\r\n all: initial;\r\n contain: layout style paint;\r\n font-family: \"${GEIST_FONT_FAMILY}\", sans-serif;\r\n color: hsla(215, 100%, 5%, 1);\r\n font-size: 16px;\r\n line-height: 1.4;\r\n -webkit-font-smoothing: antialiased;\r\n text-rendering: optimizeLegibility;\r\n }\r\n\r\n #bulut-shadow-mount {\r\n all: initial;\r\n color: inherit;\r\n font-family: \"${GEIST_FONT_FAMILY}\", sans-serif;\r\n font-size: inherit;\r\n line-height: inherit;\r\n }\r\n\r\n #bulut-shadow-mount * {\r\n font-family: \"${GEIST_FONT_FAMILY}\", sans-serif !important;\r\n color: inherit;\r\n }\r\n\r\n #bulut-shadow-mount *, #bulut-shadow-mount *::before, #bulut-shadow-mount *::after {\r\n box-sizing: border-box;\r\n }\r\n`;\r\n\r\n// Container host for the widget\r\nlet widgetContainer: HTMLElement | null = null;\r\nlet widgetMountNode: HTMLElement | null = null;\r\nlet createdContainer = false;\r\nlet isInitialized = false;\r\n\r\n/**\r\n * Initialize the Bulut chat widget\r\n * @param options - Optional configuration options\r\n */\r\nexport const init = (options: BulutOptions = {}) => {\r\n if (isInitialized) {\r\n console.warn(\"Bulut is already initialized\");\r\n return;\r\n }\r\n\r\n ensureGeistStylesheet();\r\n\r\n const runtimeConfig = resolveRuntimeConfig(options);\r\n applyTheme(runtimeConfig.baseColor);\r\n\r\n // Create or find container\r\n if (options.containerId) {\r\n widgetContainer = document.getElementById(options.containerId);\r\n createdContainer = false;\r\n } else {\r\n widgetContainer = document.createElement(\"div\");\r\n widgetContainer.id = \"bulut-container\";\r\n document.body.appendChild(widgetContainer);\r\n createdContainer = true;\r\n }\r\n\r\n if (!widgetContainer) {\r\n console.error(\"Bulut: Container not found\");\r\n return;\r\n }\r\n\r\n const shadowRoot = widgetContainer.shadowRoot || widgetContainer.attachShadow({ mode: \"open\" });\r\n shadowRoot.replaceChildren();\r\n\r\n const style = document.createElement(\"style\");\r\n style.textContent = SHADOW_STYLE;\r\n\r\n const mountNode = document.createElement(\"div\");\r\n mountNode.id = \"bulut-shadow-mount\";\r\n\r\n shadowRoot.append(style, mountNode);\r\n widgetMountNode = mountNode;\r\n\r\n // Render the widget\r\n render(<BulutWidget config={runtimeConfig} />, mountNode);\r\n isInitialized = true;\r\n\r\n console.log(\"Bulut initialized successfully\");\r\n};\r\n\r\n/**\r\n * Destroy the Bulut widget\r\n */\r\nexport const destroy = () => {\r\n if (!isInitialized) {\r\n return;\r\n }\r\n\r\n if (widgetMountNode) {\r\n render(null, widgetMountNode);\r\n widgetMountNode = null;\r\n }\r\n\r\n if (widgetContainer && createdContainer) {\r\n document.body.removeChild(widgetContainer);\r\n }\r\n\r\n widgetContainer = null;\r\n createdContainer = false;\r\n isInitialized = false;\r\n console.log(\"Bulut destroyed\");\r\n};\r\n\r\n/**\r\n * Check if the widget is initialized\r\n */\r\nexport const isReady = () => isInitialized;\r\n\r\nconst Bulut = {\r\n init,\r\n destroy,\r\n isReady,\r\n};\r\n\r\nif (typeof window !== \"undefined\") {\r\n (window as Window & { Bulut?: typeof Bulut }).Bulut = Bulut;\r\n}\r\n\r\n// Export the main widget component for advanced usage\r\nexport { BulutWidget };\r\n\r\n// Export components for custom implementations\r\nexport { ChatButton, ChatWindow };\r\n\r\nexport default Bulut;\r\n"],"names":["n","l","u","i","o","r","e","f","c","s","a","p","v","y","d","Array","isArray","w","g","parentNode","removeChild","m","t","type","props","key","ref","__k","__","__b","__e","__c","constructor","__v","__i","__u","vnode","k","children","x","this","context","S","length","C","base","M","__d","push","$","__r","debounceRendering","sort","shift","__P","O","__n","namespaceURI","N","I","h","_","b","String","L","D","P","B","A","nextSibling","insertBefore","nodeType","T","setProperty","test","j","style","cssText","replace","toLowerCase","slice","addEventListener","removeEventListener","removeAttribute","setAttribute","F","event","H","prototype","render","contextType","value","__E","E","sub","state","__h","_sb","__s","getDerivedStateFromProps","componentWillMount","componentDidMount","componentWillReceiveProps","shouldComponentUpdate","some","componentWillUpdate","componentDidUpdate","getChildContext","getSnapshotBeforeUpdate","V","then","indexOf","z","localName","document","createTextNode","createElementNS","is","__m","data","call","childNodes","attributes","name","__html","innerHTML","content","q","diffed","forEach","map","current","unmount","componentWillUnmount","G","documentElement","arguments","defaultProps","firstChild","getDerivedStateFromError","setState","componentDidCatch","forceUpdate","Promise","bind","resolve","setTimeout","__source","__self","__H","__N","__f","filter","every","requestAnimationFrame","clearTimeout","cancelAnimationFrame","COLORS","primary","primaryHover","text","messageUser","messageUserText","getContrastIconFilter","backgroundHex","hex","trimmed","trim","normalizeHexColor","parseInt","BORDER_RADIUS","SHADOW","TRANSITIONS","microphoneIconContent","closeIconContent","stopIconContent","SvgIcon","src","width","height","title","stripColors","className","fill","stroke","strokeWidth","viewBox","useMemo","trimmedSrc","viewBoxMatch","match","jsx","display","verticalAlign","flexShrink","xmlns","dangerouslySetInnerHTML","nextContent","strokeWidthValue","ChatButton","onMicClick","onCancelRecording","onStopTask","isRecording","isBusy","showBubble","onBubbleClick","previewMessage","onPreviewClick","onPreviewClose","bgColor","containerStyle","position","right","bottom","flexDirection","alignItems","gap","zIndex","fontFamily","buttonStyle","minWidth","minHeight","borderRadius","backgroundColor","color","border","cursor","justifyContent","transition","iconStyle","showStopButton","closeBtnStyle","top","background","fontSize","lineHeight","padding","renderPopup","onClick","onClose","extraClass","scrollable","jsxs","stopPropagation","paddingRight","wordBreak","maxHeight","overflowY","Fragment","onMouseEnter","Object","assign","currentTarget","transform","onMouseLeave","PAGE_CONTEXT_CACHE_KEY","NON_CONTENT_TAGS","Set","NATIVE_INTERACTIVE_TAGS","INTERACTIVE_ROLES","TRACKED_DISPLAY_VALUES","TRACKED_POSITION_VALUES","EVENT_HINT_NAMES","ARIA_INTERACTION_ATTRS","DATA_INTERACTION_PATTERN","pageContextCache","Map","cacheHydrated","normalizeWhitespace","truncate","maxChars","suffix","Math","max","truncateInline","isCacheEntry","obj","url","summary","links","interactables","capturedAt","version","bumpCount","set","get","formatTopCounts","maxItems","size","from","entries","localeCompare","count","join","parseTabIndex","parsed","Number","isNaN","compactToken","compact","getElementDepth","element","depth","parentElement","body","getPrimaryRole","getAttribute","split","buildSummaryWithHistory","recentPages","values","entry","historySection","compactSummary","isVisible","HTMLElement","hidden","window","getComputedStyle","visibility","rect","getBoundingClientRect","toAbsoluteUrl","href","URL","location","escapeCssValue","CSS","escape","buildSelector","tag","tagName","id","ariaLabel","classes","classList","Boolean","parent","sibling","getElementLabel","innerText","textContent","placeholder","HTMLInputElement","HTMLTextAreaElement","HTMLButtonElement","classHint","item","find","fallback","label","getEventHints","record","eventHints","eventName","handlerKey","hasInlineHandler","hasPropertyHandler","getAriaInteractionHints","attrName","hasAttribute","getDataInteractionHints","getAttributeNames","startsWith","getStyleHints","styleHints","buildBranchDigest","token","idToken","classToken","buildBlueprintToken","child","has","sampled","overflow","formatSection","lines","buildOuterHtmlDigest","structural","_a","outerHTML","collectTextSnippets","root","querySelector","snippets","seen","candidates","querySelectorAll","node","add","collectPageSignalSnapshot","allElements","sampledElements","linkSet","interactableCandidates","tagCounts","roleCounts","eventCounts","displayCounts","positionCounts","visibleElements","maxDepth","semanticInteractables","nonSemanticInteractables","tabStopElements","pointerCursorElements","dataHintElements","ariaHintElements","contentEditableElements","order","role","tabIndex","hasTabStop","hasPointerCursor","dataHints","ariaHints","isContentEditable","isNativeInteractive","isRoleInteractive","isDisabled","absoluteHref","line","selector","signalTokens","signalBlock","score","existing","candidate","interactiveRoleCounts","interactionSignals","branchDigest","collectDomBranchDigest","pageBlueprint","getPageContext","sessionStorage","raw","getItem","JSON","parse","console","info","error","warn","hydrateCacheFromStorage","rawUrl","canonicalUrl","cached","snapshot","headings","input","sections","lang","landmarks","textSnippets","outerHtmlDigest","buildPageContextSummary","Date","now","sorted","delete","pruneOldestCacheEntries","serialized","stringify","setItem","persistCacheToStorage","AGENT_CURSOR_ID","CURSOR_STORAGE_KEY","CURSOR_MOVE_DURATION_MS","CURSOR_EASING","RESUME_STORAGE_KEY","savePendingAgentResume","localStorage","savedAt","clearPendingAgentResume","removeItem","clamp","min","animateWindowScrollTo","async","targetY","durationMs","startY","scrollY","delta","abs","raf","callback","performance","startTime","step","progress","eased","cos","PI","easeInOutSine","scrollTo","getPersistedCursorState","isFinite","visible","persistCursorState","payload","setCursorPosition","left","setCursorVisibility","opacity","cursorHoverTrackingInitialized","initializeCursorHoverTracking","getElementById","parseFloat","getCursorPosition","pointerX","pageX","pointerY","pageY","hypot","ensureCursor","createElement","baseColor","boxShadow","boxSizing","pointerEvents","appendChild","stored","applyStoredCursorStateForCurrentUrl","moveCursor","getElementCenter","scrollX","CONTAINS_SELECTOR_PATTERN","findElementBySelector","containsMatch","baseSelector","expectedText","_b","_c","includes","fallbackError","dispatchMouseEvent","dispatchEvent","MouseEvent","bubbles","cancelable","view","clientX","clientY","slowScrollElementIntoView","slowScrollElementIntoViewWithMode","forceCenter","viewportHeight","innerHeight","isRectOutsideViewport","maxScrollTop","scrollHeight","currentScrollY","rectTop","rectHeight","computeCenteredScrollTop","executeInteract","target","selected","center","resolveTarget","action","click","requestSubmit","form","parentForm","closest","submitElement","toUpperCase","focus","Event","typeIntoElement","executeNavigate","targetUrl","resolvedUrl","matchingElement","parsedTarget","allLinks","el","HTMLAnchorElement","elUrl","pathname","search","hash","urlSegments","lastSegment","searchTerms","searchParams","clickables","dataTab","term","findMatchingLinkForTarget","log","origin","isSamePageNavigation","newPath","history","pushState","PopStateEvent","executeSingleToolCall","callId","call_id","tool","result","executeScroll","msg","Error","message","restoreCursorFromStorageForCurrentUrl","readyState","once","TTS_WS_RETRY_DELAYS_MS","normalizeBaseUrl","baseUrl","toWebSocketUrl","path","normalized","protocol","toString","shouldFallbackToSse","retryable","parseErrorBody","response","json","detail","statusText","sleep","ms","base64ToUint8Array","base64","cleanBase64","binaryString","atob","bytes","Uint8Array","charCodeAt","playBufferedAudio","chunks","mimeType","sampleRate","onAudioStateChange","totalBytes","reduce","acc","byteLength","blobParts","chunk","copied","buffer","detectedMime","header","padStart","safeMimeType","finalBlobParts","ArrayBuffer","DataView","setUint32","setUint16","channels","createWavHeader","blob","Blob","audioElement","Audio","objectUrl","createObjectURL","preload","autoplay","play","ended","reject","watchdog","setInterval","onEnded","cleanup","onError","clearInterval","waitForPlaybackEnd","err","pause","load","revokeObjectURL","parseSseEventPayload","eventBlock","dataLines","trimStart","dataStr","isAudioSsePayload","audio","startSttWebSocketStream","config","events","wsUrl","socket","WebSocket","seq","finalText","finalSessionId","sessionId","stopped","settled","sendQueue","resolveStart","rejectStart","startPromise","resolveDone","rejectDone","donePromise","rejectAll","resolveDoneIfPossible","session_id","onopen","onRequestSent","send","project_id","projectId","language","mime_type","onmessage","parseSttWsEventPayload","onSessionId","close","buildError","onPartial","onerror","ev","onclose","code","reason","pushChunk","arrayBuffer","binary","fromCharCode","subarray","btoa","blobToBase64","OPEN","debug","stop","cancel","collectTtsViaSse","assistantText","voice","accessibilityMode","isStopped","setReader","ttsFormData","FormData","append","ttsResponse","fetch","method","ok","reader","getReader","decoder","TextDecoder","done","read","decode","stream","blocks","pop","block","format","sample_rate","releaseLock","collectTtsViaWebSocket","setSocket","requestId","crypto","randomUUID","random","highestSeqSeen","connectOnce","finalError","finalize","mode","request_id","accessibility_mode","last_seq","parseTtsWsEventPayload","incomingSeq","shouldAcceptAudioSeq","attempt","delay","speakText","ttsResult","neverStopped","agentVoiceChatStream","audioFile","executeTool","activeReader","activeSocket","errorEmitted","sttResult","file","formData","responsePromise","transcribeAudio","onSttRequestSent","currentSessionId","effectiveSessionId","userText","onTranscription","user_text","agentResolve","agentReject","finalReply","resolved","accumulatedDelta","finish","reply","fail","model","page_context","pageContext","msgType","onAssistantDelta","calls","_d","onIntermediateReply","_e","onToolCalls","results","isNavigate","pendingToolCalls","args","completedResults","_f","onToolResult","final_reply","_g","onAssistantDone","_h","errMsg","_i","onIteration","iteration","max_iterations","wsError","catch","SFX_SOURCES","sent","thinking","toolCall","completed","sfxManager","__publicField","playNow","onended","drain","active","queue","next","playCue","STORAGE_KEY","TIMESTAMP_KEY","SESSION_ID_KEY","TTL_MS","STATUS_LABELS","getGreetingText","agentName","resolveStatusText","flags","isRunningTools","isPlayingAudio","isThinking","isTranscribing","formatDurationMs","totalSeconds","floor","createInitialMessages","isUser","clearPersistedChatState","storage","getNextMessageId","messages","shouldAutoListenAfterAudio","ChatWindow","onAccessibilityToggle","actionsRef","onRecordingChange","onBusyChange","onPreviewChange","setMessages","useState","saved","timestamp","setIsBusy","setIsRecording","setIsTranscribing","setIsThinking","isRenderingAudio","setIsRenderingAudio","setIsPlayingAudio","setIsRunningTools","recordingDurationMs","setRecordingDurationMs","statusOverride","setStatusOverride","resolvedStatusText","isBusyRef","useRef","isRecordingRef","nextMessageIdRef","recorderRef","streamRef","audioChunksRef","activeStreamControllerRef","sessionIdRef","ts","silenceStartRef","vadIntervalRef","audioContextRef","sourceRef","discardNextRecordingRef","micPressStartRef","micHoldTimeoutRef","micHoldTriggeredRef","recordingModeRef","pendingStopAfterStartRef","startRecordingPendingRef","assistantMessageIdRef","assistantTextBufferRef","transcriptionReceivedRef","assistantDoneReceivedRef","recordingStartedAtRef","recordingTimerIntervalRef","messagesContainerRef","messagesContentRef","pendingUserTextRef","pendingAssistantTextRef","streamingJsonParserRef","awaitingAssistantResponseRef","activeSttWsRef","liveTranscriptionMessageIdRef","liveTranscriptionTextRef","autoListenSuppressedRef","useEffect","lastAssistant","reverse","st","playSfx","scrollMessagesToBottom","scrollTop","ResizeObserver","observer","observe","disconnect","stopRecordingTimer","resetProcessingFlags","clearMicHoldTimeout","cleanupVAD","stopStreamTracks","getTracks","track","stopActiveStream","cancelActiveSttWs","activeSttWs","recorder","ondataavailable","onstop","resumeState","getPendingAgentResume","freshPageContext","controller","allResults","tc","pending_tool_calls","tool_results","agentResumeStream","backendBaseUrl","sid","appendMessage","updateMessageText","finalDisplayText","handleAudioStateChange","toolLabel","prev","last","finally","startRecording","previous","upsertLiveUserTranscription","clearLiveUserTranscriptionState","finalizeStreamCycle","runAgentForUserText","normalizedUserText","handleToolExecution","agentTextChatStream","stopRecording","options","discard","navigator","mediaDevices","getUserMedia","MediaRecorder","recorderOptions","audioBitsPerSecond","preferredMimeTypes","mime","isTypeSupported","sttMimeType","sttWsController","shouldDiscard","currentSttWs","fileType","extension","File","previousUserText","_callId","_toolName","_result","_iteration","_maxIterations","handleAudioBlob","AudioCtx","AudioContext","webkitAudioContext","analyser","createAnalyser","fftSize","source","createMediaStreamSource","connect","dataArray","frequencyBinCount","speechDetected","getByteFrequencyData","sum","silenceDuration","setupVAD","start","startedAt","normalizeError","resetMicGesture","handleMicPointerUp","preventDefault","releasePointerCapture","pointerId","wasHold","thresholdMs","classifyMicGesture","timer","stopTask","cancelRecording","windowStyle","animation","headerButtonStyle","statusPanelStyle","flex","whiteSpace","textOverflow","recordingTimerStyle","fontWeight","textAlign","micFooterButtonStyle","isVadRecording","disableMicControl","maxWidth","initialMessages","alignSelf","wordWrap","onPointerDown","setPointerCapture","onPointerUp","onPointerCancel","disabled","DEFAULT_CONFIG","isValidHexColor","shadeHexColor","hexColor","amount","toChannel","adjust","channel","toHex","round","applyTheme","ACCESSIBILITY_MODE_KEY","GEIST_FONT_FAMILY","GEIST_STYLESHEET_ID","BulutWidget","liveConfig","setLiveConfig","configReady","setConfigReady","cancelled","res","fetchRemoteConfig","remote","merged","base_color","agent_name","isOpen","setIsOpen","setShowBubble","isAccessibilityEnabled","setIsAccessibilityEnabled","setPreviewMessage","previewDismissed","setPreviewDismissed","chatActionsRef","handlePreviewChange","toggleWidget","newState","handleEscape","SHADOW_STYLE","widgetContainer","widgetMountNode","createdContainer","isInitialized","init","link","rel","head","ensureGeistStylesheet","runtimeConfig","resolveRuntimeConfig","containerId","shadowRoot","attachShadow","replaceChildren","mountNode","destroy","isReady","Bulut"],"mappings":"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","x_google_ignoreList":[0,1,2]}
1
+ {"version":3,"file":"embed.cjs","sources":["../node_modules/preact/dist/preact.module.js","../node_modules/preact/jsx-runtime/dist/jsxRuntime.module.js","../node_modules/preact/hooks/dist/hooks.module.js","../src/styles/constants.ts","../src/assets.ts","../src/assets/icons/microphone.svg?raw","../src/assets/icons/close.svg?raw","../src/assets/icons/stop.svg?raw","../src/components/SvgIcon.tsx","../src/components/ChatButton.tsx","../src/agent/context.ts","../src/agent/contextConfig.ts","../src/agent/tools.ts","../src/api/client.ts","../src/audio/sfxManager.ts","../src/assets/sfx/sent.mp3","../src/assets/sfx/thinking.mp3","../src/assets/sfx/tool_call.mp3","../src/assets/sfx/completed.mp3","../src/components/ChatWindow.tsx","../src/assets/icons/bulut_logo.svg?raw","../src/assets/icons/restart.svg?raw","../src/index.tsx"],"sourcesContent":["var n,l,u,t,i,o,r,e,f,c,s,a,h,p={},v=[],y=/acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i,d=Array.isArray;function w(n,l){for(var u in l)n[u]=l[u];return n}function g(n){n&&n.parentNode&&n.parentNode.removeChild(n)}function _(l,u,t){var i,o,r,e={};for(r in u)\"key\"==r?i=u[r]:\"ref\"==r?o=u[r]:e[r]=u[r];if(arguments.length>2&&(e.children=arguments.length>3?n.call(arguments,2):t),\"function\"==typeof l&&null!=l.defaultProps)for(r in l.defaultProps)void 0===e[r]&&(e[r]=l.defaultProps[r]);return m(l,e,i,o,null)}function m(n,t,i,o,r){var e={type:n,props:t,key:i,ref:o,__k:null,__:null,__b:0,__e:null,__c:null,constructor:void 0,__v:null==r?++u:r,__i:-1,__u:0};return null==r&&null!=l.vnode&&l.vnode(e),e}function b(){return{current:null}}function k(n){return n.children}function x(n,l){this.props=n,this.context=l}function S(n,l){if(null==l)return n.__?S(n.__,n.__i+1):null;for(var u;l<n.__k.length;l++)if(null!=(u=n.__k[l])&&null!=u.__e)return u.__e;return\"function\"==typeof n.type?S(n):null}function C(n){var l,u;if(null!=(n=n.__)&&null!=n.__c){for(n.__e=n.__c.base=null,l=0;l<n.__k.length;l++)if(null!=(u=n.__k[l])&&null!=u.__e){n.__e=n.__c.base=u.__e;break}return C(n)}}function M(n){(!n.__d&&(n.__d=!0)&&i.push(n)&&!$.__r++||o!=l.debounceRendering)&&((o=l.debounceRendering)||r)($)}function $(){for(var n,u,t,o,r,f,c,s=1;i.length;)i.length>s&&i.sort(e),n=i.shift(),s=i.length,n.__d&&(t=void 0,o=void 0,r=(o=(u=n).__v).__e,f=[],c=[],u.__P&&((t=w({},o)).__v=o.__v+1,l.vnode&&l.vnode(t),O(u.__P,t,o,u.__n,u.__P.namespaceURI,32&o.__u?[r]:null,f,null==r?S(o):r,!!(32&o.__u),c),t.__v=o.__v,t.__.__k[t.__i]=t,N(f,t,c),o.__e=o.__=null,t.__e!=r&&C(t)));$.__r=0}function I(n,l,u,t,i,o,r,e,f,c,s){var a,h,y,d,w,g,_,m=t&&t.__k||v,b=l.length;for(f=P(u,l,m,f,b),a=0;a<b;a++)null!=(y=u.__k[a])&&(h=-1==y.__i?p:m[y.__i]||p,y.__i=a,g=O(n,y,h,i,o,r,e,f,c,s),d=y.__e,y.ref&&h.ref!=y.ref&&(h.ref&&B(h.ref,null,y),s.push(y.ref,y.__c||d,y)),null==w&&null!=d&&(w=d),(_=!!(4&y.__u))||h.__k===y.__k?f=A(y,f,n,_):\"function\"==typeof y.type&&void 0!==g?f=g:d&&(f=d.nextSibling),y.__u&=-7);return u.__e=w,f}function P(n,l,u,t,i){var o,r,e,f,c,s=u.length,a=s,h=0;for(n.__k=new Array(i),o=0;o<i;o++)null!=(r=l[o])&&\"boolean\"!=typeof r&&\"function\"!=typeof r?(\"string\"==typeof r||\"number\"==typeof r||\"bigint\"==typeof r||r.constructor==String?r=n.__k[o]=m(null,r,null,null,null):d(r)?r=n.__k[o]=m(k,{children:r},null,null,null):void 0===r.constructor&&r.__b>0?r=n.__k[o]=m(r.type,r.props,r.key,r.ref?r.ref:null,r.__v):n.__k[o]=r,f=o+h,r.__=n,r.__b=n.__b+1,e=null,-1!=(c=r.__i=L(r,u,f,a))&&(a--,(e=u[c])&&(e.__u|=2)),null==e||null==e.__v?(-1==c&&(i>s?h--:i<s&&h++),\"function\"!=typeof r.type&&(r.__u|=4)):c!=f&&(c==f-1?h--:c==f+1?h++:(c>f?h--:h++,r.__u|=4))):n.__k[o]=null;if(a)for(o=0;o<s;o++)null!=(e=u[o])&&0==(2&e.__u)&&(e.__e==t&&(t=S(e)),D(e,e));return t}function A(n,l,u,t){var i,o;if(\"function\"==typeof n.type){for(i=n.__k,o=0;i&&o<i.length;o++)i[o]&&(i[o].__=n,l=A(i[o],l,u,t));return l}n.__e!=l&&(t&&(l&&n.type&&!l.parentNode&&(l=S(n)),u.insertBefore(n.__e,l||null)),l=n.__e);do{l=l&&l.nextSibling}while(null!=l&&8==l.nodeType);return l}function H(n,l){return l=l||[],null==n||\"boolean\"==typeof n||(d(n)?n.some(function(n){H(n,l)}):l.push(n)),l}function L(n,l,u,t){var i,o,r,e=n.key,f=n.type,c=l[u],s=null!=c&&0==(2&c.__u);if(null===c&&null==e||s&&e==c.key&&f==c.type)return u;if(t>(s?1:0))for(i=u-1,o=u+1;i>=0||o<l.length;)if(null!=(c=l[r=i>=0?i--:o++])&&0==(2&c.__u)&&e==c.key&&f==c.type)return r;return-1}function T(n,l,u){\"-\"==l[0]?n.setProperty(l,null==u?\"\":u):n[l]=null==u?\"\":\"number\"!=typeof u||y.test(l)?u:u+\"px\"}function j(n,l,u,t,i){var o,r;n:if(\"style\"==l)if(\"string\"==typeof u)n.style.cssText=u;else{if(\"string\"==typeof t&&(n.style.cssText=t=\"\"),t)for(l in t)u&&l in u||T(n.style,l,\"\");if(u)for(l in u)t&&u[l]==t[l]||T(n.style,l,u[l])}else if(\"o\"==l[0]&&\"n\"==l[1])o=l!=(l=l.replace(f,\"$1\")),r=l.toLowerCase(),l=r in n||\"onFocusOut\"==l||\"onFocusIn\"==l?r.slice(2):l.slice(2),n.l||(n.l={}),n.l[l+o]=u,u?t?u.u=t.u:(u.u=c,n.addEventListener(l,o?a:s,o)):n.removeEventListener(l,o?a:s,o);else{if(\"http://www.w3.org/2000/svg\"==i)l=l.replace(/xlink(H|:h)/,\"h\").replace(/sName$/,\"s\");else if(\"width\"!=l&&\"height\"!=l&&\"href\"!=l&&\"list\"!=l&&\"form\"!=l&&\"tabIndex\"!=l&&\"download\"!=l&&\"rowSpan\"!=l&&\"colSpan\"!=l&&\"role\"!=l&&\"popover\"!=l&&l in n)try{n[l]=null==u?\"\":u;break n}catch(n){}\"function\"==typeof u||(null==u||!1===u&&\"-\"!=l[4]?n.removeAttribute(l):n.setAttribute(l,\"popover\"==l&&1==u?\"\":u))}}function F(n){return function(u){if(this.l){var t=this.l[u.type+n];if(null==u.t)u.t=c++;else if(u.t<t.u)return;return t(l.event?l.event(u):u)}}}function O(n,u,t,i,o,r,e,f,c,s){var a,h,p,v,y,_,m,b,S,C,M,$,P,A,H,L,T,j=u.type;if(void 0!==u.constructor)return null;128&t.__u&&(c=!!(32&t.__u),r=[f=u.__e=t.__e]),(a=l.__b)&&a(u);n:if(\"function\"==typeof j)try{if(b=u.props,S=\"prototype\"in j&&j.prototype.render,C=(a=j.contextType)&&i[a.__c],M=a?C?C.props.value:a.__:i,t.__c?m=(h=u.__c=t.__c).__=h.__E:(S?u.__c=h=new j(b,M):(u.__c=h=new x(b,M),h.constructor=j,h.render=E),C&&C.sub(h),h.state||(h.state={}),h.__n=i,p=h.__d=!0,h.__h=[],h._sb=[]),S&&null==h.__s&&(h.__s=h.state),S&&null!=j.getDerivedStateFromProps&&(h.__s==h.state&&(h.__s=w({},h.__s)),w(h.__s,j.getDerivedStateFromProps(b,h.__s))),v=h.props,y=h.state,h.__v=u,p)S&&null==j.getDerivedStateFromProps&&null!=h.componentWillMount&&h.componentWillMount(),S&&null!=h.componentDidMount&&h.__h.push(h.componentDidMount);else{if(S&&null==j.getDerivedStateFromProps&&b!==v&&null!=h.componentWillReceiveProps&&h.componentWillReceiveProps(b,M),u.__v==t.__v||!h.__e&&null!=h.shouldComponentUpdate&&!1===h.shouldComponentUpdate(b,h.__s,M)){for(u.__v!=t.__v&&(h.props=b,h.state=h.__s,h.__d=!1),u.__e=t.__e,u.__k=t.__k,u.__k.some(function(n){n&&(n.__=u)}),$=0;$<h._sb.length;$++)h.__h.push(h._sb[$]);h._sb=[],h.__h.length&&e.push(h);break n}null!=h.componentWillUpdate&&h.componentWillUpdate(b,h.__s,M),S&&null!=h.componentDidUpdate&&h.__h.push(function(){h.componentDidUpdate(v,y,_)})}if(h.context=M,h.props=b,h.__P=n,h.__e=!1,P=l.__r,A=0,S){for(h.state=h.__s,h.__d=!1,P&&P(u),a=h.render(h.props,h.state,h.context),H=0;H<h._sb.length;H++)h.__h.push(h._sb[H]);h._sb=[]}else do{h.__d=!1,P&&P(u),a=h.render(h.props,h.state,h.context),h.state=h.__s}while(h.__d&&++A<25);h.state=h.__s,null!=h.getChildContext&&(i=w(w({},i),h.getChildContext())),S&&!p&&null!=h.getSnapshotBeforeUpdate&&(_=h.getSnapshotBeforeUpdate(v,y)),L=a,null!=a&&a.type===k&&null==a.key&&(L=V(a.props.children)),f=I(n,d(L)?L:[L],u,t,i,o,r,e,f,c,s),h.base=u.__e,u.__u&=-161,h.__h.length&&e.push(h),m&&(h.__E=h.__=null)}catch(n){if(u.__v=null,c||null!=r)if(n.then){for(u.__u|=c?160:128;f&&8==f.nodeType&&f.nextSibling;)f=f.nextSibling;r[r.indexOf(f)]=null,u.__e=f}else{for(T=r.length;T--;)g(r[T]);z(u)}else u.__e=t.__e,u.__k=t.__k,n.then||z(u);l.__e(n,u,t)}else null==r&&u.__v==t.__v?(u.__k=t.__k,u.__e=t.__e):f=u.__e=q(t.__e,u,t,i,o,r,e,c,s);return(a=l.diffed)&&a(u),128&u.__u?void 0:f}function z(n){n&&n.__c&&(n.__c.__e=!0),n&&n.__k&&n.__k.forEach(z)}function N(n,u,t){for(var i=0;i<t.length;i++)B(t[i],t[++i],t[++i]);l.__c&&l.__c(u,n),n.some(function(u){try{n=u.__h,u.__h=[],n.some(function(n){n.call(u)})}catch(n){l.__e(n,u.__v)}})}function V(n){return\"object\"!=typeof n||null==n||n.__b&&n.__b>0?n:d(n)?n.map(V):w({},n)}function q(u,t,i,o,r,e,f,c,s){var a,h,v,y,w,_,m,b=i.props||p,k=t.props,x=t.type;if(\"svg\"==x?r=\"http://www.w3.org/2000/svg\":\"math\"==x?r=\"http://www.w3.org/1998/Math/MathML\":r||(r=\"http://www.w3.org/1999/xhtml\"),null!=e)for(a=0;a<e.length;a++)if((w=e[a])&&\"setAttribute\"in w==!!x&&(x?w.localName==x:3==w.nodeType)){u=w,e[a]=null;break}if(null==u){if(null==x)return document.createTextNode(k);u=document.createElementNS(r,x,k.is&&k),c&&(l.__m&&l.__m(t,e),c=!1),e=null}if(null==x)b===k||c&&u.data==k||(u.data=k);else{if(e=e&&n.call(u.childNodes),!c&&null!=e)for(b={},a=0;a<u.attributes.length;a++)b[(w=u.attributes[a]).name]=w.value;for(a in b)if(w=b[a],\"children\"==a);else if(\"dangerouslySetInnerHTML\"==a)v=w;else if(!(a in k)){if(\"value\"==a&&\"defaultValue\"in k||\"checked\"==a&&\"defaultChecked\"in k)continue;j(u,a,null,w,r)}for(a in k)w=k[a],\"children\"==a?y=w:\"dangerouslySetInnerHTML\"==a?h=w:\"value\"==a?_=w:\"checked\"==a?m=w:c&&\"function\"!=typeof w||b[a]===w||j(u,a,w,b[a],r);if(h)c||v&&(h.__html==v.__html||h.__html==u.innerHTML)||(u.innerHTML=h.__html),t.__k=[];else if(v&&(u.innerHTML=\"\"),I(\"template\"==t.type?u.content:u,d(y)?y:[y],t,i,o,\"foreignObject\"==x?\"http://www.w3.org/1999/xhtml\":r,e,f,e?e[0]:i.__k&&S(i,0),c,s),null!=e)for(a=e.length;a--;)g(e[a]);c||(a=\"value\",\"progress\"==x&&null==_?u.removeAttribute(\"value\"):null!=_&&(_!==u[a]||\"progress\"==x&&!_||\"option\"==x&&_!=b[a])&&j(u,a,_,b[a],r),a=\"checked\",null!=m&&m!=u[a]&&j(u,a,m,b[a],r))}return u}function B(n,u,t){try{if(\"function\"==typeof n){var i=\"function\"==typeof n.__u;i&&n.__u(),i&&null==u||(n.__u=n(u))}else n.current=u}catch(n){l.__e(n,t)}}function D(n,u,t){var i,o;if(l.unmount&&l.unmount(n),(i=n.ref)&&(i.current&&i.current!=n.__e||B(i,null,u)),null!=(i=n.__c)){if(i.componentWillUnmount)try{i.componentWillUnmount()}catch(n){l.__e(n,u)}i.base=i.__P=null}if(i=n.__k)for(o=0;o<i.length;o++)i[o]&&D(i[o],u,t||\"function\"!=typeof n.type);t||g(n.__e),n.__c=n.__=n.__e=void 0}function E(n,l,u){return this.constructor(n,u)}function G(u,t,i){var o,r,e,f;t==document&&(t=document.documentElement),l.__&&l.__(u,t),r=(o=\"function\"==typeof i)?null:i&&i.__k||t.__k,e=[],f=[],O(t,u=(!o&&i||t).__k=_(k,null,[u]),r||p,p,t.namespaceURI,!o&&i?[i]:r?null:t.firstChild?n.call(t.childNodes):null,e,!o&&i?i:r?r.__e:t.firstChild,o,f),N(e,u,f)}function J(n,l){G(n,l,J)}function K(l,u,t){var i,o,r,e,f=w({},l.props);for(r in l.type&&l.type.defaultProps&&(e=l.type.defaultProps),u)\"key\"==r?i=u[r]:\"ref\"==r?o=u[r]:f[r]=void 0===u[r]&&null!=e?e[r]:u[r];return arguments.length>2&&(f.children=arguments.length>3?n.call(arguments,2):t),m(l.type,f,i||l.key,o||l.ref,null)}function Q(n){function l(n){var u,t;return this.getChildContext||(u=new Set,(t={})[l.__c]=this,this.getChildContext=function(){return t},this.componentWillUnmount=function(){u=null},this.shouldComponentUpdate=function(n){this.props.value!=n.value&&u.forEach(function(n){n.__e=!0,M(n)})},this.sub=function(n){u.add(n);var l=n.componentWillUnmount;n.componentWillUnmount=function(){u&&u.delete(n),l&&l.call(n)}}),n.children}return l.__c=\"__cC\"+h++,l.__=n,l.Provider=l.__l=(l.Consumer=function(n,l){return n.children(l)}).contextType=l,l}n=v.slice,l={__e:function(n,l,u,t){for(var i,o,r;l=l.__;)if((i=l.__c)&&!i.__)try{if((o=i.constructor)&&null!=o.getDerivedStateFromError&&(i.setState(o.getDerivedStateFromError(n)),r=i.__d),null!=i.componentDidCatch&&(i.componentDidCatch(n,t||{}),r=i.__d),r)return i.__E=i}catch(l){n=l}throw n}},u=0,t=function(n){return null!=n&&void 0===n.constructor},x.prototype.setState=function(n,l){var u;u=null!=this.__s&&this.__s!=this.state?this.__s:this.__s=w({},this.state),\"function\"==typeof n&&(n=n(w({},u),this.props)),n&&w(u,n),null!=n&&this.__v&&(l&&this._sb.push(l),M(this))},x.prototype.forceUpdate=function(n){this.__v&&(this.__e=!0,n&&this.__h.push(n),M(this))},x.prototype.render=k,i=[],r=\"function\"==typeof Promise?Promise.prototype.then.bind(Promise.resolve()):setTimeout,e=function(n,l){return n.__v.__b-l.__v.__b},$.__r=0,f=/(PointerCapture)$|Capture$/i,c=0,s=F(!1),a=F(!0),h=0;export{x as Component,k as Fragment,K as cloneElement,Q as createContext,_ as createElement,b as createRef,_ as h,J as hydrate,t as isValidElement,l as options,G as render,H as toChildArray};\n//# sourceMappingURL=preact.module.js.map\n","import{options as r,Fragment as e}from\"preact\";export{Fragment}from\"preact\";var t=/[\"&<]/;function n(r){if(0===r.length||!1===t.test(r))return r;for(var e=0,n=0,o=\"\",f=\"\";n<r.length;n++){switch(r.charCodeAt(n)){case 34:f=\"&quot;\";break;case 38:f=\"&amp;\";break;case 60:f=\"&lt;\";break;default:continue}n!==e&&(o+=r.slice(e,n)),o+=f,e=n+1}return n!==e&&(o+=r.slice(e,n)),o}var o=/acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i,f=0,i=Array.isArray;function u(e,t,n,o,i,u){t||(t={});var a,c,p=t;if(\"ref\"in p)for(c in p={},t)\"ref\"==c?a=t[c]:p[c]=t[c];var l={type:e,props:p,key:n,ref:a,__k:null,__:null,__b:0,__e:null,__c:null,constructor:void 0,__v:--f,__i:-1,__u:0,__source:i,__self:u};if(\"function\"==typeof e&&(a=e.defaultProps))for(c in a)void 0===p[c]&&(p[c]=a[c]);return r.vnode&&r.vnode(l),l}function a(r){var t=u(e,{tpl:r,exprs:[].slice.call(arguments,1)});return t.key=t.__v,t}var c={},p=/[A-Z]/g;function l(e,t){if(r.attr){var f=r.attr(e,t);if(\"string\"==typeof f)return f}if(t=function(r){return null!==r&&\"object\"==typeof r&&\"function\"==typeof r.valueOf?r.valueOf():r}(t),\"ref\"===e||\"key\"===e)return\"\";if(\"style\"===e&&\"object\"==typeof t){var i=\"\";for(var u in t){var a=t[u];if(null!=a&&\"\"!==a){var l=\"-\"==u[0]?u:c[u]||(c[u]=u.replace(p,\"-$&\").toLowerCase()),s=\";\";\"number\"!=typeof a||l.startsWith(\"--\")||o.test(l)||(s=\"px;\"),i=i+l+\":\"+a+s}}return e+'=\"'+n(i)+'\"'}return null==t||!1===t||\"function\"==typeof t||\"object\"==typeof t?\"\":!0===t?e:e+'=\"'+n(\"\"+t)+'\"'}function s(r){if(null==r||\"boolean\"==typeof r||\"function\"==typeof r)return null;if(\"object\"==typeof r){if(void 0===r.constructor)return r;if(i(r)){for(var e=0;e<r.length;e++)r[e]=s(r[e]);return r}}return n(\"\"+r)}export{u as jsx,l as jsxAttr,u as jsxDEV,s as jsxEscape,a as jsxTemplate,u as jsxs};\n//# sourceMappingURL=jsxRuntime.module.js.map\n","import{options as n}from\"preact\";var t,r,u,i,o=0,f=[],c=n,e=c.__b,a=c.__r,v=c.diffed,l=c.__c,m=c.unmount,s=c.__;function p(n,t){c.__h&&c.__h(r,n,o||t),o=0;var u=r.__H||(r.__H={__:[],__h:[]});return n>=u.__.length&&u.__.push({}),u.__[n]}function d(n){return o=1,h(D,n)}function h(n,u,i){var o=p(t++,2);if(o.t=n,!o.__c&&(o.__=[i?i(u):D(void 0,u),function(n){var t=o.__N?o.__N[0]:o.__[0],r=o.t(t,n);t!==r&&(o.__N=[r,o.__[1]],o.__c.setState({}))}],o.__c=r,!r.__f)){var f=function(n,t,r){if(!o.__c.__H)return!0;var u=o.__c.__H.__.filter(function(n){return!!n.__c});if(u.every(function(n){return!n.__N}))return!c||c.call(this,n,t,r);var i=o.__c.props!==n;return u.forEach(function(n){if(n.__N){var t=n.__[0];n.__=n.__N,n.__N=void 0,t!==n.__[0]&&(i=!0)}}),c&&c.call(this,n,t,r)||i};r.__f=!0;var c=r.shouldComponentUpdate,e=r.componentWillUpdate;r.componentWillUpdate=function(n,t,r){if(this.__e){var u=c;c=void 0,f(n,t,r),c=u}e&&e.call(this,n,t,r)},r.shouldComponentUpdate=f}return o.__N||o.__}function y(n,u){var i=p(t++,3);!c.__s&&C(i.__H,u)&&(i.__=n,i.u=u,r.__H.__h.push(i))}function _(n,u){var i=p(t++,4);!c.__s&&C(i.__H,u)&&(i.__=n,i.u=u,r.__h.push(i))}function A(n){return o=5,T(function(){return{current:n}},[])}function F(n,t,r){o=6,_(function(){if(\"function\"==typeof n){var r=n(t());return function(){n(null),r&&\"function\"==typeof r&&r()}}if(n)return n.current=t(),function(){return n.current=null}},null==r?r:r.concat(n))}function T(n,r){var u=p(t++,7);return C(u.__H,r)&&(u.__=n(),u.__H=r,u.__h=n),u.__}function q(n,t){return o=8,T(function(){return n},t)}function x(n){var u=r.context[n.__c],i=p(t++,9);return i.c=n,u?(null==i.__&&(i.__=!0,u.sub(r)),u.props.value):n.__}function P(n,t){c.useDebugValue&&c.useDebugValue(t?t(n):n)}function b(n){var u=p(t++,10),i=d();return u.__=n,r.componentDidCatch||(r.componentDidCatch=function(n,t){u.__&&u.__(n,t),i[1](n)}),[i[0],function(){i[1](void 0)}]}function g(){var n=p(t++,11);if(!n.__){for(var u=r.__v;null!==u&&!u.__m&&null!==u.__;)u=u.__;var i=u.__m||(u.__m=[0,0]);n.__=\"P\"+i[0]+\"-\"+i[1]++}return n.__}function j(){for(var n;n=f.shift();)if(n.__P&&n.__H)try{n.__H.__h.forEach(z),n.__H.__h.forEach(B),n.__H.__h=[]}catch(t){n.__H.__h=[],c.__e(t,n.__v)}}c.__b=function(n){r=null,e&&e(n)},c.__=function(n,t){n&&t.__k&&t.__k.__m&&(n.__m=t.__k.__m),s&&s(n,t)},c.__r=function(n){a&&a(n),t=0;var i=(r=n.__c).__H;i&&(u===r?(i.__h=[],r.__h=[],i.__.forEach(function(n){n.__N&&(n.__=n.__N),n.u=n.__N=void 0})):(i.__h.forEach(z),i.__h.forEach(B),i.__h=[],t=0)),u=r},c.diffed=function(n){v&&v(n);var t=n.__c;t&&t.__H&&(t.__H.__h.length&&(1!==f.push(t)&&i===c.requestAnimationFrame||((i=c.requestAnimationFrame)||w)(j)),t.__H.__.forEach(function(n){n.u&&(n.__H=n.u),n.u=void 0})),u=r=null},c.__c=function(n,t){t.some(function(n){try{n.__h.forEach(z),n.__h=n.__h.filter(function(n){return!n.__||B(n)})}catch(r){t.some(function(n){n.__h&&(n.__h=[])}),t=[],c.__e(r,n.__v)}}),l&&l(n,t)},c.unmount=function(n){m&&m(n);var t,r=n.__c;r&&r.__H&&(r.__H.__.forEach(function(n){try{z(n)}catch(n){t=n}}),r.__H=void 0,t&&c.__e(t,r.__v))};var k=\"function\"==typeof requestAnimationFrame;function w(n){var t,r=function(){clearTimeout(u),k&&cancelAnimationFrame(t),setTimeout(n)},u=setTimeout(r,35);k&&(t=requestAnimationFrame(r))}function z(n){var t=r,u=n.__c;\"function\"==typeof u&&(n.__c=void 0,u()),r=t}function B(n){var t=r;n.__c=n.__(),r=t}function C(n,t){return!n||n.length!==t.length||t.some(function(t,r){return t!==n[r]})}function D(n,t){return\"function\"==typeof t?t(n):t}export{q as useCallback,x as useContext,P as useDebugValue,y as useEffect,b as useErrorBoundary,g as useId,F as useImperativeHandle,_ as useLayoutEffect,T as useMemo,h as useReducer,A as useRef,d as useState};\n//# sourceMappingURL=hooks.module.js.map\n","// Widget dimensions\nexport const BUTTON_SIZE = 60;\nexport const WINDOW_WIDTH = 350;\nexport const WINDOW_HEIGHT = 500;\n\n// Positioning\nexport const POSITION_BOTTOM = 20;\nexport const POSITION_RIGHT = 20;\n\n// Colors — initial values match the backend ProjectSettings default.\n// applyTheme() in index.tsx overrides primary/primaryHover/messageUser\n// with the remote config value before the widget renders.\nexport const COLORS = {\n primary: \"#6C03C1\",\n primaryHover: \"#5b02a4\",\n background: \"#ffffff\",\n text: \"hsla(215, 100%, 5%, 1)\",\n textSecondary: \"hsla(215, 100%, 5%, 1)\",\n border: \"#e5e7eb\",\n messageBot: \"\",\n messageUser: \"#6C03C1\",\n messageUserText: \"#ffffff\",\n};\n\nconst normalizeHexColor = (hex: string): string => {\n const trimmed = hex.trim();\n if (!/^#([0-9a-fA-F]{3}|[0-9a-fA-F]{6})$/.test(trimmed)) {\n return \"hsla(215, 100%, 5%, 1)\";\n }\n if (trimmed.length === 4) {\n const r = trimmed[1];\n const g = trimmed[2];\n const b = trimmed[3];\n return `#${r}${r}${g}${g}${b}${b}`;\n }\n return trimmed;\n};\n\nexport const getContrastIconFilter = (backgroundHex: string): string => {\n const hex = normalizeHexColor(backgroundHex).slice(1);\n const r = parseInt(hex.slice(0, 2), 16);\n const g = parseInt(hex.slice(2, 4), 16);\n const b = parseInt(hex.slice(4, 6), 16);\n\n // Relative luminance approximation for quick contrast choice.\n const luminance = (0.299 * r + 0.587 * g + 0.114 * b) / 255;\n return luminance > 0.62 ? \"brightness(0) invert(0)\" : \"brightness(0) invert(1)\";\n};\n\n// Border radius\nexport const BORDER_RADIUS = {\n button: '50%',\n window: '17px',\n message: '10px'\n};\n\n// Shadows\nexport const SHADOW = \"0 0 15px hsla(215, 100%, 5%, 0.15)\";\n\n// Transitions\nexport const TRANSITIONS = {\n fast: '150ms ease-in-out',\n medium: '250ms ease-in-out'\n};\n","import microphoneIcon from \"./assets/icons/microphone.svg?inline\";\nimport microphoneIconRaw from \"./assets/icons/microphone.svg?raw\";\nimport restartIcon from \"./assets/icons/restart.svg?inline\";\nimport restartIconRaw from \"./assets/icons/restart.svg?raw\";\nimport closeIcon from \"./assets/icons/close.svg?inline\";\nimport closeIconRaw from \"./assets/icons/close.svg?raw\";\nimport stopIcon from \"./assets/icons/stop.svg?inline\";\nimport stopIconRaw from \"./assets/icons/stop.svg?raw\";\nimport bulutLogo from \"./assets/icons/bulut_logo.svg\";\nimport bulutLogoRaw from \"./assets/icons/bulut_logo.svg?raw\";\nimport sentSfx from \"./assets/sfx/sent.mp3\";\nimport thinkingSfx from \"./assets/sfx/thinking.mp3\";\nimport toolCallSfx from \"./assets/sfx/tool_call.mp3\";\nimport completedSfx from \"./assets/sfx/completed.mp3\";\n\nexport const microphoneIconUrl = microphoneIcon;\nexport const microphoneIconContent = microphoneIconRaw;\nexport const restartIconUrl = restartIcon;\nexport const restartIconContent = restartIconRaw;\nexport const closeIconUrl = closeIcon;\nexport const closeIconContent = closeIconRaw;\nexport const stopIconUrl = stopIcon;\nexport const stopIconContent = stopIconRaw;\nexport const logoUrl = bulutLogo;\nexport const logoContent = bulutLogoRaw;\nexport const sentSfxUrl = sentSfx;\nexport const thinkingSfxUrl = thinkingSfx;\nexport const toolCallSfxUrl = toolCallSfx;\nexport const completedSfxUrl = completedSfx;\n","export default \"<svg width=\\\"50\\\" height=\\\"50\\\" viewBox=\\\"0 0 50 50\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\">\\n<path d=\\\"M17.6667 47H32.3333M39.6666 19.5001V23.1667C39.6666 31.2334 33.0666 37.8334 25 37.8334M25 37.8334C16.9333 37.8334 10.3334 31.2334 10.3334 23.1667V19.5001M25 37.8334V47M25 3.00009C24.0356 2.99523 23.0798 3.1816 22.1879 3.54841C21.296 3.91523 20.4857 4.45521 19.8037 5.13714C19.1218 5.81907 18.5818 6.62942 18.215 7.52133C17.8482 8.41325 17.6618 9.36903 17.6667 10.3334V23.0521C17.6667 27.0855 20.9896 30.5 25 30.5C29.0104 30.5 32.3333 27.1771 32.3333 23.0521V10.3334C32.3333 6.20842 29.125 3.00009 25 3.00009Z\\\" stroke=\\\"hsla(215, 100%, 5%, 1)\\\" stroke-width=\\\"3\\\" stroke-linecap=\\\"round\\\" stroke-linejoin=\\\"round\\\"/>\\n</svg>\\n\"","export default \"<svg width=\\\"50\\\" height=\\\"50\\\" viewBox=\\\"0 0 50 50\\\" fill=\\\"none\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\">\\n<path d=\\\"M42.5 42.5L7.5 7.5M42.5 7.5L7.5 42.5\\\" stroke=\\\"hsla(215, 100%, 5%, 1)\\\" stroke-width=\\\"3\\\" stroke-linecap=\\\"round\\\" stroke-linejoin=\\\"round\\\"/>\\n</svg>\\n\"","export default \"<svg width=\\\"50\\\" height=\\\"50\\\" viewBox=\\\"0 0 50 50\\\" fill=\\\"none\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\">\\n<rect x=\\\"12\\\" y=\\\"12\\\" width=\\\"26\\\" height=\\\"26\\\" rx=\\\"4\\\" stroke=\\\"hsla(215, 100%, 5%, 1)\\\" stroke-width=\\\"3\\\" fill=\\\"none\\\"/>\\n</svg>\\n\"","\nimport type { CSSProperties, JSX } from \"preact\";\nimport { useMemo } from \"preact/hooks\";\n\nexport type SvgIconProps = Omit<JSX.IntrinsicElements[\"svg\"], \"style\"> & {\n src: string;\n title?: string;\n /**\n * If true, replaces fill and stroke attributes with \"currentColor\" in the inner SVG content.\n * Default: true\n */\n stripColors?: boolean;\n style?: CSSProperties;\n // Explicitly add common props to ensure destructuring works smoothly\n className?: string;\n fill?: string;\n stroke?: string;\n strokeWidth?: string | number;\n width?: string | number;\n height?: string | number;\n};\n\nexport function SvgIcon({\n src,\n width,\n height,\n title,\n stripColors = true,\n className,\n style,\n fill,\n stroke,\n strokeWidth,\n ...props\n}: SvgIconProps) {\n const { viewBox, content } = useMemo(() => {\n if (!src) return { viewBox: \"0 0 24 24\", content: \"\" };\n\n const trimmedSrc = src.trim();\n // Extract viewBox\n const viewBoxMatch = trimmedSrc.match(/viewBox=\"([^\"]*)\"/);\n const viewBox = viewBoxMatch ? viewBoxMatch[1] : \"0 0 24 24\";\n\n // Extract inner content by removing the outer <svg> wrapper\n // We remove the opening <svg ...> tag and the closing </svg> tag only.\n let content = trimmedSrc.replace(/^<svg[^>]*>/i, \"\").replace(/<\\/svg>\\s*$/i, \"\");\n\n return { viewBox, content };\n }, [src]);\n\n const cleanContent = useMemo(() => {\n if (!content) return \"\";\n let nextContent = content;\n\n if (stripColors) {\n // Force inner nodes to use props instead of hardcoded SVG values.\n nextContent = nextContent\n .replace(/fill=\"[^\"]*\"/gi, `fill=\"${fill}\"`)\n .replace(/stroke=\"[^\"]*\"/gi, `stroke=\"${stroke}\"`);\n }\n\n if (strokeWidth !== undefined) {\n const strokeWidthValue = String(strokeWidth);\n nextContent = /stroke-width=\"[^\"]*\"/i.test(nextContent)\n ? nextContent.replace(/stroke-width=\"[^\"]*\"/gi, `stroke-width=\"${strokeWidthValue}\"`)\n : nextContent.replace(\n /<(path|circle|ellipse|line|polyline|polygon|rect)\\b/gi,\n `<$1 stroke-width=\"${strokeWidthValue}\"`,\n );\n }\n\n return nextContent;\n }, [content, stripColors, fill, stroke, strokeWidth]);\n\n return (\n <svg\n viewBox={viewBox}\n width={width}\n height={height}\n className={className}\n style={{\n display: \"inline-block\",\n verticalAlign: \"middle\",\n flexShrink: 0,\n ...style,\n }}\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n dangerouslySetInnerHTML={{ __html: cleanContent }}\n >\n {title && <title>{title}</title>}\n </svg>\n );\n}\n","import {\n BUTTON_SIZE,\n POSITION_BOTTOM,\n POSITION_RIGHT,\n COLORS,\n SHADOW,\n TRANSITIONS,\n BORDER_RADIUS,\n getContrastIconFilter,\n} from \"../styles/constants\";\nimport { closeIconContent, microphoneIconContent, stopIconContent } from \"../assets\";\nimport { SvgIcon } from \"./SvgIcon\";\n\ninterface ChatButtonProps {\n onMicClick: () => void;\n onCancelRecording: () => void;\n onStopTask: () => void;\n isRecording: boolean;\n isBusy: boolean;\n showBubble: boolean;\n onBubbleClick: () => void;\n previewMessage: string | null;\n onPreviewClick: () => void;\n onPreviewClose: () => void;\n}\n\nexport const ChatButton = ({\n onMicClick,\n onCancelRecording,\n onStopTask,\n isRecording,\n isBusy,\n showBubble,\n onBubbleClick,\n previewMessage,\n onPreviewClick,\n onPreviewClose,\n}: ChatButtonProps) => {\n const bgColor = COLORS.primary;\n\n const containerStyle: { [key: string]: string } = {\n position: \"fixed\",\n right: `${POSITION_RIGHT}px`,\n bottom: `${POSITION_BOTTOM}px`,\n display: \"flex\",\n flexDirection: \"column\",\n alignItems: \"flex-end\",\n gap: \"8px\",\n zIndex: \"9999\",\n fontFamily: \"\\\"Geist\\\", sans-serif\",\n };\n\n const controlsRowStyle: { [key: string]: string } = {\n display: \"flex\",\n alignItems: \"center\",\n gap: \"10px\",\n };\n\n const buttonStyle: { [key: string]: string } = {\n width: `${BUTTON_SIZE}px`,\n height: `${BUTTON_SIZE}px`,\n minWidth: `${BUTTON_SIZE}px`,\n minHeight: `${BUTTON_SIZE}px`,\n borderRadius: BORDER_RADIUS.button,\n backgroundColor: bgColor,\n color: \"#ffffff\",\n border: \"none\",\n cursor: \"pointer\",\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n transition: `background-color ${TRANSITIONS.fast}, transform ${TRANSITIONS.fast}`,\n position: \"relative\",\n flexShrink: \"0\",\n };\n\n const iconStyle: { [key: string]: string } = {\n width: \"24px\",\n height: \"24px\",\n display: \"block\",\n filter: getContrastIconFilter(bgColor),\n };\n\n const showStopButton = isBusy && !isRecording;\n\n const handleClick = () => {\n if (showStopButton) {\n onStopTask();\n } else if (isRecording) {\n onCancelRecording();\n } else {\n onMicClick();\n }\n };\n\n // Shared close button style\n const closeBtnStyle: { [key: string]: string } = {\n position: \"absolute\",\n top: \"6px\",\n right: \"6px\",\n width: \"20px\",\n height: \"20px\",\n borderRadius: \"50%\",\n border: \"none\",\n background: \"transparent\",\n cursor: \"pointer\",\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n fontSize: \"12px\",\n lineHeight: \"1\",\n color: COLORS.text,\n padding: \"0\",\n };\n\n const renderPopup = (\n content: preact.ComponentChildren,\n onClick: () => void,\n onClose: (() => void) | null,\n extraClass: string,\n scrollable: boolean,\n ) => (\n <div\n className={`bulut-popup ${extraClass}`}\n style={{ cursor: \"pointer\" }}\n onClick={onClick}\n >\n {/* Close button */}\n {onClose && (\n <button\n type=\"button\"\n style={closeBtnStyle}\n onClick={(e) => {\n e.stopPropagation();\n onClose();\n }}\n aria-label=\"Kapat\"\n >\n <SvgIcon\n strokeWidth={3}\n src={closeIconContent}\n stroke={\"currentColor\"}\n height={14}\n />\n </button>\n )}\n\n {/* Text content */}\n <div\n style={{\n paddingRight: onClose ? \"22px\" : \"0\",\n wordBreak: \"break-word\",\n ...(scrollable ? { maxHeight: \"96px\", overflowY: \"auto\" } : {}),\n }}\n >\n {content}\n </div>\n </div>\n );\n\n return (\n <>\n <style>{`\n @import url('https://fonts.googleapis.com/css2?family=Geist:wght@100..900&display=swap');\n\n .bulut-popup {\n background: #ffffff;\n color: ${COLORS.text};\n padding: 10px 14px;\n border-radius: 12px;\n font-size: 14px;\n line-height: 1.4;\n position: relative;\n overflow: visible;\n box-shadow: ${SHADOW};\n }\n .bulut-popup-bubble {\n animation: bulut-bubbleIn 400ms ease-out;\n }\n .bulut-popup-preview {\n animation: bulut-popIn ${TRANSITIONS.medium};\n }\n\n /* Desktop: limit width, lean to right */\n .bulut-popup {\n max-width: 320px;\n }\n\n /* Mobile: full-width layout with popup filling remaining space */\n @media (max-width: 600px) {\n .bulut-fab-container:has(.bulut-popup) {\n left: 16px !important;\n right: 16px !important;\n }\n .bulut-fab-container:has(.bulut-popup) .bulut-controls-row {\n width: 100%;\n }\n .bulut-popup {\n flex: 1;\n min-width: 0;\n max-width: none;\n }\n }\n\n @keyframes bulut-popIn {\n from { opacity: 0; transform: translateX(10px); }\n to { opacity: 1; transform: translateX(0); }\n }\n @keyframes bulut-bubbleIn {\n 0% { opacity: 0; transform: translateX(10px) scale(0.95); }\n 60% { opacity: 1; transform: translateX(-4px) scale(1.02); }\n 100% { opacity: 1; transform: translateX(0) scale(1); }\n }\n @keyframes bulut-badgeIn {\n from { opacity: 0; transform: translateY(-4px); }\n to { opacity: 1; transform: translateY(0); }\n }\n `}</style>\n\n <div className=\"bulut-fab-container\" style={containerStyle}>\n <div className=\"bulut-controls-row\" style={controlsRowStyle}>\n {/* Welcome bubble */}\n {showBubble &&\n !isRecording &&\n !previewMessage &&\n renderPopup(\n \"Destek lazımsa hemen konuşmaya başlayabiliriz!\",\n onBubbleClick,\n null,\n \"bulut-popup-bubble\",\n false,\n )}\n\n {/* New-message preview */}\n {previewMessage &&\n renderPopup(\n previewMessage,\n onPreviewClick,\n onPreviewClose,\n \"bulut-popup-preview\",\n true,\n )}\n\n {/* Main mic / cancel button */}\n <button\n style={buttonStyle}\n onClick={handleClick}\n onMouseEnter={(e) => {\n Object.assign(e.currentTarget.style, {\n backgroundColor: COLORS.primaryHover,\n transform: \"scale(1.05)\",\n });\n }}\n onMouseLeave={(e) => {\n Object.assign(e.currentTarget.style, {\n transform: \"scale(1)\",\n });\n }}\n aria-label={showStopButton ? \"Görevi durdur\" : isRecording ? \"Kaydı iptal et\" : \"Konuşmaya başla\"}\n >\n <SvgIcon\n src={showStopButton ? stopIconContent : isRecording ? closeIconContent : microphoneIconContent}\n aria-hidden=\"true\"\n fill-opacity={0}\n stroke={\"currentColor\"}\n style={iconStyle}\n />\n </button>\n </div>\n </div>\n </>\n );\n};\n","export interface PageContext {\n links: string[];\n interactables: string[];\n summary: string;\n}\n\nexport interface CachedPageContextEntry {\n url: string;\n summary: string;\n links: string[];\n interactables: string[];\n capturedAt: number;\n version: number;\n}\n\nexport interface PageContextSummaryInput {\n url: string;\n title: string;\n lang: string;\n headings: string[];\n landmarks: string[];\n links: string[];\n interactables: string[];\n interactionSignals: string[];\n styleSelectors: string[];\n pageBlueprint: string[];\n textSnippets: string[];\n outerHtmlDigest: string;\n}\n\ninterface InteractableCandidate {\n line: string;\n score: number;\n order: number;\n}\n\ninterface PageSignalSnapshot {\n links: string[];\n interactables: string[];\n interactionSignals: string[];\n styleSelectors: string[];\n pageBlueprint: string[];\n}\n\nimport {\n MAX_LINKS,\n MAX_INTERACTABLES,\n MAX_HEADINGS,\n MAX_TEXT_SNIPPETS,\n MAX_CACHED_PAGES,\n MAX_PAGE_SCAN_ELEMENTS,\n MAX_EVENT_HINTS_PER_ELEMENT,\n MAX_BRANCH_SAMPLES,\n MAX_BRANCH_DEPTH,\n MAX_STYLESHEET_SELECTORS,\n MAX_STYLESHEET_RULES,\n} from \"./contextConfig\";\n\nexport const PAGE_CONTEXT_CACHE_VERSION = 3;\nexport const PAGE_CONTEXT_CACHE_KEY = \"auticbot_page_context_cache_v3\";\n\nconst NON_CONTENT_TAGS = new Set([\n \"script\",\n \"style\",\n \"noscript\",\n \"template\",\n \"link\",\n \"meta\",\n]);\n\nconst NATIVE_INTERACTIVE_TAGS = new Set([\n \"a\",\n \"button\",\n \"input\",\n \"textarea\",\n \"select\",\n \"summary\",\n \"details\",\n \"option\",\n]);\n\nconst INTERACTIVE_ROLES = new Set([\n \"button\",\n \"link\",\n \"tab\",\n \"menuitem\",\n \"option\",\n \"checkbox\",\n \"radio\",\n \"switch\",\n \"combobox\",\n \"textbox\",\n \"searchbox\",\n \"slider\",\n \"spinbutton\",\n \"treeitem\",\n]);\n\nconst TRACKED_DISPLAY_VALUES = new Set([\n \"block\",\n \"inline\",\n \"inline-block\",\n \"flex\",\n \"inline-flex\",\n \"grid\",\n \"inline-grid\",\n]);\n\nconst TRACKED_POSITION_VALUES = new Set([\n \"relative\",\n \"absolute\",\n \"fixed\",\n \"sticky\",\n]);\n\nconst EVENT_HINT_NAMES = [\n \"click\",\n \"dblclick\",\n \"mousedown\",\n \"mouseup\",\n \"pointerdown\",\n \"pointerup\",\n \"touchstart\",\n \"touchend\",\n \"keydown\",\n \"keyup\",\n \"keypress\",\n \"input\",\n \"change\",\n \"submit\",\n \"focus\",\n \"blur\",\n];\n\nconst ARIA_INTERACTION_ATTRS = [\n \"aria-controls\",\n \"aria-expanded\",\n \"aria-haspopup\",\n \"aria-pressed\",\n \"aria-selected\",\n];\n\nconst DATA_INTERACTION_PATTERN =\n /(action|click|press|toggle|target|trigger|nav|open|close|menu|modal|command|submit)/i;\n\nconst STYLESHEET_SELECTOR_PATTERN =\n /(:hover|:focus|:active|button|a\\b|input|textarea|select|\\[role=|\\[aria-|\\[data-|\\.btn|\\.link)/i;\n\nconst pageContextCache = new Map<string, CachedPageContextEntry>();\nlet cacheHydrated = false;\n\nconst normalizeWhitespace = (value: string): string =>\n value.replace(/\\s+/g, \" \").trim();\n\nconst canonicalUrl = (rawUrl: string): string => {\n try {\n return new URL(rawUrl, rawUrl).href;\n } catch {\n return rawUrl;\n }\n};\n\nconst isCacheEntry = (value: unknown): value is CachedPageContextEntry => {\n if (typeof value !== \"object\" || value === null) {\n return false;\n }\n\n const obj = value as Record<string, unknown>;\n return (\n typeof obj.url === \"string\" &&\n typeof obj.summary === \"string\" &&\n Array.isArray(obj.links) &&\n Array.isArray(obj.interactables) &&\n typeof obj.capturedAt === \"number\" &&\n typeof obj.version === \"number\"\n );\n};\n\nconst bumpCount = (map: Map<string, number>, key: string): void => {\n if (!key) {\n return;\n }\n map.set(key, (map.get(key) ?? 0) + 1);\n};\n\nconst formatTopCounts = (map: Map<string, number>, maxItems: number): string => {\n if (map.size === 0) {\n return \"none\";\n }\n\n return Array.from(map.entries())\n .sort((a, b) => b[1] - a[1] || a[0].localeCompare(b[0]))\n .slice(0, maxItems)\n .map(([name, count]) => `${name}*${count}`)\n .join(\", \");\n};\n\nconst parseTabIndex = (value: string | null): number | null => {\n if (value === null) {\n return null;\n }\n\n const parsed = Number.parseInt(value, 10);\n return Number.isNaN(parsed) ? null : parsed;\n};\n\nconst compactToken = (value: string): string => {\n const compact = value.replace(/\\s+/g, \"-\").replace(/[^a-zA-Z0-9_-]/g, \"\");\n return compact || \"\";\n};\n\nconst getElementDepth = (element: Element): number => {\n let depth = 0;\n let cursor: Element | null = element;\n while (cursor?.parentElement) {\n depth += 1;\n cursor = cursor.parentElement;\n if (cursor === document.body) {\n break;\n }\n }\n return depth;\n};\n\nconst getPrimaryRole = (element: Element): string => {\n const rawRole = normalizeWhitespace(element.getAttribute(\"role\") || \"\")\n .toLowerCase()\n .split(\" \")[0];\n return rawRole || \"\";\n};\n\nconst hydrateCacheFromStorage = (): void => {\n if (cacheHydrated || typeof sessionStorage === \"undefined\") {\n return;\n }\n\n cacheHydrated = true;\n\n try {\n const raw = sessionStorage.getItem(PAGE_CONTEXT_CACHE_KEY);\n if (!raw) {\n return;\n }\n\n const parsed = JSON.parse(raw);\n if (!Array.isArray(parsed)) {\n return;\n }\n\n for (const value of parsed) {\n if (!isCacheEntry(value)) {\n continue;\n }\n if (value.version !== PAGE_CONTEXT_CACHE_VERSION) {\n continue;\n }\n pageContextCache.set(value.url, value);\n }\n if (pageContextCache.size > 0) {\n console.info(\n `[Autic] context cache restored entries=${pageContextCache.size}`,\n );\n }\n } catch (error) {\n console.warn(\"[Autic] context cache restore failed\", error);\n }\n};\n\nconst persistCacheToStorage = (): void => {\n if (typeof sessionStorage === \"undefined\") {\n return;\n }\n\n try {\n const serialized = JSON.stringify(\n Array.from(pageContextCache.values()).sort(\n (a, b) => a.capturedAt - b.capturedAt,\n ),\n );\n sessionStorage.setItem(PAGE_CONTEXT_CACHE_KEY, serialized);\n } catch (error) {\n console.warn(\"[Autic] context cache persist failed\", error);\n }\n};\n\nconst pruneOldestCacheEntries = (): void => {\n if (pageContextCache.size <= MAX_CACHED_PAGES) {\n return;\n }\n\n const sorted = Array.from(pageContextCache.values()).sort(\n (a, b) => a.capturedAt - b.capturedAt,\n );\n const overflow = sorted.length - MAX_CACHED_PAGES;\n for (let i = 0; i < overflow; i += 1) {\n pageContextCache.delete(sorted[i].url);\n }\n};\n\nconst buildSummaryWithHistory = (\n current: CachedPageContextEntry,\n): string => {\n const recentPages = Array.from(pageContextCache.values())\n .filter((entry) => entry.url !== current.url)\n .sort((a, b) => b.capturedAt - a.capturedAt)\n .slice(0, 3);\n\n if (recentPages.length === 0) {\n return current.summary;\n }\n\n const historySection = [\n \"Recent Page Memory:\",\n ...recentPages.map((entry) => {\n const compactSummary = normalizeWhitespace(entry.summary);\n return `- ${entry.url} :: ${compactSummary}`;\n }),\n ].join(\"\\n\");\n\n return `${current.summary}\\n\\n${historySection}`;\n};\n\nconst isVisible = (element: Element): boolean => {\n if (element.getAttribute(\"aria-hidden\") === \"true\") {\n return false;\n }\n\n if (element instanceof HTMLElement && element.hidden) {\n return false;\n }\n\n const style = window.getComputedStyle(element);\n if (style.display === \"none\" || style.visibility === \"hidden\") {\n return false;\n }\n\n const rect = element.getBoundingClientRect();\n return rect.width > 0 && rect.height > 0;\n};\n\nconst toAbsoluteUrl = (href: string): string => {\n try {\n return new URL(href, window.location.href).href;\n } catch {\n return href;\n }\n};\n\nconst escapeCssValue = (value: string): string => {\n if (typeof CSS !== \"undefined\" && typeof CSS.escape === \"function\") {\n return CSS.escape(value);\n }\n\n return value.replace(/([ #;&,.+*~':\"!^$\\[\\]()=>|\\/@])/g, \"\\\\$1\");\n};\n\nconst buildSelectorSegment = (element: Element): string => {\n const tag = element.tagName.toLowerCase();\n\n if (element.id) {\n return `#${escapeCssValue(element.id)}`;\n }\n\n const attrCandidates: Array<[name: string, value: string | null]> = [\n [\"name\", element.getAttribute(\"name\")],\n [\"data-testid\", element.getAttribute(\"data-testid\")],\n [\"data-test-id\", element.getAttribute(\"data-test-id\")],\n [\"aria-label\", element.getAttribute(\"aria-label\")],\n [\"role\", element.getAttribute(\"role\")],\n [\"type\", element.getAttribute(\"type\")],\n ];\n\n for (const [attrName, attrValue] of attrCandidates) {\n if (attrValue) {\n return `${tag}[${attrName}=\"${escapeCssValue(attrValue)}\"]`;\n }\n }\n\n const classes = Array.from(element.classList)\n .filter(Boolean)\n .slice(0, 3)\n .map((className) => `.${escapeCssValue(className)}`)\n .join(\"\");\n if (classes) {\n return `${tag}${classes}`;\n }\n\n const parent = element.parentElement;\n if (!parent) {\n return tag;\n }\n\n const siblingsOfTag = Array.from(parent.children).filter(\n (sibling) => sibling.tagName === element.tagName,\n );\n const index = siblingsOfTag.indexOf(element) + 1;\n return `${tag}:nth-of-type(${index})`;\n};\n\nconst buildSelector = (element: Element): string => {\n const segments: string[] = [];\n let cursor: Element | null = element;\n let depth = 0;\n\n while (cursor && depth < 4) {\n const segment = buildSelectorSegment(cursor);\n segments.unshift(segment);\n if (segment.startsWith(\"#\")) {\n break;\n }\n cursor = cursor.parentElement;\n depth += 1;\n }\n\n return segments.join(\" > \");\n};\n\nconst getElementLabel = (element: Element): string => {\n const text = normalizeWhitespace(\n (element instanceof HTMLElement ? element.innerText : element.textContent) ||\n \"\",\n );\n const ariaLabel = normalizeWhitespace(element.getAttribute(\"aria-label\") || \"\");\n const title = normalizeWhitespace(element.getAttribute(\"title\") || \"\");\n const placeholder = normalizeWhitespace(\n element.getAttribute(\"placeholder\") || \"\",\n );\n const name = normalizeWhitespace(element.getAttribute(\"name\") || \"\");\n const value =\n element instanceof HTMLInputElement ||\n element instanceof HTMLTextAreaElement ||\n element instanceof HTMLButtonElement\n ? normalizeWhitespace(element.value || \"\")\n : \"\";\n\n const classHint = Array.from(element.classList)\n .map((item) => compactToken(item))\n .find(Boolean);\n const fallback =\n (element.id && `#${element.id}`) ||\n (classHint && `.${classHint}`) ||\n buildSelector(element);\n\n const label =\n text || ariaLabel || title || placeholder || value || name || fallback;\n\n if (element.tagName.toLowerCase() === \"input\") {\n const inputType = element.getAttribute(\"type\") || \"text\";\n return `${inputType} ${label || \"input\"}`;\n }\n\n return label || \"untitled\";\n};\n\nconst getEventHints = (element: Element): string[] => {\n const record = element as unknown as Record<string, unknown>;\n const eventHints: string[] = [];\n\n for (const eventName of EVENT_HINT_NAMES) {\n const handlerKey = `on${eventName}`;\n const hasInlineHandler = Boolean(element.getAttribute(handlerKey));\n const hasPropertyHandler = typeof record[handlerKey] === \"function\";\n\n if (!hasInlineHandler && !hasPropertyHandler) {\n continue;\n }\n\n eventHints.push(eventName);\n if (eventHints.length >= MAX_EVENT_HINTS_PER_ELEMENT) {\n break;\n }\n }\n\n return eventHints;\n};\n\nconst getAriaInteractionHints = (element: Element): string[] =>\n ARIA_INTERACTION_ATTRS.filter((attrName) => element.hasAttribute(attrName)).map(\n (attrName) => attrName.replace(\"aria-\", \"\"),\n );\n\nconst getDataInteractionHints = (element: Element): string[] =>\n element\n .getAttributeNames()\n .filter(\n (attrName) =>\n attrName.startsWith(\"data-\") && DATA_INTERACTION_PATTERN.test(attrName),\n )\n .slice(0, 2)\n .map((attrName) => attrName.replace(\"data-\", \"\"));\n\nconst getComputedStyleSignals = (style: CSSStyleDeclaration): string[] => {\n const signals: string[] = [];\n\n if (style.cursor && style.cursor !== \"auto\") {\n signals.push(`cursor:${style.cursor}`);\n }\n if (style.display) {\n signals.push(`display:${style.display}`);\n }\n if (style.position) {\n signals.push(`position:${style.position}`);\n }\n if (style.zIndex && style.zIndex !== \"auto\") {\n signals.push(`z-index:${style.zIndex}`);\n }\n if (style.pointerEvents && style.pointerEvents !== \"auto\") {\n signals.push(`pointer-events:${style.pointerEvents}`);\n }\n if (style.visibility && style.visibility !== \"visible\") {\n signals.push(`visibility:${style.visibility}`);\n }\n if (style.opacity && style.opacity !== \"1\") {\n signals.push(`opacity:${style.opacity}`);\n }\n\n return Array.from(new Set(signals));\n};\n\nconst buildBlueprintToken = (element: Element): string => {\n const tag = element.tagName.toLowerCase();\n const idToken = element.id ? `#${compactToken(element.id)}` : \"\";\n const classToken = Array.from(element.classList)\n .map((item) => compactToken(item))\n .find(Boolean);\n\n return `${tag}${idToken}${classToken ? `.${classToken}` : \"\"}`;\n};\n\nconst buildBranchDigest = (element: Element, depth: number): string => {\n const token = buildBlueprintToken(element);\n if (depth <= 0) {\n return token;\n }\n\n const children = Array.from(element.children)\n .filter((child) => !NON_CONTENT_TAGS.has(child.tagName.toLowerCase()))\n .filter((child) => isVisible(child));\n if (children.length === 0) {\n return token;\n }\n\n const sampled = children\n .slice(0, 3)\n .map((child) => buildBranchDigest(child, depth - 1));\n const overflow =\n children.length > sampled.length ? `+${children.length - sampled.length}` : \"\";\n\n return `${token}>${sampled.join(\"+\")}${overflow}`;\n};\n\nconst collectDomBranchDigest = (): string[] => {\n const root = document.body ?? document.documentElement;\n const topLevelNodes = Array.from(root.children)\n .filter((child) => !NON_CONTENT_TAGS.has(child.tagName.toLowerCase()))\n .filter((child) => isVisible(child))\n .slice(0, MAX_BRANCH_SAMPLES);\n\n return topLevelNodes.map((child) =>\n buildBranchDigest(child, MAX_BRANCH_DEPTH),\n );\n};\n\nconst formatSection = (title: string, lines: string[]): string => {\n if (lines.length === 0) {\n return `${title}:\\n- none`;\n }\n\n return `${title}:\\n${lines.join(\"\\n\")}`;\n};\n\nconst buildOuterHtmlDigest = (): string => {\n const raw = document.body?.outerHTML || document.documentElement.outerHTML;\n\n const withoutScripts = raw\n .replace(/<script[\\s\\S]*?<\\/script>/gi, \"\")\n .replace(/<style[\\s\\S]*?<\\/style>/gi, \"\")\n .replace(/<noscript[\\s\\S]*?<\\/noscript>/gi, \"\")\n .replace(/<!--[\\s\\S]*?-->/g, \"\")\n .replace(/\\s+/g, \" \")\n .trim();\n\n const structural = withoutScripts\n .replace(/>[^<]*</g, \"><\")\n .replace(/\\s+/g, \" \")\n .trim();\n\n return structural;\n};\n\nconst collectTextSnippets = (): string[] => {\n const root =\n document.querySelector(\"main, article, [role='main']\") ?? document.body;\n const snippets: string[] = [];\n const seen = new Set<string>();\n\n const candidates = Array.from(root.querySelectorAll(\"p, li, h1, h2, h3\"));\n for (const node of candidates) {\n if (!isVisible(node)) {\n continue;\n }\n\n const text = normalizeWhitespace(node.textContent || \"\");\n if (!text || text.length < 20) {\n continue;\n }\n\n if (seen.has(text)) {\n continue;\n }\n\n seen.add(text);\n snippets.push(`- ${text}`);\n if (snippets.length >= MAX_TEXT_SNIPPETS) {\n break;\n }\n }\n\n return snippets;\n};\n\nconst collectLandmarkSnapshot = (): string[] => {\n const probes: Array<{ label: string; selector: string }> = [\n { label: \"main\", selector: \"main, [role='main']\" },\n { label: \"nav\", selector: \"nav, [role='navigation']\" },\n { label: \"section\", selector: \"section\" },\n { label: \"article\", selector: \"article\" },\n { label: \"form\", selector: \"form\" },\n { label: \"a\", selector: \"a\" },\n { label: \"button\", selector: \"button\" },\n { label: \"input\", selector: \"input\" },\n { label: \"role=button/link\", selector: \"[role='button'], [role='link']\" },\n { label: \"onclick attrs\", selector: \"[onclick]\" },\n {\n label: \"other event attrs\",\n selector:\n \"[onpointerdown], [onpointerup], [onkeydown], [onkeyup], [onchange], [onsubmit]\",\n },\n { label: \"tabindex\", selector: \"[tabindex]\" },\n { label: \"contenteditable\", selector: \"[contenteditable='true']\" },\n { label: \"inline cursor styles\", selector: \"[style*='cursor']\" },\n ];\n\n return probes.map(\n ({ label, selector }) => `- ${label}: ${document.querySelectorAll(selector).length}`,\n );\n};\n\nconst collectSelectorsFromRuleList = (\n rules: CSSRuleList,\n selectors: Set<string>,\n scanned: { count: number },\n): void => {\n for (const rule of Array.from(rules)) {\n if (\n scanned.count >= MAX_STYLESHEET_RULES ||\n selectors.size >= MAX_STYLESHEET_SELECTORS\n ) {\n return;\n }\n\n scanned.count += 1;\n\n if (rule instanceof CSSStyleRule) {\n const parts = rule.selectorText\n .split(\",\")\n .map((selector) => normalizeWhitespace(selector))\n .filter(Boolean);\n\n for (const selector of parts) {\n if (!STYLESHEET_SELECTOR_PATTERN.test(selector)) {\n continue;\n }\n selectors.add(selector);\n if (selectors.size >= MAX_STYLESHEET_SELECTORS) {\n return;\n }\n }\n continue;\n }\n\n if (\"cssRules\" in rule) {\n try {\n const nestedRules = (rule as CSSMediaRule).cssRules;\n collectSelectorsFromRuleList(nestedRules, selectors, scanned);\n } catch {\n // Ignore inaccessible nested rules.\n }\n }\n }\n};\n\nconst collectStylesheetSelectors = (): string[] => {\n const selectors = new Set<string>();\n const scanned = { count: 0 };\n\n for (const stylesheet of Array.from(document.styleSheets)) {\n if (\n scanned.count >= MAX_STYLESHEET_RULES ||\n selectors.size >= MAX_STYLESHEET_SELECTORS\n ) {\n break;\n }\n\n try {\n if (!stylesheet.cssRules) {\n continue;\n }\n collectSelectorsFromRuleList(stylesheet.cssRules, selectors, scanned);\n } catch {\n // Ignore cross-origin stylesheets.\n }\n }\n\n return Array.from(selectors).map((selector) => `- ${selector}`);\n};\n\nconst collectPageSignalSnapshot = (): PageSignalSnapshot => {\n const allElements = Array.from(document.querySelectorAll(\"*\"));\n const sampledElements = allElements.slice(0, MAX_PAGE_SCAN_ELEMENTS);\n\n const links: string[] = [];\n const linkSet = new Set<string>();\n const interactableCandidates = new Map<string, InteractableCandidate>();\n const tagCounts = new Map<string, number>();\n const roleCounts = new Map<string, number>();\n const eventCounts = new Map<string, number>();\n const displayCounts = new Map<string, number>();\n const positionCounts = new Map<string, number>();\n const styleSignalCounts = new Map<string, number>();\n\n let visibleElements = 0;\n let maxDepth = 0;\n let semanticInteractables = 0;\n let nonSemanticInteractables = 0;\n let eventHintElements = 0;\n let tabStopElements = 0;\n let pointerCursorElements = 0;\n let dataHintElements = 0;\n let ariaHintElements = 0;\n let contentEditableElements = 0;\n\n for (let order = 0; order < sampledElements.length; order += 1) {\n const element = sampledElements[order];\n const tag = element.tagName.toLowerCase();\n\n if (NON_CONTENT_TAGS.has(tag)) {\n continue;\n }\n\n if (!isVisible(element)) {\n continue;\n }\n\n visibleElements += 1;\n bumpCount(tagCounts, tag);\n\n const role = getPrimaryRole(element);\n if (role) {\n bumpCount(roleCounts, role);\n }\n\n const depth = getElementDepth(element);\n if (depth > maxDepth) {\n maxDepth = depth;\n }\n\n const style = window.getComputedStyle(element);\n if (TRACKED_DISPLAY_VALUES.has(style.display)) {\n bumpCount(displayCounts, style.display);\n }\n if (TRACKED_POSITION_VALUES.has(style.position)) {\n bumpCount(positionCounts, style.position);\n }\n\n const computedStyleSignals = getComputedStyleSignals(style);\n for (const styleSignal of computedStyleSignals) {\n bumpCount(styleSignalCounts, styleSignal);\n }\n\n const eventHints = getEventHints(element);\n if (eventHints.length > 0) {\n eventHintElements += 1;\n for (const eventName of eventHints) {\n bumpCount(eventCounts, eventName);\n }\n }\n\n const tabIndex = parseTabIndex(element.getAttribute(\"tabindex\"));\n const hasTabStop = tabIndex !== null && tabIndex >= 0;\n if (hasTabStop) {\n tabStopElements += 1;\n }\n\n const hasPointerCursor = style.cursor === \"pointer\";\n if (hasPointerCursor) {\n pointerCursorElements += 1;\n }\n\n const dataHints = getDataInteractionHints(element);\n if (dataHints.length > 0) {\n dataHintElements += 1;\n }\n\n const ariaHints = getAriaInteractionHints(element);\n if (ariaHints.length > 0) {\n ariaHintElements += 1;\n }\n\n const isContentEditable = element.getAttribute(\"contenteditable\") === \"true\";\n if (isContentEditable) {\n contentEditableElements += 1;\n }\n\n const href = element.getAttribute(\"href\");\n const isNativeInteractive = NATIVE_INTERACTIVE_TAGS.has(tag) && (tag !== \"a\" || Boolean(href));\n const isRoleInteractive = INTERACTIVE_ROLES.has(role);\n const isDisabled =\n element.hasAttribute(\"disabled\") ||\n element.getAttribute(\"aria-disabled\") === \"true\";\n\n if (\n tag === \"a\" &&\n href &&\n !href.startsWith(\"#\") &&\n !href.startsWith(\"javascript:\")\n ) {\n const absoluteHref = toAbsoluteUrl(href);\n const label = getElementLabel(element) || absoluteHref;\n const line = `- ${label} -> ${absoluteHref}`;\n\n if (!linkSet.has(line)) {\n linkSet.add(line);\n links.push(line);\n if (links.length >= MAX_LINKS) {\n // Keep scanning other elements for page blueprint and interactables.\n }\n }\n }\n\n const hasInteractionSignals =\n isNativeInteractive ||\n isRoleInteractive ||\n isContentEditable ||\n eventHints.length > 0 ||\n hasTabStop ||\n hasPointerCursor ||\n dataHints.length > 0 ||\n ariaHints.length > 0;\n\n if (!hasInteractionSignals || isDisabled) {\n continue;\n }\n\n if (isNativeInteractive) {\n semanticInteractables += 1;\n } else {\n nonSemanticInteractables += 1;\n }\n\n const selector = buildSelector(element);\n const label = getElementLabel(element);\n const styleSignals = computedStyleSignals;\n const signalTokens: string[] = [];\n\n if (eventHints.length > 0) {\n signalTokens.push(`evt:${eventHints.join(\"|\")}`);\n }\n if (isRoleInteractive) {\n signalTokens.push(`role:${role}`);\n }\n if (hasTabStop) {\n signalTokens.push(`tab:${tabIndex}`);\n }\n if (dataHints.length > 0) {\n signalTokens.push(`data:${dataHints.join(\"|\")}`);\n }\n if (ariaHints.length > 0) {\n signalTokens.push(`aria:${ariaHints.join(\"|\")}`);\n }\n if (styleSignals.length > 0) {\n signalTokens.push(`css:${styleSignals.join(\"|\")}`);\n } else if (hasPointerCursor) {\n signalTokens.push(\"css:cursor:pointer\");\n }\n\n const signalBlock =\n signalTokens.length > 0 ? ` [${signalTokens.join(\"; \")}]` : \"\";\n const line = `- ${tag} ${selector}${signalBlock} (${label})`;\n\n const score =\n eventHints.length * 5 +\n (isNativeInteractive ? 5 : 0) +\n (isRoleInteractive ? 4 : 0) +\n (hasTabStop ? 2 : 0) +\n (hasPointerCursor ? 2 : 0) +\n (dataHints.length > 0 ? 2 : 0) +\n (ariaHints.length > 0 ? 1 : 0) +\n (isContentEditable ? 2 : 0);\n\n const existing = interactableCandidates.get(line);\n if (!existing || score > existing.score) {\n interactableCandidates.set(line, { line, score, order });\n }\n }\n\n const interactables = Array.from(interactableCandidates.values())\n .sort((a, b) => b.score - a.score || a.order - b.order)\n .slice(0, MAX_INTERACTABLES)\n .map((candidate) => candidate.line);\n\n const interactiveRoleCounts = new Map(\n Array.from(roleCounts.entries()).filter(([role]) =>\n INTERACTIVE_ROLES.has(role),\n ),\n );\n\n const interactionSignals = [\n `- coverage: semantic=${semanticInteractables}, non-semantic=${nonSemanticInteractables}, contenteditable=${contentEditableElements}`,\n `- listener hints: ${formatTopCounts(eventCounts, 8)}`,\n `- interaction cues: tabindex>=0=${tabStopElements}, pointer-cursor=${pointerCursorElements}, data-hints=${dataHintElements}, aria-hints=${ariaHintElements}`,\n `- role hints: ${formatTopCounts(interactiveRoleCounts, 8)}`,\n `- css footprint: ${formatTopCounts(styleSignalCounts, 10)}`,\n \"- listener scope: inline/on* handlers are detected directly; addEventListener handlers are inferred via cues.\",\n ];\n\n const branchDigest = collectDomBranchDigest();\n const pageBlueprint = [\n `- nodes: total=${allElements.length}, scanned=${sampledElements.length}, visible=${visibleElements}, max-depth=${maxDepth}${allElements.length > sampledElements.length ? \", sampling=on\" : \"\"}`,\n `- tag density: ${formatTopCounts(tagCounts, 10)}`,\n `- role density: ${formatTopCounts(roleCounts, 8)}`,\n `- layout density: display(${formatTopCounts(displayCounts, 6)}), position(${formatTopCounts(positionCounts, 4)})`,\n `- branch digest: ${branchDigest.length > 0 ? branchDigest.join(\" || \") : \"none\"}`,\n ];\n\n return {\n links: links.slice(0, MAX_LINKS),\n interactables,\n interactionSignals,\n styleSelectors: collectStylesheetSelectors(),\n pageBlueprint,\n };\n};\n\nexport const buildPageContextSummary = (\n input: PageContextSummaryInput,\n): string => {\n const sections = [\n formatSection(\"Meta\", [\n `- URL: ${input.url || \"unknown\"}`,\n `- Title: ${input.title || \"unknown\"}`,\n `- Lang: ${input.lang || \"unknown\"}`,\n ]),\n formatSection(\"Headings\", input.headings),\n formatSection(\"Landmark Snapshot\", input.landmarks),\n formatSection(\"Interaction Signals\", input.interactionSignals),\n formatSection(\"Stylesheet Selector Snapshot\", input.styleSelectors),\n formatSection(\"Compressed Page Blueprint\", input.pageBlueprint),\n formatSection(\"Top Links\", input.links),\n formatSection(\"Top Interactables\", input.interactables),\n formatSection(\"Main Content Snippets\", input.textSnippets),\n formatSection(\"OuterHTML Skeleton\", [\n `- ${input.outerHtmlDigest || \"unavailable\"}`,\n ]),\n ];\n\n return sections.join(\"\\n\\n\");\n};\n\nexport const clearPageContextCache = (): void => {\n pageContextCache.clear();\n cacheHydrated = false;\n if (typeof sessionStorage !== \"undefined\") {\n sessionStorage.removeItem(PAGE_CONTEXT_CACHE_KEY);\n }\n};\n\nexport const getCachedPageContexts = (): CachedPageContextEntry[] => {\n hydrateCacheFromStorage();\n return Array.from(pageContextCache.values()).sort(\n (a, b) => b.capturedAt - a.capturedAt,\n );\n};\n\nexport const getPageContext = (): PageContext => {\n if (typeof window === \"undefined\" || typeof document === \"undefined\") {\n return {\n links: [],\n interactables: [],\n summary: \"\",\n };\n }\n\n hydrateCacheFromStorage();\n const url = canonicalUrl(window.location.href);\n const cached = pageContextCache.get(url);\n if (cached) {\n console.info(`[Autic] context cache hit url=${url}`);\n return {\n links: cached.links,\n interactables: cached.interactables,\n summary: buildSummaryWithHistory(cached),\n };\n }\n\n console.info(`[Autic] context cache miss url=${url}`);\n\n const snapshot = collectPageSignalSnapshot();\n const headings = Array.from(document.querySelectorAll(\"h1, h2, h3\"))\n .filter((element) => isVisible(element))\n .map((element) =>\n `- ${normalizeWhitespace(element.textContent || \"\")}`,\n )\n .filter((line) => line !== \"- \")\n .slice(0, MAX_HEADINGS);\n\n const summary = buildPageContextSummary({\n url,\n title: document.title,\n lang: document.documentElement.lang,\n headings,\n landmarks: collectLandmarkSnapshot(),\n links: snapshot.links,\n interactables: snapshot.interactables,\n interactionSignals: snapshot.interactionSignals,\n styleSelectors: snapshot.styleSelectors,\n pageBlueprint: snapshot.pageBlueprint,\n textSnippets: collectTextSnippets(),\n outerHtmlDigest: buildOuterHtmlDigest(),\n });\n\n const entry: CachedPageContextEntry = {\n url,\n summary,\n links: snapshot.links,\n interactables: snapshot.interactables,\n capturedAt: Date.now(),\n version: PAGE_CONTEXT_CACHE_VERSION,\n };\n\n pageContextCache.set(url, entry);\n pruneOldestCacheEntries();\n persistCacheToStorage();\n console.info(\n `[Autic] context cache stored url=${url} size=${pageContextCache.size}`,\n );\n\n return {\n links: entry.links,\n interactables: entry.interactables,\n summary: buildSummaryWithHistory(entry),\n };\n};\n","/**\n * Tunable parameters for page context collection.\n *\n * Adjust these values to control how much information the agent receives\n * about the current page. Lower values reduce token usage (and latency);\n * higher values give the LLM more detail to work with.\n */\n\n/** Maximum number of links to include in the context. */\nexport const MAX_LINKS = 20;\n\n/** Maximum number of interactable elements to include. */\nexport const MAX_INTERACTABLES = 24;\n\n/** Maximum number of headings (h1-h3) to include. */\nexport const MAX_HEADINGS = 10;\n\n/** Maximum number of main-content text snippets. */\nexport const MAX_TEXT_SNIPPETS = 4;\n\n/** Maximum number of pages kept in the in-memory context cache. */\nexport const MAX_CACHED_PAGES = 20;\n\n/** Maximum number of DOM elements scanned per page. */\nexport const MAX_PAGE_SCAN_ELEMENTS = 2000;\n\n/** Maximum number of event-handler hints collected per element. */\nexport const MAX_EVENT_HINTS_PER_ELEMENT = 4;\n\n/** Maximum top-level DOM branches sampled for the branch digest. */\nexport const MAX_BRANCH_SAMPLES = 4;\n\n/** Maximum tree depth for each branch digest sample. */\nexport const MAX_BRANCH_DEPTH = 2;\n\n/** Maximum stylesheet selectors to include in summary. */\nexport const MAX_STYLESHEET_SELECTORS = 80;\n\n/** Maximum CSS rules to scan while collecting stylesheet selectors. */\nexport const MAX_STYLESHEET_RULES = 700;\n","import { getPageContext } from \"./context\";\nimport { COLORS } from \"../styles/constants\";\n\nconst AGENT_CURSOR_ID = \"auticbot-agent-cursor\";\nconst CURSOR_STORAGE_KEY = \"auticbot_agent_cursor_state\";\nexport const CURSOR_MOVE_DURATION_MS = 900;\nexport const SCROLL_DURATION_MS = 900;\nconst CURSOR_EASING = \"cubic-bezier(0.4, 0, 0.2, 1)\";\nconst CURSOR_HOVER_RADIUS_PX = 14;\n\n// ── Pending Agent Resume State (survives page reloads) ──────────────\n\nconst RESUME_STORAGE_KEY = \"bulut_agent_resume\";\nconst RESUME_TTL_MS = 60_000; // 1 minute\n\nexport interface PendingAgentResume {\n sessionId: string;\n projectId: string;\n model: string;\n voice: string;\n accessibilityMode: boolean;\n pendingToolCalls: Array<{\n call_id: string;\n tool: string;\n args: Record<string, unknown>;\n }>;\n completedResults: Array<{ call_id: string; result: string }>;\n savedAt: number;\n}\n\nexport const savePendingAgentResume = (\n state: Omit<PendingAgentResume, \"savedAt\">,\n): void => {\n if (typeof localStorage === \"undefined\") return;\n try {\n localStorage.setItem(\n RESUME_STORAGE_KEY,\n JSON.stringify({ ...state, savedAt: Date.now() }),\n );\n } catch {\n // localStorage may be full or blocked\n }\n};\n\nexport const getPendingAgentResume = (): PendingAgentResume | null => {\n if (typeof localStorage === \"undefined\") return null;\n const raw = localStorage.getItem(RESUME_STORAGE_KEY);\n if (!raw) return null;\n try {\n const parsed = JSON.parse(raw) as PendingAgentResume;\n if (Date.now() - parsed.savedAt > RESUME_TTL_MS) {\n clearPendingAgentResume();\n return null;\n }\n return parsed;\n } catch {\n clearPendingAgentResume();\n return null;\n }\n};\n\nexport const clearPendingAgentResume = (): void => {\n if (typeof localStorage === \"undefined\") return;\n localStorage.removeItem(RESUME_STORAGE_KEY);\n};\n\ninterface PersistedCursorState {\n url: string;\n x: number;\n y: number;\n visible: boolean;\n}\n\ntype InteractAction = \"move\" | \"click\" | \"type\" | \"submit\";\n\ninterface InteractToolCall {\n tool: \"interact\";\n action: InteractAction;\n selector?: string;\n text?: string;\n x?: number;\n y?: number;\n}\n\ninterface NavigateToolCall {\n tool: \"navigate\";\n url: string;\n}\n\ninterface GetPageContextToolCall {\n tool: \"getPageContext\";\n}\n\ninterface ScrollToolCall {\n tool: \"scroll\";\n selector: string;\n}\n\nexport type AgentToolCall =\n | InteractToolCall\n | NavigateToolCall\n | GetPageContextToolCall\n | ScrollToolCall;\n\nexport interface ParsedAgentResponse {\n reply: string;\n toolCalls: AgentToolCall[];\n}\n\ninterface JsonObject {\n [key: string]: unknown;\n}\n\ninterface ResolvedTarget {\n element?: HTMLElement;\n x: number;\n y: number;\n}\n\nconst isObject = (value: unknown): value is JsonObject =>\n typeof value === \"object\" && value !== null && !Array.isArray(value);\n\nconst asString = (value: unknown): string | undefined =>\n typeof value === \"string\" && value.trim() ? value.trim() : undefined;\n\nconst asNumber = (value: unknown): number | undefined =>\n typeof value === \"number\" && Number.isFinite(value) ? value : undefined;\n\nconst extractJsonCandidate = (raw: string): string => {\n const trimmed = raw.trim();\n const fencedMatch = trimmed.match(/```(?:json)?\\s*([\\s\\S]*?)\\s*```/i);\n if (fencedMatch?.[1]) {\n return fencedMatch[1].trim();\n }\n return trimmed;\n};\n\nconst extractFirstJsonObject = (input: string): string | null => {\n const start = input.indexOf(\"{\");\n if (start < 0) {\n return null;\n }\n\n let depth = 0;\n let inString = false;\n let isEscaped = false;\n\n for (let i = start; i < input.length; i += 1) {\n const char = input[i];\n\n if (inString) {\n if (isEscaped) {\n isEscaped = false;\n } else if (char === \"\\\\\") {\n isEscaped = true;\n } else if (char === '\"') {\n inString = false;\n }\n continue;\n }\n\n if (char === '\"') {\n inString = true;\n continue;\n }\n\n if (char === \"{\") {\n depth += 1;\n continue;\n }\n\n if (char === \"}\") {\n depth -= 1;\n if (depth === 0) {\n return input.slice(start, i + 1);\n }\n }\n }\n\n return null;\n};\n\nconst parseJsonFromRaw = (raw: string): unknown => {\n const candidate = extractJsonCandidate(raw);\n try {\n return JSON.parse(candidate);\n } catch {\n const objectCandidate = extractFirstJsonObject(candidate);\n if (!objectCandidate) {\n return null;\n }\n try {\n return JSON.parse(objectCandidate);\n } catch {\n return null;\n }\n }\n};\n\nconst sanitizeToolCalls = (value: unknown): AgentToolCall[] => {\n if (!Array.isArray(value)) {\n return [];\n }\n\n const toolCalls: AgentToolCall[] = [];\n\n for (const item of value) {\n if (!isObject(item)) {\n continue;\n }\n\n if (item.tool === \"interact\") {\n const action = asString(item.action) as InteractAction | undefined;\n if (!action || ![\"move\", \"click\", \"type\", \"submit\"].includes(action)) {\n continue;\n }\n\n toolCalls.push({\n tool: \"interact\",\n action,\n selector: asString(item.selector),\n text: typeof item.text === \"string\" ? item.text : undefined,\n x: asNumber(item.x),\n y: asNumber(item.y),\n });\n continue;\n }\n\n if (item.tool === \"navigate\") {\n const url = asString(item.url);\n if (!url) {\n continue;\n }\n\n toolCalls.push({\n tool: \"navigate\",\n url,\n });\n continue;\n }\n\n if (item.tool === \"getPageContext\") {\n toolCalls.push({\n tool: \"getPageContext\",\n });\n continue;\n }\n\n if (item.tool === \"scroll\") {\n const selector = asString(item.selector);\n if (!selector) {\n continue;\n }\n\n toolCalls.push({\n tool: \"scroll\",\n selector,\n });\n }\n }\n\n return toolCalls;\n};\n\nexport const parseAgentResponse = (raw: string): ParsedAgentResponse => {\n const parsed = parseJsonFromRaw(raw);\n if (!isObject(parsed)) {\n return {\n reply: raw.trim(),\n toolCalls: [],\n };\n }\n\n const reply = asString(parsed.reply) || \"\";\n const toolCalls = sanitizeToolCalls(parsed.tool_calls ?? parsed.toolCalls);\n\n return {\n reply,\n toolCalls,\n };\n};\n\nexport const clamp = (value: number, min: number, max: number): number =>\n Math.min(max, Math.max(min, value));\n\nexport const easeInOutCubic = (progress: number): number => {\n if (progress < 0.5) {\n return 4 * progress * progress * progress;\n }\n return 1 - Math.pow(-2 * progress + 2, 3) / 2;\n};\n\nexport const easeInOutSine = (progress: number): number =>\n -(Math.cos(Math.PI * progress) - 1) / 2;\n\nexport const isRectOutsideViewport = (\n rect: Pick<DOMRect, \"top\" | \"bottom\">,\n viewportHeight: number,\n): boolean => rect.top < 0 || rect.bottom > viewportHeight;\n\nexport const computeCenteredScrollTop = (\n currentScrollY: number,\n rectTop: number,\n rectHeight: number,\n viewportHeight: number,\n maxScrollTop: number,\n): number => {\n const desired =\n currentScrollY + rectTop - (viewportHeight / 2 - rectHeight / 2);\n return clamp(desired, 0, Math.max(0, maxScrollTop));\n};\n\nexport const animateWindowScrollTo = async (\n targetY: number,\n durationMs: number = SCROLL_DURATION_MS,\n): Promise<void> => {\n if (typeof window === \"undefined\") {\n return;\n }\n\n const startY = window.scrollY;\n const delta = targetY - startY;\n if (Math.abs(delta) < 1) {\n return;\n }\n\n await new Promise<void>((resolve) => {\n const raf =\n window.requestAnimationFrame ||\n ((callback: FrameRequestCallback) => window.setTimeout(() => callback(performance.now()), 16));\n\n const startTime = performance.now();\n\n const step = (now: number) => {\n const elapsed = now - startTime;\n const progress = clamp(elapsed / durationMs, 0, 1);\n const eased = easeInOutSine(progress);\n window.scrollTo(0, startY + delta * eased);\n\n if (progress < 1) {\n raf(step);\n } else {\n resolve();\n }\n };\n\n raf(step);\n });\n};\n\nconst getPersistedCursorState = (): PersistedCursorState | null => {\n if (typeof localStorage === \"undefined\") {\n return null;\n }\n\n try {\n const raw = localStorage.getItem(CURSOR_STORAGE_KEY);\n if (!raw) {\n return null;\n }\n\n const parsed = JSON.parse(raw) as Partial<PersistedCursorState>;\n if (\n typeof parsed.url !== \"string\" ||\n typeof parsed.x !== \"number\" ||\n !Number.isFinite(parsed.x) ||\n typeof parsed.y !== \"number\" ||\n !Number.isFinite(parsed.y)\n ) {\n return null;\n }\n\n return {\n url: parsed.url,\n x: parsed.x,\n y: parsed.y,\n visible: parsed.visible !== false,\n };\n } catch {\n return null;\n }\n};\n\nconst persistCursorState = (x: number, y: number, visible: boolean) => {\n if (typeof localStorage === \"undefined\") {\n return;\n }\n\n try {\n const payload: PersistedCursorState = {\n url: window.location.href,\n x,\n y,\n visible,\n };\n localStorage.setItem(CURSOR_STORAGE_KEY, JSON.stringify(payload));\n } catch {\n // No-op: localStorage may be unavailable or blocked.\n }\n};\n\nconst setCursorPosition = (cursor: HTMLElement, x: number, y: number) => {\n cursor.style.left = `${x}px`;\n cursor.style.top = `${y}px`;\n};\n\nconst getCursorPosition = (cursor: HTMLElement): { x: number; y: number } => ({\n x: Number.parseFloat(cursor.style.left) || 0,\n y: Number.parseFloat(cursor.style.top) || 0,\n});\n\nconst setCursorVisibility = (cursor: HTMLElement, visible: boolean) => {\n cursor.style.opacity = visible ? \"1\" : \"0\";\n};\n\nexport const hideAgentCursor = (): void => {\n if (typeof document === \"undefined\" || typeof window === \"undefined\") {\n return;\n }\n\n const cursor = document.getElementById(AGENT_CURSOR_ID);\n if (!(cursor instanceof HTMLElement)) {\n return;\n }\n\n const { x, y } = getCursorPosition(cursor);\n setCursorVisibility(cursor, false);\n persistCursorState(x, y, false);\n};\n\nlet cursorHoverTrackingInitialized = false;\nconst initializeCursorHoverTracking = () => {\n if (cursorHoverTrackingInitialized) {\n return;\n }\n cursorHoverTrackingInitialized = true;\n\n document.addEventListener(\"mousemove\", (event) => {\n const cursor = document.getElementById(AGENT_CURSOR_ID);\n if (!(cursor instanceof HTMLElement)) {\n return;\n }\n\n if (cursor.style.opacity !== \"1\") {\n return;\n }\n\n const { x, y } = getCursorPosition(cursor);\n const pointerX = event.pageX;\n const pointerY = event.pageY;\n const distance = Math.hypot(pointerX - x, pointerY - y);\n\n if (distance <= CURSOR_HOVER_RADIUS_PX) {\n setCursorVisibility(cursor, false);\n persistCursorState(x, y, false);\n }\n });\n};\n\nconst applyStoredCursorStateForCurrentUrl = (cursor: HTMLElement) => {\n const stored = getPersistedCursorState();\n if (!stored || stored.url !== window.location.href) {\n return;\n }\n\n setCursorPosition(cursor, stored.x, stored.y);\n setCursorVisibility(cursor, stored.visible);\n};\n\nconst ensureCursor = (): HTMLElement => {\n const existing = document.getElementById(AGENT_CURSOR_ID);\n if (existing) {\n // Keep cursor color in sync with the current theme\n existing.style.background = COLORS.primary;\n initializeCursorHoverTracking();\n return existing as HTMLElement;\n }\n\n const cursor = document.createElement(\"div\");\n cursor.id = AGENT_CURSOR_ID;\n cursor.style.position = \"absolute\";\n cursor.style.left = \"0px\";\n cursor.style.top = \"0px\";\n cursor.style.opacity = \"0\";\n const width = 25;\n cursor.style.width = `${width}px`;\n cursor.style.height = `${width}px`;\n cursor.style.borderRadius = \"50%\";\n const baseColor = COLORS.primary;\n cursor.style.background = baseColor;\n const border = 25 * 16 / 100;\n cursor.style.border = `${border}px solid #ffffff`;\n cursor.style.boxShadow = \"0px 0px 10px rgba(0, 11, 26, 0.5)\";\n cursor.style.boxSizing = \"border-box\";\n cursor.style.zIndex = \"2147483647\";\n cursor.style.pointerEvents = \"none\";\n cursor.style.transform = \"translate(-50%, -50%)\";\n cursor.style.transition = `left ${CURSOR_MOVE_DURATION_MS}ms ${CURSOR_EASING}, top ${CURSOR_MOVE_DURATION_MS}ms ${CURSOR_EASING}, opacity 150ms ease-out`;\n document.body.appendChild(cursor);\n initializeCursorHoverTracking();\n applyStoredCursorStateForCurrentUrl(cursor);\n console.info(`[Autic] cursor created color=${baseColor} duration=${CURSOR_MOVE_DURATION_MS}ms`);\n return cursor;\n};\n\nconst moveCursor = async (x: number, y: number) => {\n const cursor = ensureCursor();\n setCursorPosition(cursor, x, y);\n setCursorVisibility(cursor, true);\n persistCursorState(x, y, true);\n await new Promise((resolve) => setTimeout(resolve, CURSOR_MOVE_DURATION_MS));\n};\n\nconst getElementCenter = (element: HTMLElement): { x: number; y: number } => {\n const rect = element.getBoundingClientRect();\n return {\n x: rect.left + window.scrollX + rect.width / 2,\n y: rect.top + window.scrollY + rect.height / 2,\n };\n};\n\nconst CONTAINS_SELECTOR_PATTERN = /^(.*?):contains\\((['\"])(.*?)\\2\\)\\s*$/;\n\nconst findElementBySelector = (selector: string): Element | null => {\n try {\n return document.querySelector(selector);\n } catch (error) {\n const containsMatch = selector.match(CONTAINS_SELECTOR_PATTERN);\n if (!containsMatch) {\n console.warn(`AuticBot selector invalid: ${selector}`, error);\n return null;\n }\n\n const baseSelector = containsMatch[1]?.trim() || \"*\";\n const expectedText = containsMatch[3]?.trim() || \"\";\n if (!expectedText) {\n console.warn(`AuticBot selector contains empty text: ${selector}`);\n return null;\n }\n\n try {\n const candidates = document.querySelectorAll(baseSelector);\n for (const candidate of candidates) {\n if (candidate.textContent?.includes(expectedText)) {\n return candidate;\n }\n }\n return null;\n } catch (fallbackError) {\n console.warn(`AuticBot selector fallback invalid: ${selector}`, fallbackError);\n return null;\n }\n }\n};\n\nconst resolveTarget = (call: InteractToolCall): ResolvedTarget | null => {\n if (call.selector) {\n const selected = findElementBySelector(call.selector);\n\n if (selected instanceof HTMLElement) {\n const center = getElementCenter(selected);\n return {\n element: selected,\n x: center.x,\n y: center.y,\n };\n }\n console.warn(`AuticBot interact: selector not found: ${call.selector}`);\n }\n\n if (typeof call.x === \"number\" && typeof call.y === \"number\") {\n return {\n x: call.x,\n y: call.y,\n };\n }\n\n console.warn(\"AuticBot interact: missing target selector or coordinates.\", call);\n return null;\n};\n\nconst dispatchMouseEvent = (\n element: HTMLElement,\n type: string,\n x: number,\n y: number,\n) => {\n element.dispatchEvent(\n new MouseEvent(type, {\n bubbles: true,\n cancelable: true,\n view: window,\n clientX: x - window.scrollX,\n clientY: y - window.scrollY,\n }),\n );\n};\n\nconst typeIntoElement = (element: HTMLElement, text: string) => {\n const tagName = element.tagName.toUpperCase();\n if (tagName === \"INPUT\" || tagName === \"TEXTAREA\") {\n (element as HTMLInputElement).focus();\n (element as HTMLInputElement).value = text;\n element.dispatchEvent(new Event(\"input\", { bubbles: true }));\n element.dispatchEvent(new Event(\"change\", { bubbles: true }));\n return;\n }\n\n if (element.isContentEditable) {\n element.focus();\n element.textContent = text;\n element.dispatchEvent(new Event(\"input\", { bubbles: true }));\n return;\n }\n\n console.warn(\n \"AuticBot interact: type action requires input, textarea, or contenteditable target.\",\n );\n};\n\nconst submitElement = (element: HTMLElement) => {\n if (element.tagName === \"FORM\") {\n (element as HTMLFormElement).requestSubmit();\n return;\n }\n\n if (element.tagName === \"BUTTON\" && (element as HTMLButtonElement).form) {\n (element as HTMLButtonElement).form?.requestSubmit();\n return;\n }\n\n const parentForm = element.closest(\"form\");\n if (parentForm) {\n parentForm.requestSubmit();\n return;\n }\n\n console.warn(\"AuticBot interact: submit action requires a form target.\");\n};\n\nconst slowScrollElementIntoView = async (element: HTMLElement): Promise<void> => {\n await slowScrollElementIntoViewWithMode(element, false);\n};\n\nconst slowScrollElementIntoViewWithMode = async (\n element: HTMLElement,\n forceCenter: boolean,\n): Promise<void> => {\n const rect = element.getBoundingClientRect();\n const viewportHeight = window.innerHeight;\n\n if (!forceCenter && !isRectOutsideViewport(rect, viewportHeight)) {\n return;\n }\n\n const maxScrollTop = Math.max(\n 0,\n Math.max(document.body.scrollHeight, document.documentElement.scrollHeight) - viewportHeight,\n );\n const targetY = computeCenteredScrollTop(\n window.scrollY,\n rect.top,\n rect.height,\n viewportHeight,\n maxScrollTop,\n );\n\n await animateWindowScrollTo(targetY, SCROLL_DURATION_MS);\n};\n\nconst executeScroll = async (call: ScrollToolCall) => {\n const selected = findElementBySelector(call.selector);\n if (!(selected instanceof HTMLElement)) {\n console.warn(`AuticBot scroll: selector not found: ${call.selector}`);\n return;\n }\n\n await slowScrollElementIntoViewWithMode(selected, true);\n const center = getElementCenter(selected);\n await moveCursor(center.x, center.y);\n};\n\nconst executeInteract = async (call: InteractToolCall) => {\n const target = resolveTarget(call);\n if (!target) {\n return;\n }\n\n if (call.action === \"click\" && target.element) {\n await slowScrollElementIntoView(target.element);\n const center = getElementCenter(target.element);\n target.x = center.x;\n target.y = center.y;\n }\n\n await moveCursor(target.x, target.y);\n\n if (call.action === \"move\") {\n return;\n }\n\n if (!target.element) {\n console.warn(\"AuticBot interact: target element not available for action.\", call.action);\n return;\n }\n\n if (call.action === \"click\") {\n dispatchMouseEvent(target.element, \"pointerdown\", target.x, target.y);\n dispatchMouseEvent(target.element, \"mousedown\", target.x, target.y);\n dispatchMouseEvent(target.element, \"pointerup\", target.x, target.y);\n dispatchMouseEvent(target.element, \"mouseup\", target.x, target.y);\n target.element.click();\n return;\n }\n\n if (call.action === \"type\") {\n typeIntoElement(target.element, call.text ?? \"\");\n return;\n }\n\n submitElement(target.element);\n};\n\nconst isSamePageNavigation = (targetUrl: string): boolean => {\n try {\n const current = new URL(window.location.href);\n const target = new URL(targetUrl);\n return current.origin === target.origin && current.pathname === target.pathname;\n } catch {\n return false;\n }\n};\n\n/**\n * Find the best matching link element for a target URL.\n * Supports exact href match, partial path/query/hash match,\n * and text-content match for framework <Link> components.\n */\nconst findMatchingLinkForTarget = (targetUrl: string): HTMLElement | null => {\n let parsedTarget: URL | null = null;\n try {\n parsedTarget = new URL(targetUrl, window.location.href);\n } catch {\n // will fall through to text-based matching\n }\n\n const allLinks = Array.from(\n document.querySelectorAll('a[href], [role=\"link\"][href], [data-href]'),\n ) as HTMLElement[];\n\n // 1. Exact href match\n for (const el of allLinks) {\n if (el instanceof HTMLAnchorElement && el.href === parsedTarget?.href) {\n return el;\n }\n }\n\n if (parsedTarget) {\n // 2. Match by pathname + search + hash (ignoring origin)\n for (const el of allLinks) {\n if (!(el instanceof HTMLAnchorElement)) continue;\n try {\n const elUrl = new URL(el.href, window.location.href);\n if (\n elUrl.pathname === parsedTarget.pathname &&\n elUrl.search === parsedTarget.search &&\n elUrl.hash === parsedTarget.hash\n ) {\n return el;\n }\n } catch {\n continue;\n }\n }\n\n // 3. Match by pathname only (query/hash may differ)\n for (const el of allLinks) {\n if (!(el instanceof HTMLAnchorElement)) continue;\n try {\n const elUrl = new URL(el.href, window.location.href);\n if (elUrl.pathname === parsedTarget.pathname) {\n return el;\n }\n } catch {\n continue;\n }\n }\n\n // 4. Partial href attribute match (covers relative paths, query strings)\n const rawUrl = targetUrl.replace(/^\\//, \"\");\n for (const el of allLinks) {\n const href = el.getAttribute(\"href\") || el.getAttribute(\"data-href\") || \"\";\n if (href && (href === targetUrl || href === rawUrl || href === `/${rawUrl}`)) {\n return el;\n }\n }\n }\n\n // 5. Text-content match (for framework <Link> or <button> navigations)\n const urlSegments = targetUrl\n .replace(/^https?:\\/\\/[^/]+/, \"\")\n .replace(/[?#].*$/, \"\")\n .split(\"/\")\n .filter(Boolean);\n const lastSegment = urlSegments[urlSegments.length - 1] || \"\";\n\n if (lastSegment) {\n // Also search query param values (e.g., ?tab=interact → \"interact\")\n let searchTerms = [lastSegment];\n if (parsedTarget) {\n for (const [, value] of parsedTarget.searchParams.entries()) {\n if (value) searchTerms.push(value);\n }\n if (parsedTarget.hash) {\n searchTerms.push(parsedTarget.hash.replace(/^#/, \"\"));\n }\n }\n searchTerms = searchTerms.map((t) => t.toLowerCase());\n\n // Look across all clickable elements\n const clickables = Array.from(\n document.querySelectorAll(\n 'a, button, [role=\"link\"], [role=\"tab\"], [role=\"button\"], [data-tab], [onclick]',\n ),\n ) as HTMLElement[];\n\n for (const el of clickables) {\n const text = (el.textContent || \"\").trim().toLowerCase();\n const ariaLabel = (el.getAttribute(\"aria-label\") || \"\").toLowerCase();\n const dataTab = (el.getAttribute(\"data-tab\") || \"\").toLowerCase();\n for (const term of searchTerms) {\n if (\n text === term ||\n ariaLabel === term ||\n dataTab === term ||\n text.includes(term)\n ) {\n return el;\n }\n }\n }\n }\n\n return null;\n};\n\nconst executeNavigate = async (call: NavigateToolCall): Promise<boolean> => {\n try {\n const targetUrl = call.url;\n let resolvedUrl: string;\n try {\n resolvedUrl = new URL(targetUrl, window.location.href).href;\n } catch {\n resolvedUrl = targetUrl;\n }\n\n const matchingElement = findMatchingLinkForTarget(targetUrl);\n\n if (matchingElement) {\n console.log(\"AuticBot navigate: clicking element\", resolvedUrl, matchingElement.tagName);\n await slowScrollElementIntoView(matchingElement);\n\n const center = getElementCenter(matchingElement);\n await moveCursor(center.x, center.y);\n\n matchingElement.dispatchEvent(new MouseEvent(\"pointerdown\", { bubbles: true, view: window }));\n matchingElement.dispatchEvent(new MouseEvent(\"mousedown\", { bubbles: true, view: window }));\n matchingElement.dispatchEvent(new MouseEvent(\"pointerup\", { bubbles: true, view: window }));\n matchingElement.dispatchEvent(new MouseEvent(\"mouseup\", { bubbles: true, view: window }));\n matchingElement.click();\n\n return !isSamePageNavigation(resolvedUrl);\n }\n\n // 6. Fallback: direct browser navigation (query param, hash, or full URL)\n console.log(\"AuticBot navigate: no matching element found, using direct navigation\", resolvedUrl);\n\n // Hash-only navigation\n try {\n const parsed = new URL(resolvedUrl);\n if (\n parsed.origin === window.location.origin &&\n parsed.pathname === window.location.pathname &&\n parsed.hash\n ) {\n window.location.hash = parsed.hash;\n return false;\n }\n } catch { /* continue */ }\n\n // Query-param or same-origin navigation via History API\n try {\n const parsed = new URL(resolvedUrl);\n if (parsed.origin === window.location.origin) {\n // Use pushState + popstate to trigger SPA routers\n const newPath = parsed.pathname + parsed.search + parsed.hash;\n window.history.pushState({}, \"\", newPath);\n window.dispatchEvent(new PopStateEvent(\"popstate\", { state: {} }));\n return false;\n }\n } catch { /* continue */ }\n\n // Cross-origin: full page navigation\n window.location.href = resolvedUrl;\n return true;\n } catch (error) {\n console.warn(\"AuticBot navigate: error\", call.url, error);\n return false;\n }\n};\n\nconst executeGetPageContext = async () => {\n const context = getPageContext();\n console.info(\n `[Autic] getPageContext tool executed links=${context.links.length} interactables=${context.interactables.length} summary_len=${context.summary.length}`,\n );\n};\n\nexport const executeToolCalls = async (toolCalls: AgentToolCall[]) => {\n for (const toolCall of toolCalls) {\n if (toolCall.tool === \"interact\") {\n await executeInteract(toolCall);\n continue;\n }\n\n if (toolCall.tool === \"scroll\") {\n await executeScroll(toolCall);\n continue;\n }\n\n if (toolCall.tool === \"getPageContext\") {\n await executeGetPageContext();\n continue;\n }\n\n if (toolCall.tool === \"navigate\") {\n const terminalNavigation = await executeNavigate(toolCall);\n if (terminalNavigation) {\n break;\n }\n }\n }\n};\n\n// ── Agent-mode tool execution (returns results) ─────────────────────\n\nexport type ToolCallWithId = AgentToolCall & {\n call_id: string;\n};\n\nexport interface ToolCallResult {\n call_id: string;\n result: string;\n}\n\n/**\n * Execute a single tool call and return a result string.\n * Used by the agent loop to feed results back into the LLM.\n */\nexport const executeSingleToolCall = async (\n call: ToolCallWithId,\n): Promise<ToolCallResult> => {\n const callId = call.call_id;\n try {\n if (call.tool === \"interact\") {\n await executeInteract(call);\n return {\n call_id: callId,\n result: `Etkileşim başarılı: ${call.action}`,\n };\n }\n\n if (call.tool === \"scroll\") {\n await executeScroll(call);\n return {\n call_id: callId,\n result: \"Öğeye kaydırma başarılı.\",\n };\n }\n\n if (call.tool === \"getPageContext\") {\n const context = getPageContext();\n return {\n call_id: callId,\n result: context.summary,\n };\n }\n\n if (call.tool === \"navigate\") {\n await executeNavigate(call);\n // Wait for navigation / SPA routing to settle\n await new Promise((resolve) => setTimeout(resolve, 1500));\n const context = getPageContext();\n return {\n call_id: callId,\n result: `Navigasyon tamamlandı. Şu anki sayfa: ${window.location.href}\\nSayfa bağlamı: ${context.summary}`,\n };\n }\n\n return { call_id: callId, result: \"Bilinmeyen araç.\" };\n } catch (error) {\n const msg = error instanceof Error ? error.message : String(error);\n console.warn(`[Autic] Tool execution error: ${call.tool}`, error);\n return { call_id: callId, result: `Hata: ${msg}` };\n }\n};\n\nconst restoreCursorFromStorageForCurrentUrl = () => {\n if (typeof document === \"undefined\" || typeof window === \"undefined\") {\n return;\n }\n\n const stored = getPersistedCursorState();\n if (!stored || stored.url !== window.location.href) {\n return;\n }\n\n ensureCursor();\n};\n\nif (typeof document !== \"undefined\") {\n if (document.readyState === \"loading\") {\n document.addEventListener(\"DOMContentLoaded\", restoreCursorFromStorageForCurrentUrl, {\n once: true,\n });\n } else {\n restoreCursorFromStorageForCurrentUrl();\n }\n}\n","import {\n savePendingAgentResume,\n clearPendingAgentResume,\n hideAgentCursor,\n type PendingAgentResume,\n} from \"../agent/tools\";\n\nexport type ChatRole = \"system\" | \"user\" | \"assistant\";\n\nexport interface ChatMessage {\n role: ChatRole;\n content: string;\n}\n\ninterface ApiErrorBody {\n detail?: string;\n error?: string;\n message?: string;\n}\n\ninterface SseEventPayload {\n type?: string;\n session_id?: string;\n user_text?: string;\n assistant_text?: string;\n delta?: string;\n audio?: string;\n format?: string;\n mime_type?: string;\n sample_rate?: number;\n error?: string;\n}\n\ninterface TtsWsEventPayload {\n type?: string;\n request_id?: string;\n seq?: number;\n audio?: string;\n format?: string;\n mime_type?: string;\n sample_rate?: number;\n error?: string;\n retryable?: boolean;\n last_seq?: number;\n}\n\ninterface SttWsEventPayload {\n type?: string;\n session_id?: string;\n seq?: number;\n text?: string;\n error?: string;\n retryable?: boolean;\n}\n\nexport type AudioStreamState = \"rendering\" | \"playing\" | \"done\" | \"fallback\";\nexport const TTS_WS_RETRY_DELAYS_MS = [250, 750, 1500];\n\nconst BULUT_AUDIO_STOP_EVENT = \"bulut:audio-stop\";\nconst activeAudioElements = new Set<HTMLAudioElement>();\nlet audioPlaybackGeneration = 0;\n\nconst normalizeBaseUrl = (baseUrl: string): string => {\n const trimmed = baseUrl.trim().replace(/\\/+$/, \"\");\n if (/^https?:\\/\\//i.test(trimmed)) {\n return trimmed;\n }\n // Treat host-only values like \"api.bulut.lu\" as HTTPS absolute URLs.\n return `https://${trimmed}`;\n};\nconst toWebSocketUrl = (baseUrl: string, path: string): string => {\n const normalized = normalizeBaseUrl(baseUrl);\n const url = new URL(normalized);\n url.protocol = url.protocol === \"https:\" ? \"wss:\" : \"ws:\";\n url.pathname = `${url.pathname.replace(/\\/$/, \"\")}${path}`;\n url.search = \"\";\n url.hash = \"\";\n return url.toString();\n};\n\nconst createRequestId = (): string => {\n if (typeof crypto !== \"undefined\" && \"randomUUID\" in crypto) {\n return crypto.randomUUID();\n }\n return `tts-${Date.now()}-${Math.random().toString(16).slice(2)}`;\n};\n\nexport const parseTtsWsEventPayload = (\n value: unknown,\n): TtsWsEventPayload | null => {\n try {\n if (typeof value !== \"string\") {\n return null;\n }\n return JSON.parse(value) as TtsWsEventPayload;\n } catch {\n return null;\n }\n};\n\nexport const parseSttWsEventPayload = (\n value: unknown,\n): SttWsEventPayload | null => {\n try {\n if (typeof value !== \"string\") {\n return null;\n }\n return JSON.parse(value) as SttWsEventPayload;\n } catch {\n return null;\n }\n};\n\nexport const shouldAcceptAudioSeq = (\n incomingSeq: number,\n highestSeqSeen: number,\n): boolean => incomingSeq > highestSeqSeen;\n\nexport const shouldFallbackToSse = (error: unknown): boolean => {\n if (typeof error === \"object\" && error !== null && \"retryable\" in error) {\n return Boolean((error as { retryable?: boolean }).retryable);\n }\n return true;\n};\n\nconst parseErrorBody = async (response: Response): Promise<string> => {\n try {\n const data = (await response.json()) as ApiErrorBody;\n const detail = data.detail;\n if (typeof detail === \"string\") return detail;\n if (detail && typeof detail === \"object\") return JSON.stringify(detail);\n return data.error || data.message || response.statusText;\n } catch {\n return response.statusText;\n }\n};\n\nconst sleep = (ms: number): Promise<void> =>\n new Promise((resolve) => {\n setTimeout(resolve, ms);\n });\n\nconst registerActiveAudioElement = (audioElement: HTMLAudioElement): void => {\n activeAudioElements.add(audioElement);\n};\n\nconst unregisterActiveAudioElement = (audioElement: HTMLAudioElement): void => {\n activeAudioElements.delete(audioElement);\n};\n\nconst wasPlaybackStoppedAfter = (generationAtStart: number): boolean =>\n audioPlaybackGeneration !== generationAtStart;\n\nexport const getAudioPlaybackGeneration = (): number => audioPlaybackGeneration;\n\nexport const stopActiveAudioPlayback = (): void => {\n audioPlaybackGeneration += 1;\n const active = Array.from(activeAudioElements);\n for (const audioElement of active) {\n try {\n audioElement.dispatchEvent(new Event(BULUT_AUDIO_STOP_EVENT));\n audioElement.pause();\n audioElement.removeAttribute(\"src\");\n audioElement.load();\n } catch {\n // Ignore playback stop errors.\n }\n }\n};\n\nexport const base64ToUint8Array = (base64: string): Uint8Array<ArrayBuffer> => {\n // Strip potential data URI prefix if present\n const cleanBase64 = base64.replace(/^data:audio\\/\\w+;base64,/, \"\");\n const binaryString = atob(cleanBase64);\n const bytes = new Uint8Array(binaryString.length) as Uint8Array<ArrayBuffer>;\n for (let i = 0; i < binaryString.length; i += 1) {\n bytes[i] = binaryString.charCodeAt(i);\n }\n return bytes;\n};\n\nconst blobToBase64 = async (blob: Blob): Promise<string> => {\n const bytes = new Uint8Array(await blob.arrayBuffer());\n const chunkSize = 0x8000;\n let binary = \"\";\n for (let i = 0; i < bytes.length; i += chunkSize) {\n binary += String.fromCharCode(...bytes.subarray(i, i + chunkSize));\n }\n return btoa(binary);\n};\n\nconst createWavHeader = (\n length: number,\n sampleRate: number = 16000,\n): Uint8Array<ArrayBuffer> => {\n const buffer = new ArrayBuffer(44);\n const view = new DataView(buffer);\n const channels = 1;\n\n // RIFF chunk descriptor\n view.setUint32(0, 0x52494646, false); // \"RIFF\"\n view.setUint32(4, 36 + length, true); // file length - 8\n view.setUint32(8, 0x57415645, false); // \"WAVE\"\n\n // fmt sub-chunk\n view.setUint32(12, 0x666d7420, false); // \"fmt \"\n view.setUint32(16, 16, true); // Subchunk1Size (16 for PCM)\n view.setUint16(20, 1, true); // AudioFormat (1 for PCM)\n view.setUint16(22, channels, true); // NumChannels\n view.setUint32(24, sampleRate, true); // SampleRate\n view.setUint32(28, sampleRate * channels * 2, true); // ByteRate\n view.setUint16(32, channels * 2, true); // BlockAlign\n view.setUint16(34, 16, true); // BitsPerSample\n\n // data sub-chunk\n view.setUint32(36, 0x64617461, false); // \"data\"\n view.setUint32(40, length, true); // Subchunk2Size\n\n return new Uint8Array(buffer) as Uint8Array<ArrayBuffer>;\n};\nconst waitForPlaybackEnd = async (\n audioElement: HTMLAudioElement,\n): Promise<void> => {\n if (audioElement.ended) {\n return;\n }\n\n await new Promise<void>((resolve, reject) => {\n const watchdog = window.setInterval(() => {\n if (!audioElement.ended) {\n console.info(\"[Bulut] playback watchdog: still playing...\");\n }\n }, 30000);\n\n const onEnded = () => {\n cleanup();\n resolve();\n };\n\n const onError = () => {\n cleanup();\n reject(new Error(\"Ses oynatma hatası oluştu.\"));\n };\n\n const onForcedStop = () => {\n cleanup();\n resolve();\n };\n\n const cleanup = () => {\n window.clearInterval(watchdog);\n audioElement.removeEventListener(\"ended\", onEnded);\n audioElement.removeEventListener(\"error\", onError);\n audioElement.removeEventListener(BULUT_AUDIO_STOP_EVENT, onForcedStop);\n };\n\n audioElement.addEventListener(\"ended\", onEnded);\n audioElement.addEventListener(\"error\", onError);\n audioElement.addEventListener(BULUT_AUDIO_STOP_EVENT, onForcedStop);\n });\n};\n\n\n\nconst playBufferedAudio = async (\n chunks: Uint8Array<ArrayBuffer>[],\n mimeType: string,\n sampleRate: number = 16000,\n onAudioStateChange?: (state: AudioStreamState) => void,\n): Promise<void> => {\n const playbackGeneration = getAudioPlaybackGeneration();\n if (chunks.length === 0) {\n onAudioStateChange?.(\"done\");\n return;\n }\n\n if (wasPlaybackStoppedAfter(playbackGeneration)) {\n onAudioStateChange?.(\"done\");\n return;\n }\n\n // Debug info\n const totalBytes = chunks.reduce((acc, c) => acc + c.byteLength, 0);\n console.log(`[Bulut] Playing buffered audio: ${chunks.length} chunks, ${totalBytes} bytes, type=${mimeType}`);\n\n onAudioStateChange?.(\"fallback\");\n\n const blobParts: ArrayBuffer[] = chunks.map((chunk) => {\n const copied = new Uint8Array(chunk.byteLength) as Uint8Array<ArrayBuffer>;\n copied.set(chunk);\n return copied.buffer;\n });\n\n // Verify magic numbers and detect MIME type\n let detectedMime = mimeType;\n if (chunks.length > 0 && chunks[0].length >= 4) {\n const header = Array.from(chunks[0].slice(0, 4))\n .map(b => b.toString(16).padStart(2, '0').toUpperCase())\n .join(' ');\n console.log(`[Bulut] Audio header (hex): ${header}`);\n\n // Magic number detection\n if (header.startsWith(\"49 44 33\")) { // ID3\n detectedMime = \"audio/mpeg\";\n } else if (header.startsWith(\"FF F3\") || header.startsWith(\"FF F2\")) { // MP3 Sync\n detectedMime = \"audio/mpeg\";\n } else if (header.startsWith(\"52 49 46 46\")) { // RIFF (WAV)\n detectedMime = \"audio/wav\";\n } else if (header.startsWith(\"1A 45 DF A3\")) { // EBML (WebM)\n detectedMime = \"audio/webm\";\n }\n }\n\n // Ensure valid MIME type\n // Ensure valid MIME type or wrap raw PCM\n let safeMimeType = detectedMime && detectedMime.includes(\"/\") ? detectedMime : \"audio/mpeg\";\n let finalBlobParts: BlobPart[] = blobParts;\n\n if (mimeType === \"audio/pcm\") {\n // Wrap raw PCM in WAV container\n const totalLength = chunks.reduce((acc, c) => acc + c.byteLength, 0);\n const header = createWavHeader(totalLength, sampleRate);\n finalBlobParts = [header.buffer, ...blobParts];\n safeMimeType = \"audio/wav\";\n console.log(`[Bulut] Wrapped raw PCM in WAV (rate=${sampleRate})`);\n }\n\n console.log(`[Bulut] Creating blob with type: ${safeMimeType} (original: ${mimeType})`);\n const blob = new Blob(finalBlobParts, { type: safeMimeType });\n\n const audioElement = new Audio();\n const objectUrl = URL.createObjectURL(blob);\n\n try {\n registerActiveAudioElement(audioElement);\n\n audioElement.preload = \"auto\";\n audioElement.autoplay = true;\n // Some browsers need this\n audioElement.setAttribute(\"playsinline\", \"true\");\n audioElement.src = objectUrl;\n\n if (wasPlaybackStoppedAfter(playbackGeneration)) {\n onAudioStateChange?.(\"done\");\n return;\n }\n\n await audioElement.play();\n onAudioStateChange?.(\"playing\");\n await waitForPlaybackEnd(audioElement);\n onAudioStateChange?.(\"done\");\n } catch (err) {\n console.error(`[Bulut] Playback failed: ${err}`, { mimeType: safeMimeType, size: blob.size });\n onAudioStateChange?.(\"done\"); // Signal done to unblock UI even on error\n throw err;\n } finally {\n unregisterActiveAudioElement(audioElement);\n audioElement.pause();\n audioElement.removeAttribute(\"src\");\n audioElement.load();\n URL.revokeObjectURL(objectUrl);\n }\n};\n\nexport interface StreamController {\n stop: () => void;\n done: Promise<void>;\n}\n\nexport const parseSseEventPayload = (eventBlock: string): SseEventPayload | null => {\n const dataLines = eventBlock\n .split(/\\r?\\n/)\n .map((line) => line.trim())\n .filter((line) => line.startsWith(\"data:\"))\n .map((line) => line.slice(5).trimStart());\n\n if (dataLines.length === 0) {\n return null;\n }\n\n const dataStr = dataLines.join(\"\\n\");\n if (dataStr === \"[DONE]\") {\n return { type: \"done\" };\n }\n\n try {\n return JSON.parse(dataStr) as SseEventPayload;\n } catch (error) {\n console.warn(\"Error parsing SSE chunk:\", error);\n return null;\n }\n};\n\nexport const isAudioSsePayload = (\n payload: SseEventPayload,\n): payload is SseEventPayload & { audio: string } =>\n typeof payload.audio === \"string\" &&\n (payload.type === undefined || payload.type === \"audio\");\n\n// ── Separated Endpoint Helpers ──────────────────────────────────────\n\nexport async function transcribeAudio(\n baseUrl: string,\n file: File,\n projectId: string,\n sessionId: string | null,\n language: string,\n onRequestSent?: () => void,\n): Promise<{ text: string; session_id: string }> {\n const url = `${normalizeBaseUrl(baseUrl)}/chat/stt`;\n const formData = new FormData();\n formData.append(\"file\", file);\n formData.append(\"project_id\", projectId);\n if (sessionId) formData.append(\"session_id\", sessionId);\n formData.append(\"language\", language);\n\n const responsePromise = fetch(url, { method: \"POST\", body: formData });\n onRequestSent?.();\n const response = await responsePromise;\n if (!response.ok) {\n throw new Error(await parseErrorBody(response));\n }\n return response.json();\n}\n\nexport interface SttWsResult {\n text: string;\n session_id: string;\n}\n\nexport interface SttWsEvents {\n onRequestSent?: () => void;\n onSessionId?: (sessionId: string) => void;\n onPartial?: (payload: { seq: number; text: string }) => void;\n}\n\nexport interface SttWsController {\n pushChunk: (chunk: Blob) => Promise<void>;\n stop: () => Promise<SttWsResult>;\n cancel: () => void;\n}\n\nexport const startSttWebSocketStream = (\n baseUrl: string,\n config: {\n projectId: string;\n sessionId: string | null;\n language?: string;\n mimeType?: string;\n },\n events: SttWsEvents = {},\n): SttWsController => {\n const wsUrl = toWebSocketUrl(baseUrl, \"/chat/stt/ws\");\n console.info(\"[Bulut] STT WS connecting to\", wsUrl);\n const socket = new WebSocket(wsUrl);\n let seq = 0;\n let finalText = \"\";\n let finalSessionId = config.sessionId || \"\";\n let stopped = false;\n let settled = false;\n // All chunk sends and the final stop are chained through sendQueue\n // so the \"stop\" message always follows all enqueued chunks.\n let sendQueue: Promise<void> = Promise.resolve();\n\n let resolveStart: (() => void) | null = null;\n let rejectStart: ((error: Error & { retryable?: boolean }) => void) | null = null;\n const startPromise = new Promise<void>((resolve, reject) => {\n resolveStart = resolve;\n rejectStart = reject;\n });\n\n let resolveDone: ((result: SttWsResult) => void) | null = null;\n let rejectDone: ((error: Error & { retryable?: boolean }) => void) | null = null;\n const donePromise = new Promise<SttWsResult>((resolve, reject) => {\n resolveDone = resolve;\n rejectDone = reject;\n });\n\n const rejectAll = (error: Error & { retryable?: boolean }) => {\n if (settled) return;\n settled = true;\n console.warn(\"[Bulut] STT WS rejected:\", error.message);\n rejectStart?.(error);\n rejectDone?.(error);\n };\n\n const resolveDoneIfPossible = () => {\n if (settled) return;\n if (!finalText.trim() || !finalSessionId) return;\n settled = true;\n resolveStart?.();\n resolveDone?.({\n text: finalText.trim(),\n session_id: finalSessionId,\n });\n };\n\n socket.onopen = () => {\n console.info(\"[Bulut] STT WS connected, sending start\");\n events.onRequestSent?.();\n socket.send(\n JSON.stringify({\n type: \"start\",\n project_id: config.projectId,\n session_id: config.sessionId || undefined,\n language: config.language || \"tr\",\n mime_type: config.mimeType || \"audio/webm\",\n }),\n );\n };\n\n socket.onmessage = (event) => {\n const payload = parseSttWsEventPayload(String(event.data));\n if (!payload) return;\n\n if (payload.type === \"start_ack\" && typeof payload.session_id === \"string\") {\n console.info(\"[Bulut] STT WS start_ack received, session:\", payload.session_id);\n finalSessionId = payload.session_id;\n events.onSessionId?.(payload.session_id);\n resolveStart?.();\n return;\n }\n\n if (payload.type === \"partial\" && typeof payload.text === \"string\") {\n events.onPartial?.({\n seq: typeof payload.seq === \"number\" ? payload.seq : 0,\n text: payload.text,\n });\n return;\n }\n\n if (payload.type === \"final\" && typeof payload.text === \"string\") {\n console.info(\"[Bulut] STT WS final text received:\", payload.text.slice(0, 80));\n finalText = payload.text;\n if (typeof payload.session_id === \"string\") {\n finalSessionId = payload.session_id;\n events.onSessionId?.(payload.session_id);\n }\n return;\n }\n\n if (payload.type === \"done\") {\n console.info(\"[Bulut] STT WS done\");\n resolveDoneIfPossible();\n socket.close();\n return;\n }\n\n if (payload.type === \"error\") {\n console.error(\"[Bulut] STT WS server error:\", payload.error);\n const err = buildError(payload.error || \"stt_ws_error\", payload.retryable !== false);\n rejectAll(err);\n socket.close();\n }\n };\n\n socket.onerror = (ev) => {\n console.error(\"[Bulut] STT WS transport error\", ev);\n rejectAll(buildError(\"stt_ws_transport_error\", true));\n };\n\n socket.onclose = (ev) => {\n console.info(\"[Bulut] STT WS closed code=%d reason=%s\", ev.code, ev.reason);\n if (settled) return;\n if (finalText && finalSessionId) {\n resolveDoneIfPossible();\n return;\n }\n rejectAll(buildError(\"stt_ws_closed_before_done\", true));\n };\n\n return {\n pushChunk: (chunk: Blob): Promise<void> => {\n if (stopped || chunk.size === 0) return Promise.resolve();\n // Chain the entire operation (wait for connection, base64-encode,\n // send) into sendQueue so that a later stop() is guaranteed to\n // follow all previously-enqueued chunks.\n sendQueue = sendQueue.then(async () => {\n if (stopped) return;\n await startPromise;\n if (stopped) return;\n const audio = await blobToBase64(chunk);\n seq += 1;\n if (stopped || socket.readyState !== WebSocket.OPEN) return;\n console.debug(\"[Bulut] STT WS sending chunk seq=%d size=%d\", seq, chunk.size);\n socket.send(JSON.stringify({ type: \"chunk\", seq, audio }));\n });\n return sendQueue;\n },\n stop: (): Promise<SttWsResult> => {\n console.info(\"[Bulut] STT WS stop requested, draining %d pending chunks\", seq);\n // Chain after all pending pushChunk operations so the server\n // always receives every chunk before the stop message.\n sendQueue = sendQueue.then(async () => {\n await startPromise;\n if (stopped) return;\n if (socket.readyState === WebSocket.OPEN) {\n console.info(\"[Bulut] STT WS sending stop after seq=%d\", seq);\n socket.send(JSON.stringify({ type: \"stop\" }));\n }\n });\n return donePromise;\n },\n cancel: () => {\n stopped = true;\n try {\n socket.close();\n } catch {\n // no-op\n }\n },\n };\n};\n\ninterface TtsCollectResult {\n chunks: Uint8Array<ArrayBuffer>[];\n mimeType: string;\n sampleRate: number;\n}\n\nconst buildError = (message: string, retryable: boolean = true): Error & { retryable: boolean } => {\n const error = new Error(message) as Error & { retryable: boolean };\n error.retryable = retryable;\n return error;\n};\n\nconst collectTtsViaSse = async (\n baseUrl: string,\n assistantText: string,\n voice: string,\n accessibilityMode: boolean,\n isStopped: () => boolean,\n setReader: (reader: ReadableStreamDefaultReader<Uint8Array> | undefined) => void,\n): Promise<TtsCollectResult> => {\n const ttsFormData = new FormData();\n ttsFormData.append(\"text\", assistantText);\n ttsFormData.append(\"voice\", voice);\n ttsFormData.append(\"accessibility_mode\", String(accessibilityMode));\n\n const ttsResponse = await fetch(`${normalizeBaseUrl(baseUrl)}/chat/tts`, {\n method: \"POST\",\n body: ttsFormData,\n });\n\n if (!ttsResponse.ok) {\n throw buildError(await parseErrorBody(ttsResponse), false);\n }\n\n const reader = ttsResponse.body?.getReader();\n if (!reader) {\n throw buildError(\"TTS response body is not readable\", false);\n }\n\n setReader(reader);\n\n const chunks: Uint8Array<ArrayBuffer>[] = [];\n let mimeType = \"audio/mpeg\";\n let sampleRate = 16000;\n const decoder = new TextDecoder();\n let buffer = \"\";\n\n while (true) {\n if (isStopped()) {\n break;\n }\n\n const { done, value } = await reader.read();\n if (done) {\n break;\n }\n\n buffer += decoder.decode(value, { stream: true });\n const blocks = buffer.split(/\\r?\\n\\r?\\n/);\n buffer = blocks.pop() || \"\";\n\n for (const block of blocks) {\n const payload = parseSseEventPayload(block);\n if (!payload) {\n continue;\n }\n\n if (isAudioSsePayload(payload)) {\n const format = payload.format || \"mp3\";\n mimeType = payload.mime_type || (format === \"webm\" ? \"audio/webm\" : \"audio/mpeg\");\n chunks.push(base64ToUint8Array(payload.audio));\n if (payload.sample_rate) {\n sampleRate = payload.sample_rate;\n }\n }\n }\n }\n\n reader.releaseLock();\n setReader(undefined);\n\n return { chunks, mimeType, sampleRate };\n};\n\nconst collectTtsViaWebSocket = async (\n baseUrl: string,\n assistantText: string,\n voice: string,\n accessibilityMode: boolean,\n isStopped: () => boolean,\n setSocket: (socket: WebSocket | null) => void,\n): Promise<TtsCollectResult> => {\n const wsUrl = toWebSocketUrl(baseUrl, \"/chat/tts/ws\");\n const requestId = createRequestId();\n const chunks: Uint8Array<ArrayBuffer>[] = [];\n let mimeType = \"audio/mpeg\";\n let sampleRate = 16000;\n let highestSeqSeen = 0;\n\n const connectOnce = (): Promise<void> =>\n new Promise((resolve, reject) => {\n if (isStopped()) {\n reject(buildError(\"stream_stopped\", false));\n return;\n }\n\n let done = false;\n let finalError: (Error & { retryable?: boolean }) | null = null;\n const socket = new WebSocket(wsUrl);\n setSocket(socket);\n\n const finalize = (\n mode: \"resolve\" | \"reject\",\n error?: Error & { retryable?: boolean },\n ) => {\n socket.onopen = null;\n socket.onmessage = null;\n socket.onerror = null;\n socket.onclose = null;\n setSocket(null);\n if (mode === \"resolve\") {\n resolve();\n return;\n }\n reject(error || buildError(\"tts_ws_closed\", true));\n };\n\n socket.onopen = () => {\n console.info(\n `[Bulut] TTS WS connected request_id=${requestId} resume_seq=${highestSeqSeen}`,\n );\n socket.send(\n JSON.stringify({\n type: \"start\",\n request_id: requestId,\n text: assistantText,\n voice,\n accessibility_mode: accessibilityMode,\n last_seq: highestSeqSeen,\n }),\n );\n };\n\n socket.onmessage = (event) => {\n const payload = parseTtsWsEventPayload(String(event.data));\n if (!payload) {\n console.warn(\"[Bulut] TTS WS invalid JSON payload\");\n return;\n }\n\n if (payload.type === \"audio\" && typeof payload.audio === \"string\") {\n const seq = typeof payload.seq === \"number\" ? payload.seq : 0;\n if (shouldAcceptAudioSeq(seq, highestSeqSeen)) {\n chunks.push(base64ToUint8Array(payload.audio));\n highestSeqSeen = seq;\n if (payload.mime_type) {\n mimeType = payload.mime_type;\n }\n if (typeof payload.sample_rate === \"number\") {\n sampleRate = payload.sample_rate;\n }\n } else {\n console.info(\n `[Bulut] TTS WS duplicate chunk ignored request_id=${requestId} seq=${seq} seen=${highestSeqSeen}`,\n );\n }\n\n if (socket.readyState === WebSocket.OPEN) {\n socket.send(\n JSON.stringify({\n type: \"ack\",\n request_id: requestId,\n last_seq: highestSeqSeen,\n }),\n );\n }\n return;\n }\n\n if (payload.type === \"done\") {\n const streamLastSeq =\n typeof payload.last_seq === \"number\" ? payload.last_seq : highestSeqSeen;\n if (streamLastSeq > highestSeqSeen) {\n finalError = buildError(\"tts_ws_sequence_gap\", true);\n done = false;\n socket.close();\n return;\n }\n done = true;\n socket.close();\n return;\n }\n\n if (payload.type === \"error\") {\n finalError = buildError(payload.error || \"tts_ws_error\", payload.retryable !== false);\n done = false;\n socket.close();\n }\n };\n\n socket.onerror = () => {\n if (!finalError) {\n finalError = buildError(\"tts_ws_transport_error\", true);\n }\n };\n\n socket.onclose = () => {\n if (isStopped()) {\n finalize(\"reject\", buildError(\"stream_stopped\", false));\n return;\n }\n if (done) {\n finalize(\"resolve\");\n return;\n }\n finalize(\"reject\", finalError || buildError(\"tts_ws_closed_before_done\", true));\n };\n });\n\n for (let attempt = 0; attempt <= TTS_WS_RETRY_DELAYS_MS.length; attempt += 1) {\n if (attempt > 0) {\n const delay = TTS_WS_RETRY_DELAYS_MS[attempt - 1];\n console.warn(\n `[Bulut] TTS WS retry attempt=${attempt} delay_ms=${delay} last_seq=${highestSeqSeen}`,\n );\n await sleep(delay);\n }\n\n try {\n await connectOnce();\n return { chunks, mimeType, sampleRate };\n } catch (error) {\n const retryable =\n shouldFallbackToSse(error);\n const message = error instanceof Error ? error.message : String(error);\n console.warn(\n `[Bulut] TTS WS attempt failed attempt=${attempt} retryable=${retryable} error=${message}`,\n );\n if (!retryable || attempt === TTS_WS_RETRY_DELAYS_MS.length) {\n throw error;\n }\n }\n }\n\n throw buildError(\"tts_ws_exhausted\", true);\n};\n\n// ── Agent-mode Types ────────────────────────────────────────────────\n\nexport interface AgentToolCallInfo {\n call_id: string;\n tool: string;\n args: Record<string, unknown>;\n}\n\nexport interface AgentVoiceChatEvents {\n onSttRequestSent?: () => void;\n onTranscription?: (data: {\n session_id: string;\n user_text: string;\n }) => void;\n onAssistantDelta?: (delta: string) => void;\n onAssistantDone?: (assistantText: string) => void;\n onAudioStateChange?: (state: AudioStreamState) => void;\n onError?: (error: string) => void;\n /** Called when the agent requests tool execution on the frontend. */\n onToolCalls?: (calls: AgentToolCallInfo[]) => void;\n /** Called after each tool has been executed with the result. */\n onToolResult?: (callId: string, toolName: string, result: string) => void;\n /** Called at the start of each agent iteration. */\n onIteration?: (iteration: number, maxIterations: number) => void;\n /** Called when the backend confirms / creates a session ID. */\n onSessionId?: (sessionId: string) => void;\n /**\n * Called when the agent emits a reply text followed by tool calls.\n * This text is spoken aloud before the tools run so the user hears\n * every piece of the conversation, not just the final reply.\n */\n onIntermediateReply?: (text: string) => void;\n}\n\n/**\n * Standalone TTS helper: synthesize + play a text snippet.\n * Uses WebSocket TTS with SSE fallback, same as the main stream functions.\n */\nexport const speakText = async (\n baseUrl: string,\n text: string,\n voice: string,\n accessibilityMode: boolean,\n onAudioStateChange?: (state: AudioStreamState) => void,\n): Promise<void> => {\n const trimmed = text.trim();\n if (!trimmed) return;\n const playbackGeneration = getAudioPlaybackGeneration();\n\n console.info(`[Bulut] speakText start (${trimmed.length} chars)`);\n onAudioStateChange?.(\"rendering\");\n let ttsResult: TtsCollectResult;\n\n const neverStopped = () => false;\n\n try {\n ttsResult = await collectTtsViaWebSocket(\n baseUrl, trimmed, voice, accessibilityMode,\n neverStopped,\n () => {},\n );\n } catch {\n ttsResult = await collectTtsViaSse(\n baseUrl, trimmed, voice, accessibilityMode,\n neverStopped,\n () => {},\n );\n }\n\n if (wasPlaybackStoppedAfter(playbackGeneration)) {\n onAudioStateChange?.(\"done\");\n return;\n }\n\n if (ttsResult.chunks.length > 0) {\n await playBufferedAudio(\n ttsResult.chunks, ttsResult.mimeType, ttsResult.sampleRate,\n onAudioStateChange,\n );\n } else {\n onAudioStateChange?.(\"done\");\n }\n};\n\n// ── Agent Voice Chat Stream (STT → Agent WS → TTS) ─────────────────\n\nexport const agentVoiceChatStream = (\n baseUrl: string,\n audioFile: File,\n projectId: string,\n sessionId: string | null,\n config: {\n model: string;\n voice: string;\n pageContext?: string;\n accessibilityMode?: boolean;\n },\n events: AgentVoiceChatEvents,\n executeTool: (call: AgentToolCallInfo) => Promise<{ call_id: string; result: string }>,\n): StreamController => {\n let isStopped = false;\n let activeSocket: WebSocket | null = null;\n let activeReader: ReadableStreamDefaultReader<Uint8Array> | undefined;\n let errorEmitted = false;\n\n const donePromise = new Promise<void>(async (resolve, reject) => {\n try {\n // ── 1. STT ────────────────────────────────────────────────\n if (isStopped) return resolve();\n const sttResult = await transcribeAudio(\n baseUrl,\n audioFile,\n projectId,\n sessionId,\n \"tr\",\n events.onSttRequestSent,\n );\n\n const currentSessionId = sttResult.session_id;\n let effectiveSessionId = currentSessionId;\n const userText = sttResult.text;\n\n events.onTranscription?.({\n session_id: currentSessionId,\n user_text: userText,\n });\n\n if (isStopped) return resolve();\n\n // ── 2. Agent loop via WebSocket ───────────────────────────\n const assistantText = await new Promise<string>((agentResolve, agentReject) => {\n if (isStopped) { agentResolve(\"\"); return; }\n\n const wsUrl = toWebSocketUrl(baseUrl, \"/chat/agent/ws\");\n const socket = new WebSocket(wsUrl);\n activeSocket = socket;\n\n let finalReply = \"\";\n let resolved = false;\n let accumulatedDelta = \"\";\n\n const finish = (reply: string) => {\n if (resolved) return;\n resolved = true;\n agentResolve(reply);\n };\n\n const fail = (error: Error) => {\n if (resolved) return;\n resolved = true;\n agentReject(error);\n };\n\n socket.onopen = () => {\n console.info(\"[Bulut] Agent WS connected\");\n socket.send(JSON.stringify({\n type: \"start\",\n project_id: projectId,\n session_id: currentSessionId,\n user_text: userText,\n model: config.model,\n page_context: config.pageContext,\n accessibility_mode: config.accessibilityMode,\n }));\n };\n\n socket.onmessage = async (event) => {\n let data: Record<string, unknown>;\n try {\n data = JSON.parse(String(event.data));\n } catch {\n console.warn(\"[Bulut] Agent WS invalid JSON\");\n return;\n }\n\n const msgType = data.type as string;\n\n if (msgType === \"session\" && typeof data.session_id === \"string\") {\n effectiveSessionId = data.session_id as string;\n events.onSessionId?.(effectiveSessionId);\n return;\n }\n\n if (msgType === \"iteration\") {\n events.onIteration?.(\n data.iteration as number,\n data.max_iterations as number,\n );\n return;\n }\n\n if (msgType === \"reply_delta\" && typeof data.delta === \"string\") {\n accumulatedDelta += data.delta;\n events.onAssistantDelta?.(data.delta);\n return;\n }\n\n if (msgType === \"tool_calls\" && Array.isArray(data.calls)) {\n const calls = data.calls as AgentToolCallInfo[];\n\n // Speak accumulated text before running tools\n if (accumulatedDelta.trim()) {\n events.onIntermediateReply?.(accumulatedDelta.trim());\n }\n accumulatedDelta = \"\";\n\n events.onToolCalls?.(calls);\n\n const results: { call_id: string; result: string }[] = [];\n for (const call of calls) {\n // Save resume state before navigate in case of full-page reload\n const isNavigate = call.tool === \"navigate\";\n if (isNavigate) {\n savePendingAgentResume({\n sessionId: effectiveSessionId,\n projectId,\n model: config.model,\n voice: config.voice,\n accessibilityMode: Boolean(config.accessibilityMode),\n pendingToolCalls: calls.map((c) => ({\n call_id: c.call_id,\n tool: c.tool,\n args: c.args,\n })),\n completedResults: [...results],\n });\n }\n\n const result = await executeTool(call);\n\n // If we reach here, no full-page reload happened\n if (isNavigate) {\n clearPendingAgentResume();\n }\n\n events.onToolResult?.(call.call_id, call.tool, result.result);\n results.push(result);\n }\n\n if (socket.readyState === WebSocket.OPEN) {\n socket.send(JSON.stringify({\n type: \"tool_results\",\n results,\n }));\n }\n return;\n }\n\n if (msgType === \"agent_done\") {\n finalReply = (data.final_reply as string) || \"\";\n events.onAssistantDone?.(finalReply);\n if (typeof data.session_id === \"string\") {\n events.onSessionId?.(data.session_id as string);\n }\n finish(finalReply);\n return;\n }\n\n if (msgType === \"error\") {\n const errMsg = (data.error as string) || \"Agent error\";\n errorEmitted = true;\n events.onError?.(errMsg);\n fail(new Error(errMsg));\n return;\n }\n };\n\n socket.onerror = () => {\n console.error(\"[Bulut] Agent WS error\");\n errorEmitted = true;\n events.onError?.(\"Agent WebSocket connection error\");\n fail(new Error(\"Agent WebSocket connection error\"));\n };\n\n socket.onclose = () => {\n console.info(\"[Bulut] Agent WS closed\");\n finish(finalReply);\n };\n });\n\n activeSocket = null;\n\n // ── 3. TTS ────────────────────────────────────────────────\n if (isStopped || !assistantText) {\n if (!isStopped) {\n hideAgentCursor();\n }\n return resolve();\n }\n\n console.info(\n `[Bulut] TTS start mode=agent voice=${config.voice}`,\n );\n\n events.onAudioStateChange?.(\"rendering\");\n let ttsResult: TtsCollectResult;\n\n try {\n ttsResult = await collectTtsViaWebSocket(\n baseUrl,\n assistantText,\n config.voice,\n Boolean(config.accessibilityMode),\n () => isStopped,\n (socket) => { activeSocket = socket; },\n );\n } catch (wsError) {\n if (isStopped) return resolve();\n console.warn(\n `[Bulut] TTS WS failed, falling back to SSE: ${wsError instanceof Error ? wsError.message : String(wsError)}`,\n );\n ttsResult = await collectTtsViaSse(\n baseUrl,\n assistantText,\n config.voice,\n Boolean(config.accessibilityMode),\n () => isStopped,\n (reader) => { activeReader = reader; },\n );\n }\n\n if (!isStopped && ttsResult.chunks.length > 0) {\n await playBufferedAudio(\n ttsResult.chunks,\n ttsResult.mimeType,\n ttsResult.sampleRate,\n events.onAudioStateChange,\n );\n } else {\n events.onAudioStateChange?.(\"done\");\n }\n\n if (!isStopped) {\n hideAgentCursor();\n }\n resolve();\n } catch (err) {\n // Only emit onError if it hasn't been emitted already by the WS handler\n if (!errorEmitted) {\n const msg = err instanceof Error ? err.message : String(err);\n events.onError?.(msg);\n }\n reject(err);\n } finally {\n activeReader?.cancel().catch(() => { });\n if (activeSocket && activeSocket.readyState <= WebSocket.OPEN) {\n activeSocket.close();\n }\n activeSocket = null;\n }\n });\n\n return {\n stop: () => {\n isStopped = true;\n stopActiveAudioPlayback();\n if (activeReader) {\n activeReader.cancel().catch(() => { });\n }\n if (activeSocket && activeSocket.readyState <= WebSocket.OPEN) {\n activeSocket.close();\n }\n },\n done: donePromise,\n };\n};\n\n// ── Agent Text Chat Stream (no STT, Agent WS → TTS) ────────────────\n\nexport const agentTextChatStream = (\n baseUrl: string,\n userText: string,\n projectId: string,\n sessionId: string | null,\n config: {\n model: string;\n voice: string;\n pageContext?: string;\n accessibilityMode?: boolean;\n },\n events: AgentVoiceChatEvents,\n executeTool: (call: AgentToolCallInfo) => Promise<{ call_id: string; result: string }>,\n): StreamController => {\n let isStopped = false;\n let activeSocket: WebSocket | null = null;\n let activeReader: ReadableStreamDefaultReader<Uint8Array> | undefined;\n let errorEmitted = false;\n\n const donePromise = new Promise<void>(async (resolve, reject) => {\n try {\n if (isStopped) return resolve();\n\n // ── 1. Agent loop via WebSocket ───────────────────────────\n const assistantText = await new Promise<string>((agentResolve, agentReject) => {\n if (isStopped) { agentResolve(\"\"); return; }\n\n const wsUrl = toWebSocketUrl(baseUrl, \"/chat/agent/ws\");\n const socket = new WebSocket(wsUrl);\n activeSocket = socket;\n\n let finalReply = \"\";\n let resolved = false;\n let effectiveSessionId = sessionId || \"\";\n let accumulatedDelta = \"\";\n\n const finish = (reply: string) => {\n if (resolved) return;\n resolved = true;\n agentResolve(reply);\n };\n\n const fail = (error: Error) => {\n if (resolved) return;\n resolved = true;\n agentReject(error);\n };\n\n socket.onopen = () => {\n socket.send(JSON.stringify({\n type: \"start\",\n project_id: projectId,\n session_id: sessionId,\n user_text: userText,\n model: config.model,\n page_context: config.pageContext,\n accessibility_mode: config.accessibilityMode,\n }));\n };\n\n socket.onmessage = async (event) => {\n let data: Record<string, unknown>;\n try {\n data = JSON.parse(String(event.data));\n } catch { return; }\n\n const msgType = data.type as string;\n\n if (msgType === \"session\" && typeof data.session_id === \"string\") {\n effectiveSessionId = data.session_id as string;\n events.onSessionId?.(effectiveSessionId);\n return;\n }\n\n if (msgType === \"iteration\") {\n events.onIteration?.(\n data.iteration as number,\n data.max_iterations as number,\n );\n return;\n }\n\n if (msgType === \"reply_delta\" && typeof data.delta === \"string\") {\n accumulatedDelta += data.delta;\n events.onAssistantDelta?.(data.delta);\n return;\n }\n\n if (msgType === \"tool_calls\" && Array.isArray(data.calls)) {\n const calls = data.calls as AgentToolCallInfo[];\n\n // Speak accumulated text before running tools\n if (accumulatedDelta.trim()) {\n events.onIntermediateReply?.(accumulatedDelta.trim());\n }\n accumulatedDelta = \"\";\n\n events.onToolCalls?.(calls);\n\n const results: { call_id: string; result: string }[] = [];\n for (const call of calls) {\n const isNavigate = call.tool === \"navigate\";\n if (isNavigate) {\n savePendingAgentResume({\n sessionId: effectiveSessionId,\n projectId,\n model: config.model,\n voice: config.voice,\n accessibilityMode: Boolean(config.accessibilityMode),\n pendingToolCalls: calls.map((c) => ({\n call_id: c.call_id,\n tool: c.tool,\n args: c.args,\n })),\n completedResults: [...results],\n });\n }\n\n const result = await executeTool(call);\n\n if (isNavigate) {\n clearPendingAgentResume();\n }\n\n events.onToolResult?.(call.call_id, call.tool, result.result);\n results.push(result);\n }\n\n if (socket.readyState === WebSocket.OPEN) {\n socket.send(JSON.stringify({\n type: \"tool_results\",\n results,\n }));\n }\n return;\n }\n\n if (msgType === \"agent_done\") {\n finalReply = (data.final_reply as string) || \"\";\n events.onAssistantDone?.(finalReply);\n if (typeof data.session_id === \"string\") {\n events.onSessionId?.(data.session_id as string);\n }\n finish(finalReply);\n return;\n }\n\n if (msgType === \"error\") {\n const errMsg = (data.error as string) || \"Agent error\";\n errorEmitted = true;\n events.onError?.(errMsg);\n fail(new Error(errMsg));\n return;\n }\n };\n\n socket.onerror = () => {\n errorEmitted = true;\n events.onError?.(\"Agent WebSocket error\");\n fail(new Error(\"Agent WebSocket error\"));\n };\n socket.onclose = () => finish(finalReply);\n });\n\n activeSocket = null;\n\n // ── 2. TTS ────────────────────────────────────────────────\n if (isStopped || !assistantText) {\n if (!isStopped) {\n hideAgentCursor();\n }\n return resolve();\n }\n\n events.onAudioStateChange?.(\"rendering\");\n let ttsResult: TtsCollectResult;\n\n try {\n ttsResult = await collectTtsViaWebSocket(\n baseUrl, assistantText, config.voice, Boolean(config.accessibilityMode),\n () => isStopped,\n (socket) => { activeSocket = socket; },\n );\n } catch (wsError) {\n if (isStopped) return resolve();\n ttsResult = await collectTtsViaSse(\n baseUrl, assistantText, config.voice, Boolean(config.accessibilityMode),\n () => isStopped,\n (reader) => { activeReader = reader; },\n );\n }\n\n if (!isStopped && ttsResult.chunks.length > 0) {\n await playBufferedAudio(\n ttsResult.chunks, ttsResult.mimeType, ttsResult.sampleRate,\n events.onAudioStateChange,\n );\n } else {\n events.onAudioStateChange?.(\"done\");\n }\n\n if (!isStopped) {\n hideAgentCursor();\n }\n resolve();\n } catch (err) {\n if (!errorEmitted) {\n const msg = err instanceof Error ? err.message : String(err);\n events.onError?.(msg);\n }\n reject(err);\n } finally {\n activeReader?.cancel().catch(() => { });\n if (activeSocket && activeSocket.readyState <= WebSocket.OPEN) {\n activeSocket.close();\n }\n activeSocket = null;\n }\n });\n\n return {\n stop: () => {\n isStopped = true;\n stopActiveAudioPlayback();\n if (activeReader) activeReader.cancel().catch(() => { });\n if (activeSocket && activeSocket.readyState <= WebSocket.OPEN) {\n activeSocket.close();\n }\n },\n done: donePromise,\n };\n};\n\n// ── Agent Resume Stream (after page navigation reload) ──────────────\n//\n// When a navigate tool causes a full-page reload, the agent WS is lost.\n// This function opens a new WS with {type: \"resume\"}, sends the\n// completed tool results (including the navigate result with the new\n// page context), and continues the agent loop from where it left off.\n\nexport const agentResumeStream = (\n baseUrl: string,\n resumeState: PendingAgentResume,\n pageContext: string,\n events: AgentVoiceChatEvents,\n executeTool: (call: AgentToolCallInfo) => Promise<{ call_id: string; result: string }>,\n): StreamController => {\n let isStopped = false;\n let activeSocket: WebSocket | null = null;\n let activeReader: ReadableStreamDefaultReader<Uint8Array> | undefined;\n let errorEmitted = false;\n\n // Build tool results for the calls that were pending when the page reloaded.\n // Navigate results include the new page context; other tools that couldn't\n // execute get a descriptive skip message.\n const allResults = [...resumeState.completedResults];\n for (const tc of resumeState.pendingToolCalls) {\n if (allResults.some((r) => r.call_id === tc.call_id)) continue;\n if (tc.tool === \"navigate\") {\n allResults.push({\n call_id: tc.call_id,\n result: `Navigasyon tamamlandı. Şu anki sayfa: ${typeof window !== \"undefined\" ? window.location.href : \"\"}\\nSayfa bağlamı: ${pageContext}`,\n });\n } else {\n allResults.push({\n call_id: tc.call_id,\n result: \"Sayfa yeniden yüklendi, bu araç çalıştırılamadı.\",\n });\n }\n }\n\n const donePromise = new Promise<void>(async (resolve, reject) => {\n try {\n if (isStopped) return resolve();\n\n let effectiveSessionId = resumeState.sessionId;\n\n const assistantText = await new Promise<string>((agentResolve, agentReject) => {\n if (isStopped) { agentResolve(\"\"); return; }\n\n const wsUrl = toWebSocketUrl(baseUrl, \"/chat/agent/ws\");\n const socket = new WebSocket(wsUrl);\n activeSocket = socket;\n\n let finalReply = \"\";\n let resolved = false;\n let accumulatedDelta = \"\";\n\n const finish = (reply: string) => {\n if (resolved) return;\n resolved = true;\n agentResolve(reply);\n };\n\n const fail = (error: Error) => {\n if (resolved) return;\n resolved = true;\n agentReject(error);\n };\n\n socket.onopen = () => {\n console.info(\"[Bulut] Agent WS resume connected\");\n socket.send(JSON.stringify({\n type: \"resume\",\n project_id: resumeState.projectId,\n session_id: resumeState.sessionId,\n model: resumeState.model,\n page_context: pageContext,\n accessibility_mode: resumeState.accessibilityMode,\n pending_tool_calls: resumeState.pendingToolCalls,\n tool_results: allResults,\n }));\n };\n\n socket.onmessage = async (event) => {\n let data: Record<string, unknown>;\n try {\n data = JSON.parse(String(event.data));\n } catch { return; }\n\n const msgType = data.type as string;\n\n if (msgType === \"session\" && typeof data.session_id === \"string\") {\n effectiveSessionId = data.session_id as string;\n events.onSessionId?.(effectiveSessionId);\n return;\n }\n\n if (msgType === \"iteration\") {\n events.onIteration?.(\n data.iteration as number,\n data.max_iterations as number,\n );\n return;\n }\n\n if (msgType === \"reply_delta\" && typeof data.delta === \"string\") {\n accumulatedDelta += data.delta;\n events.onAssistantDelta?.(data.delta);\n return;\n }\n\n if (msgType === \"tool_calls\" && Array.isArray(data.calls)) {\n const calls = data.calls as AgentToolCallInfo[];\n\n // Speak accumulated text before running tools\n if (accumulatedDelta.trim()) {\n events.onIntermediateReply?.(accumulatedDelta.trim());\n }\n accumulatedDelta = \"\";\n\n events.onToolCalls?.(calls);\n\n const results: { call_id: string; result: string }[] = [];\n for (const call of calls) {\n const isNavigate = call.tool === \"navigate\";\n if (isNavigate) {\n savePendingAgentResume({\n sessionId: effectiveSessionId,\n projectId: resumeState.projectId,\n model: resumeState.model,\n voice: resumeState.voice,\n accessibilityMode: resumeState.accessibilityMode,\n pendingToolCalls: calls.map((c) => ({\n call_id: c.call_id,\n tool: c.tool,\n args: c.args,\n })),\n completedResults: [...results],\n });\n }\n\n const result = await executeTool(call);\n\n if (isNavigate) {\n clearPendingAgentResume();\n }\n\n events.onToolResult?.(call.call_id, call.tool, result.result);\n results.push(result);\n }\n\n if (socket.readyState === WebSocket.OPEN) {\n socket.send(JSON.stringify({ type: \"tool_results\", results }));\n }\n return;\n }\n\n if (msgType === \"agent_done\") {\n finalReply = (data.final_reply as string) || \"\";\n events.onAssistantDone?.(finalReply);\n if (typeof data.session_id === \"string\") {\n events.onSessionId?.(data.session_id as string);\n }\n finish(finalReply);\n return;\n }\n\n if (msgType === \"error\") {\n const errMsg = (data.error as string) || \"Agent error\";\n errorEmitted = true;\n events.onError?.(errMsg);\n fail(new Error(errMsg));\n return;\n }\n };\n\n socket.onerror = () => {\n errorEmitted = true;\n events.onError?.(\"Agent WebSocket error\");\n fail(new Error(\"Agent WebSocket error\"));\n };\n\n socket.onclose = () => finish(finalReply);\n });\n\n activeSocket = null;\n\n // ── TTS ────────────────────────────────────────────────\n if (isStopped || !assistantText) {\n if (!isStopped) {\n hideAgentCursor();\n }\n return resolve();\n }\n\n console.info(`[Bulut] TTS start mode=resume voice=${resumeState.voice}`);\n events.onAudioStateChange?.(\"rendering\");\n let ttsResult: TtsCollectResult;\n\n try {\n ttsResult = await collectTtsViaWebSocket(\n baseUrl, assistantText, resumeState.voice, Boolean(resumeState.accessibilityMode),\n () => isStopped,\n (socket) => { activeSocket = socket; },\n );\n } catch (wsError) {\n if (isStopped) return resolve();\n console.warn(\n `[Bulut] TTS WS failed, falling back to SSE: ${wsError instanceof Error ? wsError.message : String(wsError)}`,\n );\n ttsResult = await collectTtsViaSse(\n baseUrl, assistantText, resumeState.voice, Boolean(resumeState.accessibilityMode),\n () => isStopped,\n (reader) => { activeReader = reader; },\n );\n }\n\n if (!isStopped && ttsResult.chunks.length > 0) {\n await playBufferedAudio(\n ttsResult.chunks, ttsResult.mimeType, ttsResult.sampleRate,\n events.onAudioStateChange,\n );\n } else {\n events.onAudioStateChange?.(\"done\");\n }\n\n if (!isStopped) {\n hideAgentCursor();\n }\n resolve();\n } catch (err) {\n if (!errorEmitted) {\n const msg = err instanceof Error ? err.message : String(err);\n events.onError?.(msg);\n }\n reject(err);\n } finally {\n activeReader?.cancel().catch(() => { });\n if (activeSocket && activeSocket.readyState <= WebSocket.OPEN) {\n activeSocket.close();\n }\n activeSocket = null;\n }\n });\n\n return {\n stop: () => {\n isStopped = true;\n stopActiveAudioPlayback();\n if (activeReader) activeReader.cancel().catch(() => { });\n if (activeSocket && activeSocket.readyState <= WebSocket.OPEN) {\n activeSocket.close();\n }\n },\n done: donePromise,\n };\n};\n","import {\n completedSfxUrl,\n sentSfxUrl,\n thinkingSfxUrl,\n toolCallSfxUrl,\n} from \"../assets\";\n\nexport type SfxName = \"sent\" | \"thinking\" | \"toolCall\" | \"completed\";\n\nconst SFX_SOURCES: Record<SfxName, string> = {\n sent: sentSfxUrl,\n thinking: thinkingSfxUrl,\n toolCall: toolCallSfxUrl,\n completed: completedSfxUrl,\n};\n\nclass SfxManager {\n private queue: SfxName[] = [];\n private active = false;\n\n private playNow(name: SfxName): Promise<void> {\n return new Promise((resolve) => {\n if (typeof window === \"undefined\") {\n resolve();\n return;\n }\n\n const audio = new Audio(SFX_SOURCES[name]);\n audio.preload = \"auto\";\n\n let settled = false;\n const finalize = () => {\n if (settled) return;\n settled = true;\n audio.onended = null;\n audio.onerror = null;\n resolve();\n };\n\n audio.onended = finalize;\n audio.onerror = finalize;\n void audio.play().catch(() => finalize());\n });\n }\n\n private async drain(): Promise<void> {\n if (this.active) return;\n this.active = true;\n try {\n while (this.queue.length > 0) {\n const next = this.queue.shift();\n if (!next) continue;\n await this.playNow(next);\n }\n } finally {\n this.active = false;\n }\n }\n\n playCue(name: SfxName): void {\n if (typeof window === \"undefined\") return;\n this.queue.push(name);\n if (!this.active) {\n void this.drain();\n }\n }\n}\n\nconst sfxManager = new SfxManager();\n\nexport const playCue = (name: SfxName): void => {\n sfxManager.playCue(name);\n};\n\n","export default \"data:audio/mpeg;base64,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ciUlhGEjSloik0pFDiOCQk7CwkpfJTEhxVU13/NeLKirBnlTQsVMNkxBTUUzLjk5LjWqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqgABlZauxJiAl8OtGJtCUOXLbCYWJSp4mI7hkhQQtAm46D7OEuRPTCPY90Qp2BvbF9eSSLUC24sytUy5EiD4uHKLLq6isqsdOqI2D5KKhCNDRcouomkdOB4ugPmURCIhkZKLoG4Tq7rf/dXdbmxRFTiSaiaSaSZw4XQHzJMKREDoyMEaBticLutzYyuquv7q0qurq6ukl2HsoiERDIyUXQThOF3/+rJsNHxRj/XTZKlJ5k4ANeHGTRgGMwAAAaQAAAAgAAA0gAAABMNjKKxUsWXUBw0LCv0AyFRYW1pMgsJDMcYEltcEbDEBSri82XaTiygI8gmpKTiyxUVWKiweNCrP6xRsCios3F2VCwr//9uKijf//8WFakxBTUUzLjk5LjWqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqo=\"","export default \"data:audio/mpeg;base64,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qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqr/+rJsOxMAD/AAAGkAAAAIAAANIAAAAQAAAaQAAAAgAAA0gAAABExBTUUzLjk5LjWqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqkxBTUUzLjk5LjWqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqo=\"","export default \"data:audio/mpeg;base64,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qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqo=\"","export default \"data:audio/mpeg;base64,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\"","import { useEffect, useLayoutEffect, useRef, useState } from \"preact/hooks\";\nimport type { JSX } from \"preact\";\nimport type { BulutRuntimeConfig } from \"../index\";\nimport {\n agentTextChatStream,\n agentVoiceChatStream,\n agentResumeStream,\n startSttWebSocketStream,\n stopActiveAudioPlayback,\n speakText,\n type AudioStreamState,\n type StreamController,\n type AgentToolCallInfo,\n type SttWsController,\n} from \"../api/client\";\nimport {\n executeSingleToolCall,\n parseAgentResponse,\n getPendingAgentResume,\n clearPendingAgentResume,\n type ToolCallWithId,\n} from \"../agent/tools\";\nimport { getPageContext } from \"../agent/context\";\nimport {\n WINDOW_WIDTH,\n WINDOW_HEIGHT,\n POSITION_BOTTOM,\n POSITION_RIGHT,\n COLORS,\n TRANSITIONS,\n BORDER_RADIUS,\n SHADOW,\n} from \"../styles/constants\";\nimport {\n closeIconContent,\n microphoneIconContent,\n stopIconContent,\n restartIconContent,\n logoContent,\n} from \"../assets\";\nimport { StreamingJsonParser } from \"../utils/streamingJson\";\nimport { playCue, type SfxName } from \"../audio/sfxManager\";\n\nimport { SvgIcon } from \"./SvgIcon\";\n\nexport interface ChatWindowHandle {\n startRecording: () => void;\n cancelRecording: () => void;\n stopTask: () => void;\n}\n\ninterface ChatWindowProps {\n onClose: () => void;\n config: BulutRuntimeConfig;\n accessibilityMode?: boolean;\n onAccessibilityToggle?: () => void;\n hidden?: boolean;\n actionsRef?: { current: ChatWindowHandle | null };\n onRecordingChange?: (recording: boolean) => void;\n onBusyChange?: (busy: boolean) => void;\n onPreviewChange?: (text: string | null) => void;\n}\n\ninterface Message {\n id: number;\n text: string;\n isUser: boolean;\n /** \"message\" (default) | \"tool\" for tool call indicators */\n type?: \"message\" | \"tool\";\n}\n\ntype RecordingMode = \"vad\" | \"press\";\n\ntype StorageLike = {\n removeItem: (key: string) => void;\n};\n\nconst STORAGE_KEY = \"bulut_chat_history\";\nconst TIMESTAMP_KEY = \"bulut_chat_timestamp\";\nconst SESSION_ID_KEY = \"bulut_session_id\";\nconst TTL_MS = 5 * 60 * 1000;\nconst VAD_THRESHOLD = 0.06;\nconst SILENCE_DURATION_MS = 500;\nexport const HOLD_THRESHOLD_MS = 250;\n\nconst STATUS_LABELS = {\n ready: \"Hazır\",\n loading: \"Yükleniyor\",\n listening: \"Dinliyor\",\n transcribing: \"Metne dönüştürülüyor\",\n thinking: \"Düşünüyor\",\n playingAudio: \"Ses oynatılıyor\",\n runningTools: \"Araç çalıştırılıyor\",\n} as const;\n\nexport const getGreetingText = (agentName: string): string =>\n `Merhaba, ben ${agentName}. Bu web sayfasında neler yapalım?`;\n\nexport interface StatusFlags {\n isBusy: boolean;\n isRecording: boolean;\n isTranscribing: boolean;\n isThinking: boolean;\n isRenderingAudio: boolean;\n isPlayingAudio: boolean;\n isRunningTools: boolean;\n}\n\nexport const resolveStatusText = (flags: StatusFlags): string => {\n if (flags.isRecording) return STATUS_LABELS.listening;\n if (flags.isRunningTools) return STATUS_LABELS.runningTools;\n if (flags.isPlayingAudio) return STATUS_LABELS.playingAudio;\n if (flags.isThinking) return STATUS_LABELS.thinking;\n if (flags.isTranscribing) return STATUS_LABELS.transcribing;\n if (flags.isBusy) return STATUS_LABELS.loading;\n return STATUS_LABELS.ready;\n};\n\nexport const hasActiveStatus = (\n flags: StatusFlags,\n statusOverride: string | null,\n): boolean =>\n Boolean(\n statusOverride\n || flags.isBusy\n || flags.isRecording\n || flags.isTranscribing\n || flags.isThinking\n || flags.isRenderingAudio\n || flags.isPlayingAudio\n || flags.isRunningTools,\n );\n\nexport const formatDurationMs = (durationMs: number): string => {\n const totalSeconds = Math.max(0, Math.floor(durationMs / 1000));\n const minutes = Math.floor(totalSeconds / 60)\n .toString()\n .padStart(2, \"0\");\n const seconds = (totalSeconds % 60).toString().padStart(2, \"0\");\n return `${minutes}:${seconds}`;\n};\n\nexport const classifyMicGesture = (\n durationMs: number,\n thresholdMs: number = HOLD_THRESHOLD_MS,\n): \"tap\" | \"hold\" => (durationMs >= thresholdMs ? \"hold\" : \"tap\");\n\nexport const createInitialMessages = (agentName: string): Message[] => [\n {\n id: 1,\n text: getGreetingText(agentName),\n isUser: false,\n },\n];\n\nexport const clearPersistedChatState = (storage: StorageLike | null): void => {\n if (!storage) {\n return;\n }\n\n storage.removeItem(STORAGE_KEY);\n storage.removeItem(TIMESTAMP_KEY);\n storage.removeItem(SESSION_ID_KEY);\n};\n\nexport const scrollElementToBottom = (\n element: { scrollTop: number; scrollHeight: number } | null,\n): void => {\n if (!element) {\n return;\n }\n\n element.scrollTop = element.scrollHeight;\n};\n\nconst normalizeError = (error: unknown) => {\n if (error instanceof Error) {\n return error.message;\n }\n return \"Bilinmeyen hata\";\n};\n\nconst getNextMessageId = (messages: Message[]): number => {\n const maxId = messages.reduce((acc, message) => Math.max(acc, message.id), 0);\n return maxId + 1;\n};\n\nexport interface AssistantPayloadResolution {\n displayText: string;\n toolCalls: ReturnType<typeof parseAgentResponse>[\"toolCalls\"];\n}\n\nexport const resolveAssistantPayload = (\n assistantText: string,\n): AssistantPayloadResolution => {\n const parsed = parseAgentResponse(assistantText);\n return {\n displayText: parsed.reply || assistantText,\n toolCalls: parsed.toolCalls,\n };\n};\n\nexport const shouldAutoListenAfterAudio = (\n accessibilityMode: boolean,\n isRecording: boolean,\n isBusy: boolean,\n): boolean => accessibilityMode && !isRecording && !isBusy;\n\nexport const ChatWindow = ({\n onClose,\n config,\n accessibilityMode = false,\n onAccessibilityToggle,\n hidden = false,\n actionsRef,\n onRecordingChange,\n onBusyChange,\n onPreviewChange,\n}: ChatWindowProps) => {\n const [messages, setMessages] = useState<Message[]>(() => {\n if (typeof localStorage !== \"undefined\") {\n const saved = localStorage.getItem(STORAGE_KEY);\n const timestamp = localStorage.getItem(TIMESTAMP_KEY);\n\n if (saved && timestamp) {\n const timePassed = Date.now() - parseInt(timestamp, 10);\n if (timePassed < TTL_MS) {\n try {\n return JSON.parse(saved) as Message[];\n } catch {\n // Ignore parse error and continue with default.\n }\n } else {\n clearPersistedChatState(localStorage);\n }\n }\n }\n\n return createInitialMessages(config.agentName);\n });\n\n const [isBusy, setIsBusy] = useState(false);\n const [isRecording, setIsRecording] = useState(false);\n const [isTranscribing, setIsTranscribing] = useState(false);\n const [isThinking, setIsThinking] = useState(false);\n const [isRenderingAudio, setIsRenderingAudio] = useState(false);\n const [isPlayingAudio, setIsPlayingAudio] = useState(false);\n const [isRunningTools, setIsRunningTools] = useState(false);\n const [recordingDurationMs, setRecordingDurationMs] = useState(0);\n const [statusOverride, setStatusOverride] = useState<string | null>(null);\n const statusFlags: StatusFlags = {\n isBusy,\n isRecording,\n isTranscribing,\n isThinking,\n isRenderingAudio,\n isPlayingAudio,\n isRunningTools,\n };\n const resolvedStatusText = resolveStatusText(statusFlags);\n const showStatus = hasActiveStatus(statusFlags, statusOverride);\n const statusText = showStatus ? (statusOverride ?? resolvedStatusText) : STATUS_LABELS.ready;\n\n const isBusyRef = useRef(isBusy);\n const isRecordingRef = useRef(isRecording);\n\n const nextMessageIdRef = useRef(getNextMessageId(messages));\n const recorderRef = useRef<MediaRecorder | null>(null);\n const streamRef = useRef<MediaStream | null>(null);\n const audioChunksRef = useRef<BlobPart[]>([]);\n const activeStreamControllerRef = useRef<StreamController | null>(null);\n const sessionIdRef = useRef<string | null>(\n typeof localStorage !== \"undefined\"\n ? (() => {\n const ts = localStorage.getItem(TIMESTAMP_KEY);\n if (ts && Date.now() - parseInt(ts, 10) < TTL_MS) {\n return localStorage.getItem(SESSION_ID_KEY);\n }\n return null;\n })()\n : null,\n );\n\n const silenceStartRef = useRef<number | null>(null);\n const vadIntervalRef = useRef<number | null>(null);\n const audioContextRef = useRef<AudioContext | null>(null);\n const sourceRef = useRef<MediaStreamAudioSourceNode | null>(null);\n\n const discardNextRecordingRef = useRef(false);\n\n const micPressStartRef = useRef<number | null>(null);\n const micHoldTimeoutRef = useRef<number | null>(null);\n const micHoldTriggeredRef = useRef(false);\n const recordingModeRef = useRef<RecordingMode | null>(null);\n const pendingStopAfterStartRef = useRef(false);\n const startRecordingPendingRef = useRef(false);\n\n const assistantMessageIdRef = useRef<number | null>(null);\n const assistantTextBufferRef = useRef(\"\");\n const transcriptionReceivedRef = useRef(false);\n const assistantDoneReceivedRef = useRef(false);\n\n const recordingStartedAtRef = useRef<number | null>(null);\n const recordingTimerIntervalRef = useRef<number | null>(null);\n\n const messagesContainerRef = useRef<HTMLDivElement | null>(null);\n const messagesContentRef = useRef<HTMLDivElement | null>(null);\n\n const pendingUserTextRef = useRef<string | null>(null);\n const pendingAssistantTextRef = useRef<string>(\"\");\n const streamingJsonParserRef = useRef<StreamingJsonParser | null>(null);\n const awaitingAssistantResponseRef = useRef(false);\n const activeSttWsRef = useRef<SttWsController | null>(null);\n const liveTranscriptionMessageIdRef = useRef<number | null>(null);\n const liveTranscriptionTextRef = useRef(\"\");\n const autoListenSuppressedRef = useRef(false);\n const requestEpochRef = useRef(0);\n const sttSendCuePlayedRef = useRef(false);\n\n useEffect(() => {\n isBusyRef.current = isBusy;\n }, [isBusy]);\n\n useEffect(() => {\n isRecordingRef.current = isRecording;\n }, [isRecording]);\n\n // Report state changes to parent\n useEffect(() => { onRecordingChange?.(isRecording); }, [isRecording]);\n useEffect(() => { onBusyChange?.(isBusy); }, [isBusy]);\n\n // Derive and report preview text to parent\n useEffect(() => {\n if (!onPreviewChange) return;\n if (isRecording) {\n onPreviewChange(STATUS_LABELS.listening);\n return;\n }\n // When audio is rendering/playing, show the actual message text\n if (isRenderingAudio || isPlayingAudio) {\n const lastAssistant = [...messages].reverse().find(m => !m.isUser && m.type !== \"tool\");\n onPreviewChange(lastAssistant?.text ?? getGreetingText(config.agentName));\n return;\n }\n if (showStatus) {\n const st = statusOverride ?? resolveStatusText({\n isBusy,\n isRecording,\n isTranscribing,\n isThinking,\n isRenderingAudio,\n isPlayingAudio,\n isRunningTools,\n });\n onPreviewChange(st);\n return;\n }\n // Show last assistant message (or greeting)\n const lastAssistant = [...messages].reverse().find(m => !m.isUser && m.type !== \"tool\");\n onPreviewChange(lastAssistant?.text ?? getGreetingText(config.agentName));\n }, [\n isRecording,\n isBusy,\n isTranscribing,\n isThinking,\n isRunningTools,\n isPlayingAudio,\n isRenderingAudio,\n statusOverride,\n showStatus,\n messages,\n ]);\n\n const playSfx = (name: SfxName) => {\n playCue(name);\n };\n\n const beginRequestEpoch = () => {\n requestEpochRef.current += 1;\n return requestEpochRef.current;\n };\n\n const invalidateRequestEpoch = () => {\n requestEpochRef.current += 1;\n };\n\n const isCurrentRequestEpoch = (epoch: number): boolean =>\n requestEpochRef.current === epoch;\n\n const playSttSentCueOnce = () => {\n if (sttSendCuePlayedRef.current) {\n return;\n }\n sttSendCuePlayedRef.current = true;\n playSfx(\"sent\");\n };\n\n useEffect(() => {\n if (typeof localStorage !== \"undefined\") {\n localStorage.setItem(STORAGE_KEY, JSON.stringify(messages));\n localStorage.setItem(TIMESTAMP_KEY, Date.now().toString());\n }\n }, [messages]);\n\n const scrollMessagesToBottom = () => {\n scrollElementToBottom(messagesContainerRef.current);\n };\n\n useLayoutEffect(() => {\n scrollMessagesToBottom();\n }, [messages, statusText, isBusy, isRecording]);\n\n useEffect(() => {\n const content = messagesContentRef.current;\n if (!content || typeof ResizeObserver === \"undefined\") {\n return;\n }\n\n const observer = new ResizeObserver(() => {\n scrollMessagesToBottom();\n });\n\n observer.observe(content);\n return () => observer.disconnect();\n }, []);\n\n const stopRecordingTimer = () => {\n if (recordingTimerIntervalRef.current !== null) {\n window.clearInterval(recordingTimerIntervalRef.current);\n recordingTimerIntervalRef.current = null;\n }\n recordingStartedAtRef.current = null;\n };\n\n const startRecordingTimer = () => {\n stopRecordingTimer();\n recordingStartedAtRef.current = Date.now();\n setRecordingDurationMs(0);\n\n recordingTimerIntervalRef.current = window.setInterval(() => {\n const startedAt = recordingStartedAtRef.current;\n if (startedAt === null) {\n setRecordingDurationMs(0);\n return;\n }\n setRecordingDurationMs(Date.now() - startedAt);\n }, 200);\n };\n\n const resetProcessingFlags = () => {\n setIsTranscribing(false);\n setIsThinking(false);\n setIsRenderingAudio(false);\n setIsPlayingAudio(false);\n setIsRunningTools(false);\n setStatusOverride(null);\n assistantMessageIdRef.current = null;\n assistantTextBufferRef.current = \"\";\n transcriptionReceivedRef.current = false;\n assistantDoneReceivedRef.current = false;\n awaitingAssistantResponseRef.current = false;\n pendingUserTextRef.current = null;\n pendingAssistantTextRef.current = \"\";\n };\n\n const clearMicHoldTimeout = () => {\n if (micHoldTimeoutRef.current !== null) {\n window.clearTimeout(micHoldTimeoutRef.current);\n micHoldTimeoutRef.current = null;\n }\n };\n\n const cleanupVAD = () => {\n if (vadIntervalRef.current !== null) {\n clearInterval(vadIntervalRef.current);\n vadIntervalRef.current = null;\n }\n\n if (sourceRef.current) {\n sourceRef.current.disconnect();\n sourceRef.current = null;\n }\n\n if (audioContextRef.current) {\n audioContextRef.current.close().catch(() => {});\n audioContextRef.current = null;\n }\n\n silenceStartRef.current = null;\n };\n\n const stopStreamTracks = () => {\n if (!streamRef.current) {\n return;\n }\n\n streamRef.current.getTracks().forEach((track) => track.stop());\n streamRef.current = null;\n };\n\n const stopActiveStream = () => {\n if (!activeStreamControllerRef.current) {\n return;\n }\n\n activeStreamControllerRef.current.stop();\n activeStreamControllerRef.current = null;\n };\n\n const cancelActiveSttWs = () => {\n const activeSttWs = activeSttWsRef.current;\n activeSttWsRef.current = null;\n activeSttWs?.cancel();\n liveTranscriptionMessageIdRef.current = null;\n liveTranscriptionTextRef.current = \"\";\n };\n\n useEffect(\n () => () => {\n invalidateRequestEpoch();\n clearMicHoldTimeout();\n pendingStopAfterStartRef.current = false;\n\n stopActiveStream();\n stopActiveAudioPlayback();\n cancelActiveSttWs();\n cleanupVAD();\n stopStreamTracks();\n stopRecordingTimer();\n\n const recorder = recorderRef.current;\n if (recorder) {\n recorder.ondataavailable = null;\n recorder.onstop = null;\n recorder.onerror = null;\n if (recorder.state !== \"inactive\") {\n recorder.stop();\n }\n recorderRef.current = null;\n }\n\n cancelActiveSttWs();\n },\n [],\n );\n\n // ── Resume agent loop after full-page navigation ────────────────\n useEffect(() => {\n const resumeState = getPendingAgentResume();\n if (!resumeState) return;\n\n clearPendingAgentResume();\n console.info(\"[Bulut] Resuming agent after navigation\");\n\n // Restore session ID from resume state\n if (resumeState.sessionId) {\n sessionIdRef.current = resumeState.sessionId;\n if (typeof localStorage !== \"undefined\") {\n localStorage.setItem(SESSION_ID_KEY, resumeState.sessionId);\n }\n }\n\n const requestEpoch = beginRequestEpoch();\n setIsBusy(true);\n setIsRunningTools(true);\n setStatusOverride(STATUS_LABELS.thinking);\n\n const freshPageContext = getPageContext().summary;\n\n const resumeToolExec = async (\n call: AgentToolCallInfo,\n ): Promise<{ call_id: string; result: string }> => {\n const toolCall: ToolCallWithId = {\n tool: call.tool as \"navigate\" | \"getPageContext\" | \"interact\" | \"scroll\",\n call_id: call.call_id,\n ...call.args,\n } as ToolCallWithId;\n return executeSingleToolCall(toolCall);\n };\n\n const controller = agentResumeStream(\n config.backendBaseUrl,\n resumeState,\n freshPageContext,\n {\n onSessionId: (sid) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n if (sid && sid !== sessionIdRef.current) {\n sessionIdRef.current = sid;\n if (typeof localStorage !== \"undefined\") {\n localStorage.setItem(SESSION_ID_KEY, sid);\n }\n }\n },\n onAssistantDelta: (delta) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n setIsRunningTools(false);\n setIsThinking(true);\n setStatusOverride(null);\n\n pendingAssistantTextRef.current += delta;\n\n if (assistantMessageIdRef.current === null) {\n assistantMessageIdRef.current = appendMessage(\n pendingAssistantTextRef.current,\n false,\n );\n } else {\n updateMessageText(\n assistantMessageIdRef.current,\n pendingAssistantTextRef.current,\n );\n }\n },\n onAssistantDone: (assistantText) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n playSfx(\"completed\");\n setStatusOverride(null);\n setIsThinking(false);\n setIsRenderingAudio(true);\n\n const finalDisplayText =\n assistantText || pendingAssistantTextRef.current;\n pendingAssistantTextRef.current = finalDisplayText;\n\n if (assistantMessageIdRef.current !== null) {\n updateMessageText(\n assistantMessageIdRef.current,\n finalDisplayText,\n );\n } else {\n assistantMessageIdRef.current = appendMessage(\n finalDisplayText,\n false,\n );\n }\n },\n onIntermediateReply: (text) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n void speakText(\n config.backendBaseUrl, text, config.voice,\n accessibilityMode, (state) => handleAudioStateChange(state, requestEpoch),\n ).catch((err) => console.warn(\"[Bulut] intermediate TTS failed\", err));\n },\n onToolCalls: (calls) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n if (calls.length > 0) {\n playSfx(\"toolCall\");\n }\n setIsRunningTools(true);\n setStatusOverride(STATUS_LABELS.runningTools);\n\n for (const call of calls) {\n const toolLabel =\n call.tool === \"navigate\"\n ? `Sayfaya gidiliyor: ${call.args.url ?? \"\"}`\n : call.tool === \"getPageContext\"\n ? \"Sayfa bağlamı alınıyor…\"\n : call.tool === \"interact\"\n ? `Etkileşim: ${call.args.action ?? \"\"}`\n : call.tool === \"scroll\"\n ? \"Kaydırılıyor…\"\n : call.tool;\n\n appendMessage(`${toolLabel}`, false);\n setMessages((prev) => {\n const last = prev[prev.length - 1];\n if (last && !last.isUser) {\n return [\n ...prev.slice(0, -1),\n { ...last, type: \"tool\" as const },\n ];\n }\n return prev;\n });\n }\n\n assistantMessageIdRef.current = null;\n pendingAssistantTextRef.current = \"\";\n },\n onToolResult: () => {},\n onIteration: () => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n playSfx(\"thinking\");\n setIsThinking(true);\n setStatusOverride(STATUS_LABELS.thinking);\n },\n onAudioStateChange: (state) => {\n handleAudioStateChange(state, requestEpoch);\n },\n onError: (err) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n setStatusOverride(null);\n appendMessage(`Hata: ${err}`, false);\n },\n },\n resumeToolExec,\n );\n\n activeStreamControllerRef.current = controller;\n\n controller.done\n .catch(() => {})\n .finally(() => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n setIsBusy(false);\n setIsRunningTools(false);\n setIsThinking(false);\n setIsRenderingAudio(false);\n setIsPlayingAudio(false);\n setStatusOverride(null);\n pendingAssistantTextRef.current = \"\";\n assistantMessageIdRef.current = null;\n activeStreamControllerRef.current = null;\n\n if (\n !autoListenSuppressedRef.current &&\n shouldAutoListenAfterAudio(\n accessibilityMode,\n isRecordingRef.current,\n isBusyRef.current,\n )\n ) {\n void startRecording(\"vad\");\n }\n });\n }, []); // eslint-disable-line react-hooks/exhaustive-deps\n\n const appendMessage = (text: string, isUser: boolean): number => {\n const id = nextMessageIdRef.current++;\n setMessages((previous) => [\n ...previous,\n {\n id,\n text,\n isUser,\n },\n ]);\n return id;\n };\n\n const updateMessageText = (id: number, text: string) => {\n setMessages((previous) =>\n previous.map((message) =>\n message.id === id ? { ...message, text } : message,\n ),\n );\n };\n\n const upsertLiveUserTranscription = (text: string) => {\n const normalized = text.trim();\n if (!normalized) {\n return;\n }\n liveTranscriptionTextRef.current = normalized;\n if (liveTranscriptionMessageIdRef.current === null) {\n liveTranscriptionMessageIdRef.current = appendMessage(normalized, true);\n return;\n }\n updateMessageText(liveTranscriptionMessageIdRef.current, normalized);\n };\n\n const clearLiveUserTranscriptionState = () => {\n liveTranscriptionMessageIdRef.current = null;\n liveTranscriptionTextRef.current = \"\";\n };\n\n const handleAudioStateChange = (state: AudioStreamState, requestEpoch?: number) => {\n if (typeof requestEpoch === \"number\" && !isCurrentRequestEpoch(requestEpoch)) {\n return;\n }\n\n if (state === \"rendering\") {\n setIsRenderingAudio(true);\n setIsPlayingAudio(false);\n return;\n }\n\n if (state === \"playing\") {\n setIsRenderingAudio(false);\n setIsPlayingAudio(true);\n return;\n }\n\n if (state === \"fallback\") {\n setIsRenderingAudio(true);\n setIsPlayingAudio(false);\n return;\n }\n\n if (state === \"done\") {\n setIsRenderingAudio(false);\n setIsPlayingAudio(false);\n return;\n }\n\n setIsRenderingAudio(false);\n setIsPlayingAudio(false);\n };\n\n const finalizeStreamCycle = (requestEpoch?: number) => {\n if (typeof requestEpoch === \"number\" && !isCurrentRequestEpoch(requestEpoch)) {\n return;\n }\n\n awaitingAssistantResponseRef.current = false;\n setStatusOverride(null);\n setIsBusy(false);\n setIsTranscribing(false);\n setIsThinking(false);\n setIsRenderingAudio(false);\n setIsPlayingAudio(false);\n setIsRunningTools(false);\n pendingUserTextRef.current = null;\n pendingAssistantTextRef.current = \"\";\n assistantMessageIdRef.current = null;\n if (activeStreamControllerRef.current) {\n activeStreamControllerRef.current = null;\n }\n if (\n !autoListenSuppressedRef.current &&\n shouldAutoListenAfterAudio(\n accessibilityMode,\n isRecordingRef.current,\n isBusyRef.current,\n )\n ) {\n console.info(\"[Bulut] chat-window auto-listen trigger after stream completion\");\n void startRecording(\"vad\");\n }\n };\n\n const runAgentForUserText = async (userText: string) => {\n if (!config.projectId) {\n appendMessage(\"Hata: Project ID yapılandırılmamış.\", false);\n return;\n }\n\n const normalizedUserText = userText.trim();\n if (!normalizedUserText) {\n appendMessage(\"Ses kaydı metne dönüştürülemedi. Lütfen tekrar deneyin.\", false);\n return;\n }\n\n const requestEpoch = beginRequestEpoch();\n setIsBusy(true);\n setIsTranscribing(false);\n setIsThinking(true);\n setIsRenderingAudio(false);\n setIsPlayingAudio(false);\n setIsRunningTools(false);\n setStatusOverride(STATUS_LABELS.thinking);\n awaitingAssistantResponseRef.current = true;\n\n try {\n pendingUserTextRef.current = normalizedUserText;\n upsertLiveUserTranscription(normalizedUserText);\n clearLiveUserTranscriptionState();\n\n stopActiveStream();\n const pageContext = getPageContext().summary;\n\n const handleToolExecution = async (\n call: AgentToolCallInfo,\n ): Promise<{ call_id: string; result: string }> => {\n const toolCall: ToolCallWithId = {\n tool: call.tool as\n | \"navigate\"\n | \"getPageContext\"\n | \"interact\"\n | \"scroll\",\n call_id: call.call_id,\n ...call.args,\n } as ToolCallWithId;\n return executeSingleToolCall(toolCall);\n };\n\n const controller = agentTextChatStream(\n config.backendBaseUrl,\n normalizedUserText,\n config.projectId,\n sessionIdRef.current,\n {\n model: config.model,\n voice: config.voice,\n pageContext,\n accessibilityMode,\n },\n {\n onSessionId: (sid) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n if (sid && sid !== sessionIdRef.current) {\n sessionIdRef.current = sid;\n if (typeof localStorage !== \"undefined\") {\n localStorage.setItem(SESSION_ID_KEY, sid);\n }\n }\n },\n onAssistantDelta: (delta) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n setIsTranscribing(false);\n setIsThinking(true);\n setIsRunningTools(false);\n if (awaitingAssistantResponseRef.current) {\n awaitingAssistantResponseRef.current = false;\n setStatusOverride(null);\n }\n\n pendingAssistantTextRef.current += delta;\n\n if (assistantMessageIdRef.current === null) {\n assistantMessageIdRef.current = appendMessage(\n pendingAssistantTextRef.current,\n false,\n );\n } else {\n updateMessageText(\n assistantMessageIdRef.current,\n pendingAssistantTextRef.current,\n );\n }\n },\n onAssistantDone: (assistantText) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n playSfx(\"completed\");\n awaitingAssistantResponseRef.current = false;\n setStatusOverride(null);\n setIsThinking(false);\n setIsRenderingAudio(true);\n\n const finalDisplayText = assistantText || pendingAssistantTextRef.current;\n pendingAssistantTextRef.current = finalDisplayText;\n\n if (assistantMessageIdRef.current !== null) {\n updateMessageText(\n assistantMessageIdRef.current,\n finalDisplayText,\n );\n } else {\n assistantMessageIdRef.current = appendMessage(\n finalDisplayText,\n false,\n );\n }\n },\n onIntermediateReply: (text) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n void speakText(\n config.backendBaseUrl, text, config.voice,\n accessibilityMode, (state) => handleAudioStateChange(state, requestEpoch),\n ).catch((err) => console.warn(\"[Bulut] intermediate TTS failed\", err));\n },\n onToolCalls: (calls) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n if (calls.length > 0) {\n playSfx(\"toolCall\");\n }\n setIsRunningTools(true);\n setStatusOverride(STATUS_LABELS.runningTools);\n\n for (const call of calls) {\n const toolLabel =\n call.tool === \"navigate\"\n ? `Sayfaya gidiliyor: ${call.args.url ?? \"\"}`\n : call.tool === \"getPageContext\"\n ? \"Sayfa bağlamı alınıyor…\"\n : call.tool === \"interact\"\n ? `Etkileşim: ${call.args.action ?? \"\"}`\n : call.tool === \"scroll\"\n ? \"Kaydırılıyor…\"\n : call.tool;\n\n appendMessage(`${toolLabel}`, false);\n setMessages((prev) => {\n const last = prev[prev.length - 1];\n if (last && !last.isUser) {\n return [\n ...prev.slice(0, -1),\n { ...last, type: \"tool\" as const },\n ];\n }\n return prev;\n });\n }\n\n assistantMessageIdRef.current = null;\n pendingAssistantTextRef.current = \"\";\n },\n onToolResult: () => {},\n onIteration: () => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n playSfx(\"thinking\");\n setIsThinking(true);\n setStatusOverride(STATUS_LABELS.thinking);\n },\n onAudioStateChange: (state) => {\n handleAudioStateChange(state, requestEpoch);\n },\n onError: (err) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n awaitingAssistantResponseRef.current = false;\n setStatusOverride(null);\n appendMessage(`Hata: ${err}`, false);\n },\n },\n handleToolExecution,\n );\n\n activeStreamControllerRef.current = controller;\n await controller.done;\n } catch (error) {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n awaitingAssistantResponseRef.current = false;\n setStatusOverride(null);\n if (error instanceof Error) {\n appendMessage(`Hata: ${error.message}`, false);\n }\n } finally {\n finalizeStreamCycle(requestEpoch);\n }\n };\n\n const handleAudioBlob = async (blob: Blob) => {\n if (!config.projectId) {\n appendMessage(\"Hata: Project ID yapılandırılmamış.\", false);\n return;\n }\n\n const requestEpoch = beginRequestEpoch();\n setIsBusy(true);\n setIsTranscribing(true);\n setIsThinking(false);\n setIsRenderingAudio(false);\n setIsPlayingAudio(false);\n setIsRunningTools(false);\n resetProcessingFlags(); // Start fresh\n setStatusOverride(STATUS_LABELS.thinking);\n awaitingAssistantResponseRef.current = true;\n\n try {\n const fileType = blob.type || \"audio/webm\";\n const extension = fileType.includes(\"ogg\")\n ? \"ogg\"\n : fileType.includes(\"wav\")\n ? \"wav\"\n : fileType.includes(\"mpeg\") || fileType.includes(\"mp3\")\n ? \"mp3\"\n : \"webm\";\n const file = new File([blob], `voice-input.${extension}`, {\n type: fileType,\n });\n\n stopActiveStream();\n\n const pageContext = getPageContext().summary;\n\n // Helper: bridge an AgentToolCallInfo to a ToolCallWithId\n const handleToolExecution = async (\n call: AgentToolCallInfo,\n ): Promise<{ call_id: string; result: string }> => {\n const toolCall: ToolCallWithId = {\n tool: call.tool as\n | \"navigate\"\n | \"getPageContext\"\n | \"interact\"\n | \"scroll\",\n call_id: call.call_id,\n ...call.args,\n } as ToolCallWithId;\n return executeSingleToolCall(toolCall);\n };\n\n const controller = agentVoiceChatStream(\n config.backendBaseUrl,\n file,\n config.projectId,\n sessionIdRef.current,\n {\n model: config.model,\n voice: config.voice,\n pageContext,\n accessibilityMode,\n },\n {\n onSttRequestSent: () => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n playSttSentCueOnce();\n },\n onTranscription: (data) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n if (data.session_id && data.session_id !== sessionIdRef.current) {\n sessionIdRef.current = data.session_id;\n if (typeof localStorage !== \"undefined\") {\n localStorage.setItem(SESSION_ID_KEY, data.session_id);\n }\n }\n\n const normalized = data.user_text.trim();\n if (normalized) {\n const previousUserText = pendingUserTextRef.current;\n pendingUserTextRef.current = normalized;\n if (liveTranscriptionMessageIdRef.current !== null) {\n updateMessageText(liveTranscriptionMessageIdRef.current, normalized);\n clearLiveUserTranscriptionState();\n } else if (previousUserText !== normalized) {\n appendMessage(normalized, true);\n }\n }\n\n setIsTranscribing(false);\n setIsThinking(true);\n setStatusOverride(STATUS_LABELS.thinking);\n },\n onSessionId: (sid) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n if (sid && sid !== sessionIdRef.current) {\n sessionIdRef.current = sid;\n if (typeof localStorage !== \"undefined\") {\n localStorage.setItem(SESSION_ID_KEY, sid);\n }\n }\n },\n onAssistantDelta: (delta) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n setIsTranscribing(false);\n setIsThinking(true);\n setIsRunningTools(false);\n if (awaitingAssistantResponseRef.current) {\n awaitingAssistantResponseRef.current = false;\n setStatusOverride(null);\n }\n\n // Agent returns plain text (not JSON), stream it directly\n pendingAssistantTextRef.current += delta;\n\n if (assistantMessageIdRef.current === null) {\n assistantMessageIdRef.current = appendMessage(\n pendingAssistantTextRef.current,\n false,\n );\n } else {\n updateMessageText(\n assistantMessageIdRef.current,\n pendingAssistantTextRef.current,\n );\n }\n },\n onAssistantDone: (assistantText) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n playSfx(\"completed\");\n awaitingAssistantResponseRef.current = false;\n setStatusOverride(null);\n setIsThinking(false);\n setIsRenderingAudio(true);\n\n const finalDisplayText =\n assistantText || pendingAssistantTextRef.current;\n\n streamingJsonParserRef.current = null;\n pendingAssistantTextRef.current = finalDisplayText;\n\n if (assistantMessageIdRef.current !== null) {\n updateMessageText(\n assistantMessageIdRef.current,\n finalDisplayText,\n );\n } else {\n assistantMessageIdRef.current = appendMessage(\n finalDisplayText,\n false,\n );\n }\n },\n onIntermediateReply: (text) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n void speakText(\n config.backendBaseUrl, text, config.voice,\n accessibilityMode, (state) => handleAudioStateChange(state, requestEpoch),\n ).catch((err) => console.warn(\"[Bulut] intermediate TTS failed\", err));\n },\n onToolCalls: (calls) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n if (calls.length > 0) {\n playSfx(\"toolCall\");\n }\n setIsRunningTools(true);\n setStatusOverride(STATUS_LABELS.runningTools);\n\n // Show each tool call as a small indicator message\n for (const call of calls) {\n const toolLabel =\n call.tool === \"navigate\"\n ? `Sayfaya gidiliyor: ${call.args.url ?? \"\"}`\n : call.tool === \"getPageContext\"\n ? \"Sayfa bağlamı alınıyor…\"\n : call.tool === \"interact\"\n ? `Etkileşim: ${call.args.action ?? \"\"}`\n : call.tool === \"scroll\"\n ? \"Kaydırılıyor…\"\n : call.tool;\n\n appendMessage(`${toolLabel}`, false);\n // Mark the tool message\n setMessages((prev) => {\n const last = prev[prev.length - 1];\n if (last && !last.isUser) {\n return [\n ...prev.slice(0, -1),\n { ...last, type: \"tool\" as const },\n ];\n }\n return prev;\n });\n }\n\n // Reset assistant message ref so next reply gets a new bubble\n assistantMessageIdRef.current = null;\n pendingAssistantTextRef.current = \"\";\n },\n onToolResult: (_callId, _toolName, _result) => {\n // Tool result sent back to agent automatically.\n // Could display detailed result here if needed.\n },\n onIteration: (_iteration, _maxIterations) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n // Agent started a new reasoning iteration\n playSfx(\"thinking\");\n setIsThinking(true);\n setStatusOverride(STATUS_LABELS.thinking);\n },\n onAudioStateChange: (state) => {\n handleAudioStateChange(state, requestEpoch);\n },\n onError: (err) => {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n awaitingAssistantResponseRef.current = false;\n setStatusOverride(null);\n appendMessage(`Hata: ${err}`, false);\n },\n },\n handleToolExecution,\n );\n\n activeStreamControllerRef.current = controller;\n await controller.done;\n\n // Safety: Ensure messages are flushed if not already\n // (e.g. if audio 'done' event didn't fire for some reason or there was no audio)\n /* if (pendingUserTextRef.current || pendingAssistantTextRef.current) {\n // flushPendingMessages(); // Removed as we stream now\n } */\n } catch (error) {\n if (!isCurrentRequestEpoch(requestEpoch)) return;\n // Error already shown via onError callback — don't duplicate\n awaitingAssistantResponseRef.current = false;\n setStatusOverride(null);\n } finally {\n finalizeStreamCycle(requestEpoch);\n }\n };\n\n const stopRecording = (options?: { discard?: boolean }) => {\n const recorder = recorderRef.current;\n if (!recorder || recorder.state === \"inactive\") {\n return;\n }\n\n if (options?.discard) {\n discardNextRecordingRef.current = true;\n }\n\n cleanupVAD();\n recorder.stop();\n };\n\n const setupVAD = (stream: MediaStream, recorder: MediaRecorder) => {\n const AudioCtx =\n window.AudioContext ||\n (window as Window & { webkitAudioContext?: typeof AudioContext })\n .webkitAudioContext;\n\n if (!AudioCtx) {\n return;\n }\n\n const context = new AudioCtx();\n audioContextRef.current = context;\n\n const analyser = context.createAnalyser();\n analyser.fftSize = 256;\n\n const source = context.createMediaStreamSource(stream);\n sourceRef.current = source;\n source.connect(analyser);\n\n const dataArray = new Uint8Array(analyser.frequencyBinCount);\n silenceStartRef.current = null;\n let speechDetected = false;\n\n vadIntervalRef.current = window.setInterval(() => {\n if (!isRecordingRef.current || recorder.state === \"inactive\") {\n cleanupVAD();\n return;\n }\n\n analyser.getByteFrequencyData(dataArray);\n\n let sum = 0;\n for (const value of dataArray) {\n sum += value;\n }\n const average = sum / dataArray.length;\n const volume = average / 255;\n\n if (volume < VAD_THRESHOLD) {\n if (silenceStartRef.current === null) {\n silenceStartRef.current = Date.now();\n return;\n }\n\n const silenceDuration = Date.now() - silenceStartRef.current;\n if (speechDetected && silenceDuration > SILENCE_DURATION_MS) {\n stopRecording();\n }\n return;\n }\n\n speechDetected = true;\n silenceStartRef.current = null;\n }, 50);\n };\n\n const startRecording = async (mode: RecordingMode) => {\n if (\n isBusyRef.current ||\n isRecordingRef.current ||\n startRecordingPendingRef.current\n ) {\n return;\n }\n\n setStatusOverride(STATUS_LABELS.listening);\n\n if (!navigator.mediaDevices?.getUserMedia) {\n setStatusOverride(null);\n appendMessage(\"Bu tarayıcıda mikrofon kullanılamıyor.\", false);\n return;\n }\n\n if (typeof MediaRecorder === \"undefined\") {\n setStatusOverride(null);\n appendMessage(\"Bu tarayıcıda MediaRecorder desteklenmiyor.\", false);\n return;\n }\n\n startRecordingPendingRef.current = true;\n\n try {\n const stream = await navigator.mediaDevices.getUserMedia({ audio: true });\n streamRef.current = stream;\n\n // Use low bitrate for speech — opus handles voice well at 16-24 kbps\n // and produces ~4-5x smaller payloads, speeding up the upload to fal.\n const recorderOptions: MediaRecorderOptions = {\n audioBitsPerSecond: 16_000,\n };\n\n // Prefer opus-in-ogg (smaller container) → opus-in-webm → browser default\n const preferredMimeTypes = [\n \"audio/ogg;codecs=opus\",\n \"audio/webm;codecs=opus\",\n \"audio/webm\",\n ];\n for (const mime of preferredMimeTypes) {\n if (MediaRecorder.isTypeSupported(mime)) {\n recorderOptions.mimeType = mime;\n break;\n }\n }\n\n const recorder = new MediaRecorder(stream, recorderOptions);\n recorderRef.current = recorder;\n audioChunksRef.current = [];\n clearLiveUserTranscriptionState();\n sttSendCuePlayedRef.current = false;\n\n const sttMimeType = (recorder.mimeType || recorderOptions.mimeType || \"audio/webm\")\n .split(\";\")[0]\n .trim() || \"audio/webm\";\n\n const sttWsController = startSttWebSocketStream(\n config.backendBaseUrl,\n {\n projectId: config.projectId,\n sessionId: sessionIdRef.current,\n language: \"tr\",\n mimeType: sttMimeType,\n },\n {\n onSessionId: (sid) => {\n if (!sid || sid === sessionIdRef.current) {\n return;\n }\n sessionIdRef.current = sid;\n if (typeof localStorage !== \"undefined\") {\n localStorage.setItem(SESSION_ID_KEY, sid);\n }\n },\n onPartial: ({ text }) => {\n if (!text.trim()) {\n return;\n }\n upsertLiveUserTranscription(text);\n },\n },\n );\n activeSttWsRef.current = sttWsController;\n\n recorder.ondataavailable = (event) => {\n if (event.data.size > 0) {\n audioChunksRef.current.push(event.data);\n if (activeSttWsRef.current) {\n void activeSttWsRef.current.pushChunk(event.data).catch((error) => {\n console.warn(\n `[Bulut] STT WS chunk send failed: ${error instanceof Error ? error.message : String(error)}`,\n );\n });\n }\n }\n };\n\n recorder.onerror = () => {\n appendMessage(\"Mikrofon kaydı sırasında bir hata oluştu.\", false);\n };\n\n recorder.onstop = async () => {\n setIsRecording(false);\n isRecordingRef.current = false;\n recordingModeRef.current = null;\n stopRecordingTimer();\n\n cleanupVAD();\n stopStreamTracks();\n\n const shouldDiscard = discardNextRecordingRef.current;\n discardNextRecordingRef.current = false;\n\n const blob = new Blob(audioChunksRef.current, {\n type: recorder.mimeType || \"audio/webm\",\n });\n audioChunksRef.current = [];\n\n const currentSttWs = activeSttWsRef.current;\n activeSttWsRef.current = null;\n\n if (shouldDiscard) {\n currentSttWs?.cancel();\n clearLiveUserTranscriptionState();\n setStatusOverride(null);\n return;\n }\n\n if (blob.size === 0) {\n currentSttWs?.cancel();\n clearLiveUserTranscriptionState();\n setStatusOverride(null);\n appendMessage(\"Ses kaydı alınamadı. Lütfen tekrar deneyin.\", false);\n return;\n }\n\n setIsTranscribing(true);\n setStatusOverride(STATUS_LABELS.transcribing);\n\n try {\n if (currentSttWs) {\n playSttSentCueOnce();\n const sttResult = await currentSttWs.stop();\n if (sttResult.session_id && sttResult.session_id !== sessionIdRef.current) {\n sessionIdRef.current = sttResult.session_id;\n if (typeof localStorage !== \"undefined\") {\n localStorage.setItem(SESSION_ID_KEY, sttResult.session_id);\n }\n }\n if (sttResult.text.trim()) {\n upsertLiveUserTranscription(sttResult.text);\n setStatusOverride(STATUS_LABELS.thinking);\n await runAgentForUserText(sttResult.text);\n return;\n }\n }\n } catch (error) {\n console.warn(\n `[Bulut] STT WS finalization failed, falling back to HTTP POST /chat/stt: ${error instanceof Error ? error.message : String(error)}`,\n );\n } finally {\n clearLiveUserTranscriptionState();\n }\n\n console.info(\"[Bulut] Using HTTP POST fallback for STT (streaming WS did not succeed)\");\n setStatusOverride(STATUS_LABELS.thinking);\n await handleAudioBlob(blob);\n };\n\n if (mode === \"vad\") {\n setupVAD(stream, recorder);\n }\n\n recorder.start(200);\n recordingModeRef.current = mode;\n setIsRecording(true);\n isRecordingRef.current = true;\n startRecordingTimer();\n\n if (pendingStopAfterStartRef.current) {\n pendingStopAfterStartRef.current = false;\n stopRecording();\n }\n } catch (error) {\n const errMsg = normalizeError(error);\n if (errMsg.toLowerCase().includes(\"permission\") || errMsg.toLowerCase().includes(\"denied\")) {\n autoListenSuppressedRef.current = true;\n }\n cancelActiveSttWs();\n setStatusOverride(null);\n appendMessage(`Mikrofon hatası: ${errMsg}`, false);\n cleanupVAD();\n stopStreamTracks();\n pendingStopAfterStartRef.current = false;\n setIsRecording(false);\n isRecordingRef.current = false;\n stopRecordingTimer();\n } finally {\n if (!isRecordingRef.current && !isBusyRef.current) {\n setStatusOverride(null);\n }\n startRecordingPendingRef.current = false;\n }\n };\n\n const resetMicGesture = () => {\n micPressStartRef.current = null;\n micHoldTriggeredRef.current = false;\n clearMicHoldTimeout();\n };\n\n const handleMicPointerDown = (\n event: JSX.TargetedPointerEvent<HTMLButtonElement>,\n ) => {\n event.preventDefault();\n\n if (isBusyRef.current) {\n return;\n }\n\n if (isRecordingRef.current) {\n // In VAD mode, tapping the button cancels; in press mode, it sends\n if (recordingModeRef.current === \"vad\") {\n stopRecording({ discard: true });\n } else {\n stopRecording();\n }\n return;\n }\n\n micPressStartRef.current = Date.now();\n micHoldTriggeredRef.current = false;\n clearMicHoldTimeout();\n\n if (event.currentTarget.setPointerCapture) {\n try {\n event.currentTarget.setPointerCapture(event.pointerId);\n } catch {\n // No-op.\n }\n }\n\n micHoldTimeoutRef.current = window.setTimeout(() => {\n if (\n micPressStartRef.current === null ||\n isBusyRef.current ||\n isRecordingRef.current\n ) {\n return;\n }\n\n micHoldTriggeredRef.current = true;\n void startRecording(\"press\");\n }, HOLD_THRESHOLD_MS);\n };\n\n const handleMicPointerUp = (\n event: JSX.TargetedPointerEvent<HTMLButtonElement>,\n ) => {\n event.preventDefault();\n\n if (event.currentTarget.releasePointerCapture) {\n try {\n event.currentTarget.releasePointerCapture(event.pointerId);\n } catch {\n // No-op.\n }\n }\n\n const startedAt = micPressStartRef.current;\n const wasHold = micHoldTriggeredRef.current;\n resetMicGesture();\n\n if (startedAt === null) {\n return;\n }\n\n if (wasHold) {\n if (isRecordingRef.current) {\n stopRecording();\n } else if (startRecordingPendingRef.current) {\n pendingStopAfterStartRef.current = true;\n }\n return;\n }\n\n const duration = Date.now() - startedAt;\n if (classifyMicGesture(duration) === \"tap\") {\n void startRecording(\"vad\");\n }\n };\n\n const handleMicPointerCancel = (\n event: JSX.TargetedPointerEvent<HTMLButtonElement>,\n ) => {\n handleMicPointerUp(event);\n };\n\n const handleRestart = () => {\n invalidateRequestEpoch();\n sttSendCuePlayedRef.current = false;\n resetMicGesture();\n pendingStopAfterStartRef.current = false;\n\n stopActiveStream();\n stopActiveAudioPlayback();\n cancelActiveSttWs();\n\n if (recorderRef.current && recorderRef.current.state !== \"inactive\") {\n stopRecording({ discard: true });\n } else {\n discardNextRecordingRef.current = false;\n cleanupVAD();\n stopStreamTracks();\n }\n\n stopRecordingTimer();\n setRecordingDurationMs(0);\n\n clearPersistedChatState(\n typeof localStorage !== \"undefined\" ? localStorage : null,\n );\n\n sessionIdRef.current = null;\n const initialMessages = createInitialMessages(config.agentName);\n nextMessageIdRef.current = getNextMessageId(initialMessages);\n setMessages(initialMessages);\n\n setIsBusy(false);\n isBusyRef.current = false;\n setIsRecording(false);\n isRecordingRef.current = false;\n resetProcessingFlags();\n };\n\n // Auto-listen when accessibility mode is activated (initial trigger)\n useEffect(() => {\n if (!accessibilityMode || autoListenSuppressedRef.current) return;\n const timer = window.setTimeout(() => {\n if (!isRecordingRef.current && !isBusyRef.current && !startRecordingPendingRef.current && !autoListenSuppressedRef.current) {\n void startRecording(\"vad\");\n }\n }, 500);\n return () => window.clearTimeout(timer);\n }, [accessibilityMode]); // eslint-disable-line react-hooks/exhaustive-deps\n\n const stopTask = () => {\n invalidateRequestEpoch();\n sttSendCuePlayedRef.current = false;\n stopActiveStream();\n stopActiveAudioPlayback();\n cancelActiveSttWs();\n stopRecording({ discard: true });\n cleanupVAD();\n stopStreamTracks();\n resetProcessingFlags();\n setIsBusy(false);\n };\n\n // Expose recording actions to parent via actionsRef\n if (actionsRef) {\n actionsRef.current = {\n startRecording: () => {\n autoListenSuppressedRef.current = false;\n void startRecording(\"vad\");\n },\n cancelRecording: () => {\n stopActiveAudioPlayback();\n cancelActiveSttWs();\n const recorder = recorderRef.current;\n if (recorder && recorder.state !== \"inactive\") {\n stopRecording({ discard: true });\n } else {\n cleanupVAD();\n stopStreamTracks();\n }\n },\n stopTask,\n };\n }\n\n const windowStyle: { [key: string]: string } = {\n position: \"fixed\",\n bottom: `${POSITION_BOTTOM}px`,\n right: `${POSITION_RIGHT}px`,\n width: `${WINDOW_WIDTH}px`,\n maxHeight: `${WINDOW_HEIGHT}px`,\n backgroundColor: \"hsla(0, 0%, 100%, 1)\",\n borderRadius: BORDER_RADIUS.window,\n display: hidden ? \"none\" : \"flex\",\n flexDirection: \"column\",\n overflow: \"hidden\",\n zIndex: \"10000\",\n animation: hidden ? \"none\" : `slideIn ${TRANSITIONS.medium}`,\n boxShadow: SHADOW,\n fontFamily: \"\\\"Geist\\\", sans-serif\",\n };\n\n const headerStyle: { [key: string]: string } = {\n padding: \"14px 16px\",\n display: \"flex\",\n justifyContent: \"space-between\",\n alignItems: \"center\",\n };\n\n const headerActionsStyle: { [key: string]: string } = {\n display: \"flex\",\n alignItems: \"center\",\n gap: \"6px\",\n };\n\n const headerButtonStyle: { [key: string]: string } = {\n background: \"none\",\n border: \"none\",\n cursor: \"pointer\",\n padding: \"4px\",\n borderRadius: \"6px\",\n color: COLORS.text,\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n transition: `color ${TRANSITIONS.fast}, background-color ${TRANSITIONS.fast}`,\n };\n\n const messagesContainerStyle: { [key: string]: string } = {\n padding: \"0px 16px\",\n overflowY: \"auto\",\n flex: \"1\",\n minHeight: \"0\",\n };\n\n const messagesListStyle: { [key: string]: string } = {\n display: \"flex\",\n flexDirection: \"column\",\n gap: \"16px\",\n };\n\n const messageStyle = (isUser: boolean): JSX.CSSProperties => ({\n maxWidth: \"84%\",\n padding: isUser ? \"9px 14px\" : \"0px 0px\",\n borderRadius: BORDER_RADIUS.message,\n fontSize: \"14px\",\n lineHeight: \"140%\",\n wordWrap: \"break-word\",\n whiteSpace: \"pre-wrap\",\n alignSelf: isUser ? \"flex-end\" : \"flex-start\",\n backgroundColor: isUser ? COLORS.messageUser : \"\",\n color: isUser ? COLORS.messageUserText : \"hsla(215, 100%, 5%, 1)\",\n });\n\n const footerStyle: { [key: string]: string } = {\n padding: \"10px 12px\",\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"space-between\",\n gap: \"8px\",\n };\n\n const statusPanelStyle: { [key: string]: string } = {\n flex: \"1\",\n minHeight: \"34px\",\n borderRadius: \"10px\",\n color: COLORS.text,\n fontSize: \"14px\",\n display: \"flex\",\n alignItems: \"center\",\n padding: \"0 10px\",\n whiteSpace: \"nowrap\",\n overflow: \"hidden\",\n textOverflow: \"ellipsis\",\n opacity: \"0.7\",\n };\n\n const footerActionsStyle: { [key: string]: string } = {\n display: \"flex\",\n alignItems: \"center\",\n gap: \"8px\",\n flexShrink: \"0\",\n };\n\n const recordingTimerStyle: { [key: string]: string } = {\n minWidth: \"46px\",\n fontSize: \"12px\",\n fontWeight: \"700\",\n color: COLORS.text,\n textAlign: \"right\",\n };\n\n const micFooterButtonStyle: { [key: string]: string } = {\n width: \"37px\",\n height: \"37px\",\n borderRadius: \"999px\",\n background: \"transparent\",\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n cursor: \"pointer\",\n color: \"#ffffff\",\n border: \"1px solid hsla(215, 100%, 5%, 0.5)\",\n transition: `transform ${TRANSITIONS.fast}`,\n };\n\n const isVadRecording = isRecording && recordingModeRef.current === \"vad\";\n const showStopButton = isBusy && !isRecording;\n const disableMicControl = isBusy;\n\n return (\n <div className=\"bulut-chat-window\" style={windowStyle}>\n <style>{`\n @keyframes slideIn {\n from {\n opacity: 0;\n transform: translateY(10px);\n }\n to {\n opacity: 1;\n transform: translateY(0);\n }\n }\n\n .bulut-header-btn:hover:not(:disabled) {\n color: ${COLORS.text};\n }\n\n .bulut-footer-btn:hover:not(:disabled) {\n transform: scale(1.04);\n }\n\n .bulut-header-btn:disabled,\n .bulut-footer-btn:disabled {\n cursor: not-allowed;\n opacity: 0.5;\n transform: none;\n }\n\n @keyframes bulut-dots {\n 0% { content: '.'; }\n 33% { content: '..'; }\n 66% { content: '...'; }\n }\n\n .bulut-status-dots::after {\n content: '.';\n animation: bulut-dots 1.2s steps(1) infinite;\n display: inline-block;\n min-width: 12px;\n text-align: left;\n }\n\n /* Mobile: full-screen chat window */\n @media (max-width: 600px) {\n .bulut-chat-window {\n top: 0 !important;\n left: 0 !important;\n right: 0 !important;\n bottom: 0 !important;\n width: 100% !important;\n max-height: 100% !important;\n height: 100% !important;\n border-radius: 0 !important;\n }\n .bulut-close-btn {\n width: 40px !important;\n height: 40px !important;\n padding: 8px !important;\n }\n .bulut-close-btn svg {\n width: 26px !important;\n height: 26px !important;\n }\n }\n `}</style>\n\n <div style={headerStyle}>\n <SvgIcon\n src={logoContent}\n title=\"Bulut Logo\"\n style={{ maxWidth: \"80px\", height: \"auto\" }}\n stripColors={false}\n />\n <div style={headerActionsStyle}>\n <button\n type=\"button\"\n className=\"bulut-header-btn\"\n style={headerButtonStyle}\n onClick={handleRestart}\n aria-label=\"Sohbeti yeniden başlat\"\n title=\"Sohbeti yeniden başlat\"\n >\n <SvgIcon src={restartIconContent} width={22} />\n </button>\n\n <button\n type=\"button\"\n className=\"bulut-header-btn bulut-close-btn\"\n style={{\n ...headerButtonStyle,\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n }}\n onClick={onClose}\n aria-label=\"Sohbeti kapat\"\n title=\"Sohbeti kapat\"\n >\n <SvgIcon\n fill-opacity={\"0\"}\n stroke={\"currentColor\"}\n src={closeIconContent}\n width={22}\n />\n </button>\n </div>\n </div>\n\n <div style={messagesContainerStyle} ref={messagesContainerRef}>\n <div style={messagesListStyle} ref={messagesContentRef}>\n {messages.map((message) => (\n <div\n key={message.id}\n style={\n message.type === \"tool\"\n ? {\n padding: \"9px 14px\",\n fontSize: \"14px\",\n lineHeight: \"1.4\",\n color: \"hsla(215, 100%, 5%, 1)\",\n fontWeight: 600,\n backgroundColor: \"hsla(215, 100%, 5%, 0.05)\",\n borderRadius: \"10px\",\n alignSelf: \"flex-start\",\n maxWidth: \"84%\",\n }\n : messageStyle(message.isUser)\n }\n >\n {message.text}\n </div>\n ))}\n </div>\n </div>\n\n <div style={footerStyle}>\n <div style={{ ...statusPanelStyle, transition: \"opacity 0.2s ease-out\" }}>\n {showStatus ? (\n <span className=\"bulut-status-dots\" title={statusText}>\n {statusText}\n </span>\n ) : onAccessibilityToggle ? (\n <div\n style={{\n display: \"flex\",\n alignItems: \"center\",\n gap: \"8px\",\n }}\n >\n <span\n style={{\n fontSize: \"12px\",\n opacity: \"0.6\",\n whiteSpace: \"nowrap\",\n }}\n >\n Erişilebilirlik\n </span>\n <button\n type=\"button\"\n onClick={onAccessibilityToggle}\n aria-label={\n accessibilityMode\n ? \"Erişilebilirlik modunu kapat\"\n : \"Erişilebilirlik modunu aç\"\n }\n style={{\n width: \"36px\",\n height: \"20px\",\n borderRadius: \"10px\",\n border: \"none\",\n cursor: \"pointer\",\n padding: \"2px\",\n display: \"flex\",\n alignItems: \"center\",\n backgroundColor: accessibilityMode\n ? COLORS.primary\n : \"hsla(215, 10%, 75%, 1)\",\n transition: `background-color ${TRANSITIONS.fast}`,\n flexShrink: \"0\",\n }}\n >\n <span\n style={{\n width: \"16px\",\n height: \"16px\",\n borderRadius: \"50%\",\n backgroundColor: \"#ffffff\",\n display: \"block\",\n transition: `transform ${TRANSITIONS.fast}`,\n transform: accessibilityMode\n ? \"translateX(16px)\"\n : \"translateX(0)\",\n boxShadow: \"0 1px 3px rgba(0,0,0,0.2)\",\n }}\n />\n </button>\n </div>\n ) : null}\n </div>\n\n <div style={footerActionsStyle}>\n {isRecording ? (\n <span style={recordingTimerStyle}>\n {formatDurationMs(recordingDurationMs)}\n </span>\n ) : null}\n {showStopButton ? (\n <button\n type=\"button\"\n className=\"bulut-footer-btn\"\n style={micFooterButtonStyle}\n onClick={stopTask}\n aria-label=\"Görevi durdur\"\n title=\"Görevi durdur\"\n >\n <SvgIcon\n fill-opacity={\"0\"}\n stroke={\"hsla(215, 100%, 5%, 1)\"}\n src={stopIconContent}\n width={22}\n />\n </button>\n ) : (\n <button\n type=\"button\"\n className=\"bulut-footer-btn\"\n style={micFooterButtonStyle}\n onPointerDown={handleMicPointerDown}\n onPointerUp={handleMicPointerUp}\n onPointerCancel={handleMicPointerCancel}\n disabled={disableMicControl}\n aria-label={isVadRecording ? \"Kaydı iptal et\" : isRecording ? \"Kaydı durdur\" : \"Kaydı başlat\"}\n title={\n isVadRecording\n ? \"Kaydı iptal et\"\n : isRecording\n ? \"Kaydı durdur\"\n : \"Dokun: VAD, Basılı tut: bırakınca gönder\"\n }\n >\n <SvgIcon\n fill-opacity={\"0\"}\n stroke={\"hsla(215, 100%, 5%, 1)\"}\n src={isVadRecording ? closeIconContent : microphoneIconContent}\n width={22}\n />\n </button>\n )}\n </div>\n </div>\n </div>\n );\n};\n","export default \"<svg width=\\\"2420\\\" height=\\\"438\\\" viewBox=\\\"0 0 2420 438\\\" fill=\\\"none\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\">\\n<path d=\\\"M251.823 0C313.458 0 366.34 37.767 388.932 91.5918C409.253 75.8883 434.678 66.5567 462.264 66.5566C528.885 66.5567 582.893 120.989 582.893 188.134C582.893 188.786 582.885 189.436 582.875 190.086C648.144 193.552 700 247.572 700 313.704C700 382.074 644.575 437.5 576.204 437.5H123.796C55.4255 437.5 7.42386e-05 382.074 0 313.704C0 250.475 47.4025 198.32 108.608 190.833C104.967 177.844 103.019 164.138 103.019 149.975C103.019 67.1461 169.641 0.000357483 251.823 0ZM234.696 141.93C218.117 134.066 199 146.158 199 164.507C199 174.32 204.744 183.225 213.684 187.271L336.761 242.985C337.971 243.533 338.748 244.738 338.748 246.066C338.748 247.394 337.971 248.6 336.761 249.147L213.684 304.861C204.744 308.908 199 317.812 199 327.625C199 345.974 218.117 358.066 234.696 350.202L364.672 288.554C375.142 283.588 381.815 273.036 381.815 261.448V230.684C381.815 219.096 375.142 208.544 364.672 203.578L234.696 141.93ZM413.877 296.146C402.078 296.146 392.513 305.711 392.513 317.511C392.513 329.31 402.078 338.875 413.877 338.875H526.636C538.435 338.875 548 329.31 548 317.511C548 305.711 538.435 296.146 526.636 296.146H413.877Z\\\" fill=\\\"#000B1A\\\"/>\\n<path d=\\\"M2420 424.954H2343.35C2307.08 424.954 2278.64 416.094 2258.04 398.373C2237.43 380.652 2227.13 352.216 2227.13 313.065V55.2871H2319.86V302.556C2319.86 318.217 2323.15 328.726 2329.75 334.083C2336.75 339.028 2348.29 341.501 2364.36 341.501H2420V424.954ZM2420 191.903H2178.29V115.25H2420V191.903Z\\\" fill=\\\"#000B1A\\\"/>\\n<path d=\\\"M1923.18 431.136C1894.33 431.136 1870.22 425.779 1850.85 415.064C1831.89 403.937 1817.68 389.101 1808.2 370.555C1799.13 352.01 1794.6 331.198 1794.6 308.12V115.25H1887.32V277.211C1887.32 301.938 1893.3 320.071 1905.25 331.61C1917.2 342.738 1937.81 348.301 1967.07 348.301C1997.56 348.301 2018.79 342.325 2030.74 330.374C2043.1 318.011 2049.28 298.641 2049.28 272.266L2061.03 271.648L2067.83 330.374H2050.52C2048.05 347.683 2041.87 363.962 2031.98 379.21C2022.5 394.458 2008.69 407.028 1990.56 416.918C1972.84 426.397 1950.38 431.136 1923.18 431.136ZM2142.01 424.955H2055.47V329.138L2049.28 326.047V115.25H2142.01V424.955Z\\\" fill=\\\"#000B1A\\\"/>\\n<path d=\\\"M1734.32 424.955H1641.59V10.7793H1734.32V424.955Z\\\" fill=\\\"#000B1A\\\"/>\\n<path d=\\\"M1362.98 431.136C1334.13 431.136 1310.03 425.779 1290.66 415.064C1271.7 403.937 1257.48 389.101 1248 370.555C1238.94 352.01 1234.4 331.198 1234.4 308.12V115.25H1327.13V277.211C1327.13 301.938 1333.1 320.071 1345.06 331.61C1357.01 342.738 1377.61 348.301 1406.87 348.301C1437.37 348.301 1458.59 342.325 1470.54 330.374C1482.91 318.011 1489.09 298.641 1489.09 272.266L1500.83 271.648L1507.63 330.374H1490.33C1487.85 347.683 1481.67 363.962 1471.78 379.21C1462.3 394.458 1448.5 407.028 1430.36 416.918C1412.64 426.397 1390.18 431.136 1362.98 431.136ZM1581.82 424.955H1495.27V329.138L1489.09 326.047V115.25H1581.82V424.955Z\\\" fill=\\\"#000B1A\\\"/>\\n<path d=\\\"M1035.12 431.137C999.27 431.137 971.04 423.513 950.434 408.264C930.241 392.604 917.259 369.526 911.49 339.029H894.181L900.981 272.266H912.726C912.726 289.987 916.023 304.411 922.617 315.538C929.623 326.253 939.719 334.084 952.907 339.029C966.507 343.974 983.198 346.447 1002.98 346.447C1023.17 346.447 1039.66 343.974 1052.43 339.029C1065.21 334.084 1074.69 326.047 1080.87 314.92C1087.05 303.793 1090.14 288.957 1090.14 270.412C1090.14 251.042 1087.05 236 1080.87 225.285C1074.69 214.158 1065.21 206.122 1052.43 201.177C1039.66 196.231 1023.38 193.758 1003.6 193.758C973.513 193.758 950.847 199.322 935.598 210.449C920.35 221.576 912.726 240.533 912.726 267.321H900.981V197.467H917.671C923.029 171.504 935.392 150.28 954.762 133.796C974.543 117.311 1002.77 109.069 1039.45 109.069C1070.36 109.069 1096.53 115.663 1117.96 128.85C1139.39 142.038 1155.67 160.789 1166.79 185.104C1178.33 209.007 1184.1 237.443 1184.1 270.412C1184.1 302.969 1178.33 331.405 1166.79 355.72C1155.67 379.622 1138.98 398.168 1116.72 411.355C1094.47 424.543 1067.27 431.137 1035.12 431.137ZM905.926 424.955H820V10.7793H912.726V325.429L905.926 333.465V424.955Z\\\" fill=\\\"#000B1A\\\"/>\\n</svg>\\n\"","export default \"<svg width=\\\"50\\\" height=\\\"50\\\" viewBox=\\\"0 0 50 50\\\" fill=\\\"none\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\">\\n<path d=\\\"M31.4571 10.4169C30.714 10.783 30.4083 11.6822 30.7744 12.4254C31.1405 13.1685 32.0397 13.4742 32.7829 13.1081L32.12 11.7625L31.4571 10.4169ZM44.3 28.2275C44.3 27.3991 43.6284 26.7275 42.8 26.7275C41.9716 26.7275 41.3 27.3991 41.3 28.2275H42.8H44.3ZM26.0607 0.911874C25.4749 0.326088 24.5251 0.326088 23.9393 0.911874C23.3536 1.49766 23.3536 2.44741 23.9393 3.03319L25 1.97253L26.0607 0.911874ZM33.9 10.8725L34.9607 11.9332C35.5464 11.3474 35.5464 10.3977 34.9607 9.81187L33.9 10.8725ZM23.9393 18.7119C23.3536 19.2977 23.3536 20.2474 23.9393 20.8332C24.5251 21.419 25.4749 21.419 26.0607 20.8332L25 19.7725L23.9393 18.7119ZM32.12 11.7625C32.7829 13.1081 32.7838 13.1077 32.7848 13.1072C32.7851 13.107 32.7861 13.1065 32.7868 13.1062C32.7882 13.1055 32.7896 13.1048 32.791 13.1041C32.794 13.1026 32.7971 13.101 32.8005 13.0993C32.8071 13.0959 32.8146 13.0921 32.8229 13.0878C32.8393 13.0792 32.859 13.0686 32.8813 13.0561C32.9252 13.0315 32.9828 12.9974 33.0478 12.9543C33.1597 12.8798 33.3709 12.728 33.5596 12.493C33.7406 12.2674 34.0582 11.7606 33.9356 11.0758C33.8134 10.3931 33.3372 10.002 33.0232 9.81189C32.4374 9.45724 31.5535 9.27046 30.4249 9.14527C29.2187 9.01147 27.4833 8.92753 25 8.92753V10.4275V11.9275C27.4317 11.9275 29.0439 12.0105 30.0942 12.127C31.2222 12.2521 31.5039 12.3991 31.4694 12.3782C31.4309 12.3549 31.0768 12.1307 30.9826 11.6044C30.888 11.0761 31.1396 10.7153 31.2201 10.6149C31.3083 10.5051 31.3846 10.4575 31.3868 10.4561C31.3968 10.4494 31.4058 10.444 31.4148 10.439C31.4196 10.4363 31.4253 10.4332 31.4321 10.4296C31.4355 10.4278 31.4393 10.4259 31.4434 10.4238C31.4455 10.4228 31.4477 10.4217 31.4499 10.4205C31.4511 10.4199 31.4523 10.4194 31.4535 10.4188C31.4541 10.4185 31.455 10.418 31.4553 10.4179C31.4562 10.4174 31.4571 10.4169 32.12 11.7625ZM25 10.4275V8.92753C21.1828 8.92753 17.4514 10.0595 14.2775 12.1802L15.1109 13.4274L15.9442 14.6746C18.6247 12.8835 21.7762 11.9275 25 11.9275V10.4275ZM15.1109 13.4274L14.2775 12.1802C11.1036 14.3009 8.6299 17.3151 7.16913 20.8417L8.55495 21.4158L9.94077 21.9898C11.1745 19.0114 13.2637 16.4656 15.9442 14.6746L15.1109 13.4274ZM8.55495 21.4158L7.16913 20.8417C5.70836 24.3684 5.32616 28.2489 6.07085 31.9928L7.54203 31.7001L9.01321 31.4075C8.38427 28.2456 8.70706 24.9682 9.94077 21.9898L8.55495 21.4158ZM7.54203 31.7001L6.07085 31.9928C6.81555 35.7366 8.65369 39.1755 11.3528 41.8747L12.4135 40.814L13.4742 39.7534C11.1946 37.4738 9.64215 34.5694 9.01321 31.4075L7.54203 31.7001ZM12.4135 40.814L11.3528 41.8747C14.052 44.5738 17.4909 46.412 21.2348 47.1567L21.5274 45.6855L21.82 44.2143C18.6581 43.5854 15.7538 42.033 13.4742 39.7534L12.4135 40.814ZM21.5274 45.6855L21.2348 47.1567C24.9786 47.9014 28.8592 47.5192 32.3858 46.0584L31.8118 44.6726L31.2377 43.2868C28.2593 44.5205 24.9819 44.8433 21.82 44.2143L21.5274 45.6855ZM31.8118 44.6726L32.3858 46.0584C35.9124 44.5976 38.9267 42.1239 41.0474 38.95L39.8002 38.1167L38.553 37.2833C36.7619 39.9638 34.2162 42.0531 31.2377 43.2868L31.8118 44.6726ZM39.8002 38.1167L41.0474 38.95C43.1681 35.7762 44.3 32.0447 44.3 28.2275H42.8H41.3C41.3 31.4514 40.344 34.6028 38.553 37.2833L39.8002 38.1167ZM25 1.97253L23.9393 3.03319L32.8393 11.9332L33.9 10.8725L34.9607 9.81187L26.0607 0.911874L25 1.97253ZM33.9 10.8725L32.8393 9.81187L23.9393 18.7119L25 19.7725L26.0607 20.8332L34.9607 11.9332L33.9 10.8725Z\\\" fill=\\\"hsla(215, 100%, 5%, 1)\\\"/>\\n</svg>\\n\"","import { useState, useEffect, useRef, useCallback } from \"preact/hooks\";\nimport \"./globals.css\";\nimport { render } from \"preact\";\nimport { ChatButton } from \"./components/ChatButton\";\nimport {\n ChatWindow,\n type ChatWindowHandle,\n} from \"./components/ChatWindow\";\nimport { COLORS } from \"./styles/constants\";\n\nexport type BulutVoice = \"alloy\" | \"zeynep\" | \"ali\";\n\nexport interface BulutOptions {\n containerId?: string;\n backendBaseUrl?: string;\n projectId?: string;\n}\n\nexport interface BulutRuntimeConfig {\n backendBaseUrl: string;\n projectId: string;\n model: string;\n voice: BulutVoice;\n baseColor: string;\n agentName: string;\n}\n\n/** Default LLM model — keep in sync with backend config.DEFAULT_LLM_MODEL */\nconst DEFAULT_LLM_MODEL = \"x-ai/grok-4.1-fast\";\n\nconst DEFAULT_AGENT_NAME = \"Bulut\";\n\nconst DEFAULT_CONFIG: BulutRuntimeConfig = {\n backendBaseUrl: \"https://api.bulut.lu\",\n projectId: \"\", // Must be provided\n model: DEFAULT_LLM_MODEL,\n voice: \"alloy\",\n baseColor: COLORS.primary,\n agentName: DEFAULT_AGENT_NAME,\n};\n\nconst isValidHexColor = (value: string): boolean =>\n /^#([0-9a-fA-F]{3}|[0-9a-fA-F]{6})$/.test(value);\n\nconst normalizeHexColor = (value: string): string => {\n const trimmed = value.trim();\n if (!isValidHexColor(trimmed)) {\n return DEFAULT_CONFIG.baseColor;\n }\n if (trimmed.length === 4) {\n const r = trimmed[1];\n const g = trimmed[2];\n const b = trimmed[3];\n return `#${r}${r}${g}${g}${b}${b}`.toLowerCase();\n }\n return trimmed.toLowerCase();\n};\n\nconst shadeHexColor = (hexColor: string, amount: number): string => {\n const normalized = normalizeHexColor(hexColor);\n const raw = normalized.slice(1);\n const toChannel = (start: number): number => parseInt(raw.slice(start, start + 2), 16);\n const clamp = (value: number): number => Math.max(0, Math.min(255, Math.round(value)));\n const adjust = (channel: number): number =>\n amount < 0 ? channel * (1 + amount) : channel + (255 - channel) * amount;\n const toHex = (channel: number): string => clamp(channel).toString(16).padStart(2, \"0\");\n\n const r = adjust(toChannel(0));\n const g = adjust(toChannel(2));\n const b = adjust(toChannel(4));\n\n return `#${toHex(r)}${toHex(g)}${toHex(b)}`;\n};\n\nconst applyTheme = (baseColor: string): void => {\n const normalized = normalizeHexColor(baseColor);\n COLORS.primary = normalized;\n COLORS.primaryHover = shadeHexColor(normalized, -0.15);\n COLORS.messageUser = normalized;\n};\n\ninterface RemoteProjectConfig {\n base_color: string;\n model: string;\n agent_name: string;\n voice: string;\n}\n\nconst fetchRemoteConfig = async (\n baseUrl: string,\n projectId: string,\n): Promise<RemoteProjectConfig | null> => {\n try {\n const url = baseUrl.replace(/\\/+$/, \"\");\n const res = await fetch(`${url}/projects/${projectId}/config`);\n if (!res.ok) return null;\n return (await res.json()) as RemoteProjectConfig;\n } catch {\n return null;\n }\n};\n\nconst resolveRuntimeConfig = (\n options: BulutOptions,\n): BulutRuntimeConfig => ({\n backendBaseUrl: options.backendBaseUrl || DEFAULT_CONFIG.backendBaseUrl,\n projectId: options.projectId || DEFAULT_CONFIG.projectId,\n model: DEFAULT_CONFIG.model,\n voice: DEFAULT_CONFIG.voice,\n baseColor: DEFAULT_CONFIG.baseColor,\n agentName: DEFAULT_CONFIG.agentName,\n});\n\ninterface BulutWidgetProps {\n config: BulutRuntimeConfig;\n}\n\nconst ACCESSIBILITY_MODE_KEY = \"bulut_accessibility_mode_enabled\";\nconst GEIST_FONT_FAMILY = \"Geist\";\nconst GEIST_STYLESHEET_ID = \"bulut-geist-font-stylesheet\";\nconst GEIST_STYLESHEET_URL =\n \"https://fonts.googleapis.com/css2?family=Geist:wght@100..900&display=swap\";\n\nconst ensureGeistStylesheet = (): void => {\n if (typeof document === \"undefined\") {\n return;\n }\n if (document.getElementById(GEIST_STYLESHEET_ID)) {\n return;\n }\n const link = document.createElement(\"link\");\n link.id = GEIST_STYLESHEET_ID;\n link.rel = \"stylesheet\";\n link.href = GEIST_STYLESHEET_URL;\n document.head.appendChild(link);\n};\n\nconst BulutWidget = ({ config }: BulutWidgetProps) => {\n // Live config that merges remote settings over initial config\n const [liveConfig, setLiveConfig] = useState<BulutRuntimeConfig>(config);\n const [configReady, setConfigReady] = useState(false);\n\n // Fetch remote project config on mount — widget stays hidden until done\n useEffect(() => {\n if (!config.projectId) {\n setConfigReady(true);\n return;\n }\n let cancelled = false;\n\n fetchRemoteConfig(config.backendBaseUrl, config.projectId).then((remote) => {\n if (cancelled) return;\n if (remote) {\n const merged: BulutRuntimeConfig = {\n ...config,\n baseColor: normalizeHexColor(remote.base_color || config.baseColor),\n model: remote.model || config.model,\n agentName: remote.agent_name || config.agentName,\n voice: (\n remote.voice === \"alloy\" || remote.voice === \"zeynep\" || remote.voice === \"ali\"\n ? remote.voice\n : config.voice\n ) as BulutVoice,\n };\n applyTheme(merged.baseColor);\n setLiveConfig(merged);\n }\n setConfigReady(true);\n });\n\n return () => { cancelled = true; };\n }, [config]);\n\n // Check localStorage for persisted state\n const [isOpen, setIsOpen] = useState(() => {\n if (typeof localStorage !== \"undefined\") {\n return localStorage.getItem(\"bulut_panel_open\") === \"true\";\n }\n return false;\n });\n\n const [showBubble, setShowBubble] = useState(false);\n const [isAccessibilityEnabled, setIsAccessibilityEnabled] = useState(() => {\n if (typeof localStorage === \"undefined\") {\n return false;\n }\n return localStorage.getItem(ACCESSIBILITY_MODE_KEY) === \"true\";\n });\n\n // State reported by ChatWindow\n const [isRecording, setIsRecording] = useState(false);\n const [isBusy, setIsBusy] = useState(false);\n const [previewMessage, setPreviewMessage] = useState<string | null>(null);\n const [previewDismissed, setPreviewDismissed] = useState(false);\n\n // Ref for delegating recording to ChatWindow\n const chatActionsRef = useRef<ChatWindowHandle | null>(null);\n\n const handlePreviewChange = useCallback((text: string | null) => {\n setPreviewMessage(text);\n if (text !== null) setPreviewDismissed(false);\n }, []);\n\n // Show welcome bubble once for 5 seconds\n useEffect(() => {\n if (isAccessibilityEnabled) {\n setShowBubble(false);\n return;\n }\n if (isOpen) return;\n if (typeof localStorage !== \"undefined\") {\n if (localStorage.getItem(\"bulut_bubble_shown\") === \"true\") return;\n }\n\n setShowBubble(true);\n const timer = setTimeout(() => {\n setShowBubble(false);\n if (typeof localStorage !== \"undefined\") {\n localStorage.setItem(\"bulut_bubble_shown\", \"true\");\n }\n }, 5000);\n return () => clearTimeout(timer);\n }, [isOpen, isAccessibilityEnabled]);\n\n const toggleWidget = () => {\n const newState = !isOpen;\n setIsOpen(newState);\n setShowBubble(false);\n if (typeof localStorage !== \"undefined\") {\n localStorage.setItem(\"bulut_panel_open\", String(newState));\n }\n };\n\n const toggleAccessibilityMode = () => {\n const next = !isAccessibilityEnabled;\n setIsAccessibilityEnabled(next);\n if (typeof localStorage !== \"undefined\") {\n localStorage.setItem(ACCESSIBILITY_MODE_KEY, String(next));\n }\n console.info(`[Bulut] accessibility mode toggled enabled=${next}`);\n };\n\n const handleClose = () => {\n setIsOpen(false);\n if (typeof localStorage !== \"undefined\") {\n localStorage.setItem(\"bulut_panel_open\", \"false\");\n }\n console.info(\"Bulut chat window closed.\");\n };\n\n // Close on escape key\n useEffect(() => {\n const handleEscape = (e: KeyboardEvent) => {\n if (e.key === \"Escape\" && isOpen) {\n setIsOpen(false);\n if (typeof localStorage !== \"undefined\") {\n localStorage.setItem(\"bulut_panel_open\", \"false\");\n }\n }\n };\n\n document.addEventListener(\"keydown\", handleEscape);\n return () => document.removeEventListener(\"keydown\", handleEscape);\n }, [isOpen]);\n\n if (!configReady) return null;\n\n return (\n <>\n {!isOpen && (\n <ChatButton\n onMicClick={() => chatActionsRef.current?.startRecording()}\n onCancelRecording={() => chatActionsRef.current?.cancelRecording()}\n onStopTask={() => chatActionsRef.current?.stopTask()}\n isRecording={isRecording}\n isBusy={isBusy}\n showBubble={showBubble}\n onBubbleClick={() => {\n setShowBubble(false);\n toggleWidget();\n }}\n previewMessage={previewDismissed ? null : previewMessage}\n onPreviewClick={() => toggleWidget()}\n onPreviewClose={() => setPreviewDismissed(true)}\n />\n )}\n <ChatWindow\n onClose={handleClose}\n config={liveConfig}\n accessibilityMode={isAccessibilityEnabled}\n onAccessibilityToggle={toggleAccessibilityMode}\n hidden={!isOpen}\n actionsRef={chatActionsRef}\n onRecordingChange={setIsRecording}\n onBusyChange={setIsBusy}\n onPreviewChange={handlePreviewChange}\n />\n </>\n );\n};\n\nconst SHADOW_STYLE = `\n :host {\n all: initial;\n contain: layout style paint;\n font-family: \"${GEIST_FONT_FAMILY}\", sans-serif;\n color: hsla(215, 100%, 5%, 1);\n font-size: 16px;\n line-height: 1.4;\n -webkit-font-smoothing: antialiased;\n text-rendering: optimizeLegibility;\n }\n\n #bulut-shadow-mount {\n all: initial;\n color: inherit;\n font-family: \"${GEIST_FONT_FAMILY}\", sans-serif;\n font-size: inherit;\n line-height: inherit;\n }\n\n #bulut-shadow-mount * {\n font-family: \"${GEIST_FONT_FAMILY}\", sans-serif !important;\n color: inherit;\n }\n\n #bulut-shadow-mount *, #bulut-shadow-mount *::before, #bulut-shadow-mount *::after {\n box-sizing: border-box;\n }\n`;\n\n// Container host for the widget\nlet widgetContainer: HTMLElement | null = null;\nlet widgetMountNode: HTMLElement | null = null;\nlet createdContainer = false;\nlet isInitialized = false;\n\n/**\n * Initialize the Bulut chat widget\n * @param options - Optional configuration options\n */\nexport const init = (options: BulutOptions = {}) => {\n if (isInitialized) {\n console.warn(\"Bulut is already initialized\");\n return;\n }\n\n ensureGeistStylesheet();\n\n const runtimeConfig = resolveRuntimeConfig(options);\n applyTheme(runtimeConfig.baseColor);\n\n // Create or find container\n if (options.containerId) {\n widgetContainer = document.getElementById(options.containerId);\n createdContainer = false;\n } else {\n widgetContainer = document.createElement(\"div\");\n widgetContainer.id = \"bulut-container\";\n document.body.appendChild(widgetContainer);\n createdContainer = true;\n }\n\n if (!widgetContainer) {\n console.error(\"Bulut: Container not found\");\n return;\n }\n\n const shadowRoot = widgetContainer.shadowRoot || widgetContainer.attachShadow({ mode: \"open\" });\n shadowRoot.replaceChildren();\n\n const style = document.createElement(\"style\");\n style.textContent = SHADOW_STYLE;\n\n const mountNode = document.createElement(\"div\");\n mountNode.id = \"bulut-shadow-mount\";\n\n shadowRoot.append(style, mountNode);\n widgetMountNode = mountNode;\n\n // Render the widget\n render(<BulutWidget config={runtimeConfig} />, mountNode);\n isInitialized = true;\n\n console.log(\"Bulut initialized successfully\");\n};\n\n/**\n * Destroy the Bulut widget\n */\nexport const destroy = () => {\n if (!isInitialized) {\n return;\n }\n\n if (widgetMountNode) {\n render(null, widgetMountNode);\n widgetMountNode = null;\n }\n\n if (widgetContainer && createdContainer) {\n document.body.removeChild(widgetContainer);\n }\n\n widgetContainer = null;\n createdContainer = false;\n isInitialized = false;\n console.log(\"Bulut destroyed\");\n};\n\n/**\n * Check if the widget is initialized\n */\nexport const isReady = () => isInitialized;\n\nconst Bulut = {\n init,\n destroy,\n isReady,\n};\n\nif (typeof window !== \"undefined\") {\n (window as Window & { Bulut?: typeof Bulut }).Bulut = Bulut;\n}\n\n// Export the main widget component for advanced usage\nexport { BulutWidget };\n\n// Export components for custom implementations\nexport { ChatButton, ChatWindow };\n\nexport default Bulut;\n"],"names":["n","l","u","i","o","r","e","f","c","s","a","p","v","y","d","Array","isArray","w","g","parentNode","removeChild","m","t","type","props","key","ref","__k","__","__b","__e","__c","constructor","__v","__i","__u","vnode","k","children","x","this","context","S","length","C","base","M","__d","push","$","__r","debounceRendering","sort","shift","__P","O","__n","namespaceURI","N","I","h","_","b","String","L","D","P","B","A","nextSibling","insertBefore","nodeType","T","setProperty","test","j","style","cssText","replace","toLowerCase","slice","addEventListener","removeEventListener","removeAttribute","setAttribute","F","event","H","prototype","render","contextType","value","__E","E","sub","state","__h","_sb","__s","getDerivedStateFromProps","componentWillMount","componentDidMount","componentWillReceiveProps","shouldComponentUpdate","some","componentWillUpdate","componentDidUpdate","getChildContext","getSnapshotBeforeUpdate","V","then","indexOf","z","localName","document","createTextNode","createElementNS","is","__m","data","call","childNodes","attributes","name","__html","innerHTML","content","q","diffed","forEach","map","current","unmount","componentWillUnmount","G","documentElement","arguments","defaultProps","firstChild","getDerivedStateFromError","setState","componentDidCatch","forceUpdate","Promise","bind","resolve","setTimeout","__source","__self","__H","__N","__f","filter","every","requestAnimationFrame","clearTimeout","cancelAnimationFrame","COLORS","primary","primaryHover","text","messageUser","messageUserText","getContrastIconFilter","backgroundHex","hex","trimmed","trim","normalizeHexColor","parseInt","BORDER_RADIUS","SHADOW","TRANSITIONS","microphoneIconContent","closeIconContent","stopIconContent","SvgIcon","src","width","height","title","stripColors","className","fill","stroke","strokeWidth","viewBox","useMemo","trimmedSrc","viewBoxMatch","match","jsx","display","verticalAlign","flexShrink","xmlns","dangerouslySetInnerHTML","nextContent","strokeWidthValue","ChatButton","onMicClick","onCancelRecording","onStopTask","isRecording","isBusy","showBubble","onBubbleClick","previewMessage","onPreviewClick","onPreviewClose","bgColor","containerStyle","position","right","bottom","flexDirection","alignItems","gap","zIndex","fontFamily","buttonStyle","minWidth","minHeight","borderRadius","backgroundColor","color","border","cursor","justifyContent","transition","iconStyle","showStopButton","closeBtnStyle","top","background","fontSize","lineHeight","padding","renderPopup","onClick","onClose","extraClass","scrollable","jsxs","stopPropagation","paddingRight","wordBreak","maxHeight","overflowY","Fragment","onMouseEnter","Object","assign","currentTarget","transform","onMouseLeave","PAGE_CONTEXT_CACHE_KEY","NON_CONTENT_TAGS","Set","NATIVE_INTERACTIVE_TAGS","INTERACTIVE_ROLES","TRACKED_DISPLAY_VALUES","TRACKED_POSITION_VALUES","EVENT_HINT_NAMES","ARIA_INTERACTION_ATTRS","DATA_INTERACTION_PATTERN","STYLESHEET_SELECTOR_PATTERN","pageContextCache","Map","cacheHydrated","normalizeWhitespace","isCacheEntry","obj","url","summary","links","interactables","capturedAt","version","bumpCount","set","get","formatTopCounts","maxItems","size","from","entries","localeCompare","count","join","parseTabIndex","parsed","Number","isNaN","compactToken","getElementDepth","element","depth","parentElement","body","getPrimaryRole","getAttribute","split","buildSummaryWithHistory","recentPages","values","entry","historySection","compactSummary","isVisible","HTMLElement","hidden","window","getComputedStyle","visibility","rect","getBoundingClientRect","toAbsoluteUrl","href","URL","location","escapeCssValue","CSS","escape","buildSelectorSegment","tag","tagName","id","attrCandidates","attrName","attrValue","classes","classList","Boolean","parent","sibling","buildSelector","segments","segment","unshift","startsWith","getElementLabel","innerText","textContent","ariaLabel","placeholder","HTMLInputElement","HTMLTextAreaElement","HTMLButtonElement","classHint","item","find","fallback","label","getEventHints","record","eventHints","eventName","handlerKey","hasInlineHandler","hasPropertyHandler","getAriaInteractionHints","hasAttribute","getDataInteractionHints","getAttributeNames","getComputedStyleSignals","signals","pointerEvents","opacity","buildBranchDigest","token","idToken","classToken","buildBlueprintToken","child","has","sampled","overflow","formatSection","lines","collectTextSnippets","root","querySelector","snippets","seen","candidates","querySelectorAll","node","add","collectSelectorsFromRuleList","rules","selectors","scanned","rule","CSSStyleRule","parts","selectorText","selector","nestedRules","cssRules","collectStylesheetSelectors","stylesheet","styleSheets","collectPageSignalSnapshot","allElements","sampledElements","linkSet","interactableCandidates","tagCounts","roleCounts","eventCounts","displayCounts","positionCounts","styleSignalCounts","visibleElements","maxDepth","semanticInteractables","nonSemanticInteractables","tabStopElements","pointerCursorElements","dataHintElements","ariaHintElements","contentEditableElements","order","role","computedStyleSignals","styleSignal","tabIndex","hasTabStop","hasPointerCursor","dataHints","ariaHints","isContentEditable","isNativeInteractive","isRoleInteractive","isDisabled","absoluteHref","line","styleSignals","signalTokens","score","existing","candidate","interactiveRoleCounts","interactionSignals","branchDigest","collectDomBranchDigest","pageBlueprint","styleSelectors","getPageContext","sessionStorage","raw","getItem","JSON","parse","console","info","error","warn","hydrateCacheFromStorage","rawUrl","canonicalUrl","cached","snapshot","headings","input","lang","landmarks","textSnippets","outerHtmlDigest","_a","outerHTML","Date","now","sorted","delete","pruneOldestCacheEntries","serialized","stringify","setItem","persistCacheToStorage","AGENT_CURSOR_ID","CURSOR_STORAGE_KEY","CURSOR_MOVE_DURATION_MS","CURSOR_EASING","RESUME_STORAGE_KEY","savePendingAgentResume","localStorage","savedAt","clearPendingAgentResume","removeItem","clamp","min","max","Math","animateWindowScrollTo","async","targetY","durationMs","startY","scrollY","delta","abs","raf","callback","performance","startTime","step","progress","eased","cos","PI","easeInOutSine","scrollTo","getPersistedCursorState","isFinite","visible","persistCursorState","payload","setCursorPosition","left","getCursorPosition","parseFloat","setCursorVisibility","hideAgentCursor","getElementById","cursorHoverTrackingInitialized","initializeCursorHoverTracking","pointerX","pageX","pointerY","pageY","hypot","ensureCursor","createElement","baseColor","boxShadow","boxSizing","appendChild","stored","applyStoredCursorStateForCurrentUrl","moveCursor","getElementCenter","scrollX","CONTAINS_SELECTOR_PATTERN","findElementBySelector","containsMatch","baseSelector","expectedText","_b","_c","includes","fallbackError","dispatchMouseEvent","dispatchEvent","MouseEvent","bubbles","cancelable","view","clientX","clientY","slowScrollElementIntoView","slowScrollElementIntoViewWithMode","forceCenter","viewportHeight","innerHeight","isRectOutsideViewport","maxScrollTop","scrollHeight","currentScrollY","rectTop","rectHeight","computeCenteredScrollTop","executeInteract","target","selected","center","resolveTarget","action","click","requestSubmit","form","parentForm","closest","submitElement","toUpperCase","focus","Event","typeIntoElement","executeNavigate","targetUrl","resolvedUrl","matchingElement","parsedTarget","allLinks","el","HTMLAnchorElement","elUrl","pathname","search","hash","urlSegments","lastSegment","searchTerms","searchParams","clickables","dataTab","term","findMatchingLinkForTarget","log","origin","isSamePageNavigation","newPath","history","pushState","PopStateEvent","executeSingleToolCall","callId","call_id","tool","result","executeScroll","msg","Error","message","restoreCursorFromStorageForCurrentUrl","readyState","once","TTS_WS_RETRY_DELAYS_MS","BULUT_AUDIO_STOP_EVENT","activeAudioElements","audioPlaybackGeneration","normalizeBaseUrl","baseUrl","toWebSocketUrl","path","normalized","protocol","toString","shouldFallbackToSse","retryable","parseErrorBody","response","json","detail","statusText","sleep","ms","wasPlaybackStoppedAfter","generationAtStart","getAudioPlaybackGeneration","stopActiveAudioPlayback","active","audioElement","pause","load","base64ToUint8Array","base64","cleanBase64","binaryString","atob","bytes","Uint8Array","charCodeAt","playBufferedAudio","chunks","mimeType","sampleRate","onAudioStateChange","playbackGeneration","totalBytes","reduce","acc","byteLength","blobParts","chunk","copied","buffer","detectedMime","header","padStart","safeMimeType","finalBlobParts","ArrayBuffer","DataView","setUint32","setUint16","channels","createWavHeader","blob","Blob","Audio","objectUrl","createObjectURL","registerActiveAudioElement","preload","autoplay","play","ended","reject","watchdog","setInterval","onEnded","cleanup","onError","onForcedStop","clearInterval","waitForPlaybackEnd","err","unregisterActiveAudioElement","revokeObjectURL","parseSseEventPayload","eventBlock","dataLines","trimStart","dataStr","isAudioSsePayload","audio","startSttWebSocketStream","config","events","wsUrl","socket","WebSocket","seq","finalText","finalSessionId","sessionId","stopped","settled","sendQueue","resolveStart","rejectStart","startPromise","resolveDone","rejectDone","donePromise","rejectAll","resolveDoneIfPossible","session_id","onopen","onRequestSent","send","project_id","projectId","language","mime_type","onmessage","parseSttWsEventPayload","onSessionId","close","buildError","onPartial","onerror","ev","onclose","code","reason","pushChunk","arrayBuffer","binary","fromCharCode","subarray","btoa","blobToBase64","OPEN","debug","stop","cancel","collectTtsViaSse","assistantText","voice","accessibilityMode","isStopped","setReader","ttsFormData","FormData","append","ttsResponse","fetch","method","ok","reader","getReader","decoder","TextDecoder","done","read","decode","stream","blocks","pop","block","format","sample_rate","releaseLock","collectTtsViaWebSocket","setSocket","requestId","crypto","randomUUID","random","highestSeqSeen","connectOnce","finalError","finalize","mode","request_id","accessibility_mode","last_seq","parseTtsWsEventPayload","incomingSeq","shouldAcceptAudioSeq","attempt","delay","speakText","ttsResult","neverStopped","agentVoiceChatStream","audioFile","executeTool","activeReader","activeSocket","errorEmitted","sttResult","file","formData","responsePromise","transcribeAudio","onSttRequestSent","currentSessionId","effectiveSessionId","userText","onTranscription","user_text","agentResolve","agentReject","finalReply","resolved","accumulatedDelta","finish","reply","fail","model","page_context","pageContext","msgType","onAssistantDelta","calls","_d","onIntermediateReply","_e","onToolCalls","results","isNavigate","pendingToolCalls","args","completedResults","_f","onToolResult","final_reply","_g","onAssistantDone","_h","errMsg","_i","onIteration","iteration","max_iterations","wsError","catch","SFX_SOURCES","sent","thinking","toolCall","completed","sfxManager","__publicField","playNow","onended","drain","queue","next","playCue","STORAGE_KEY","TIMESTAMP_KEY","SESSION_ID_KEY","TTL_MS","STATUS_LABELS","getGreetingText","agentName","resolveStatusText","flags","isRunningTools","isPlayingAudio","isThinking","isTranscribing","formatDurationMs","totalSeconds","floor","createInitialMessages","isUser","clearPersistedChatState","storage","getNextMessageId","messages","shouldAutoListenAfterAudio","ChatWindow","onAccessibilityToggle","actionsRef","onRecordingChange","onBusyChange","onPreviewChange","setMessages","useState","saved","timestamp","setIsBusy","setIsRecording","setIsTranscribing","setIsThinking","isRenderingAudio","setIsRenderingAudio","setIsPlayingAudio","setIsRunningTools","recordingDurationMs","setRecordingDurationMs","statusOverride","setStatusOverride","statusFlags","resolvedStatusText","showStatus","hasActiveStatus","isBusyRef","useRef","isRecordingRef","nextMessageIdRef","recorderRef","streamRef","audioChunksRef","activeStreamControllerRef","sessionIdRef","ts","silenceStartRef","vadIntervalRef","audioContextRef","sourceRef","discardNextRecordingRef","micPressStartRef","micHoldTimeoutRef","micHoldTriggeredRef","recordingModeRef","pendingStopAfterStartRef","startRecordingPendingRef","assistantMessageIdRef","assistantTextBufferRef","transcriptionReceivedRef","assistantDoneReceivedRef","recordingStartedAtRef","recordingTimerIntervalRef","messagesContainerRef","messagesContentRef","pendingUserTextRef","pendingAssistantTextRef","streamingJsonParserRef","awaitingAssistantResponseRef","activeSttWsRef","liveTranscriptionMessageIdRef","liveTranscriptionTextRef","autoListenSuppressedRef","requestEpochRef","sttSendCuePlayedRef","useEffect","lastAssistant","reverse","st","playSfx","beginRequestEpoch","invalidateRequestEpoch","isCurrentRequestEpoch","epoch","playSttSentCueOnce","scrollMessagesToBottom","scrollTop","ResizeObserver","observer","observe","disconnect","stopRecordingTimer","resetProcessingFlags","clearMicHoldTimeout","cleanupVAD","stopStreamTracks","getTracks","track","stopActiveStream","cancelActiveSttWs","activeSttWs","recorder","ondataavailable","onstop","resumeState","getPendingAgentResume","requestEpoch","freshPageContext","controller","allResults","tc","pending_tool_calls","tool_results","agentResumeStream","backendBaseUrl","sid","appendMessage","updateMessageText","finalDisplayText","handleAudioStateChange","toolLabel","prev","last","finally","startRecording","previous","upsertLiveUserTranscription","clearLiveUserTranscriptionState","finalizeStreamCycle","runAgentForUserText","normalizedUserText","handleToolExecution","agentTextChatStream","stopRecording","options","discard","navigator","mediaDevices","getUserMedia","MediaRecorder","recorderOptions","audioBitsPerSecond","preferredMimeTypes","mime","isTypeSupported","sttMimeType","sttWsController","shouldDiscard","currentSttWs","fileType","extension","File","previousUserText","_callId","_toolName","_result","_iteration","_maxIterations","handleAudioBlob","AudioCtx","AudioContext","webkitAudioContext","analyser","createAnalyser","fftSize","source","createMediaStreamSource","connect","dataArray","frequencyBinCount","speechDetected","getByteFrequencyData","sum","silenceDuration","setupVAD","start","startedAt","normalizeError","resetMicGesture","handleMicPointerUp","preventDefault","releasePointerCapture","pointerId","wasHold","thresholdMs","classifyMicGesture","timer","stopTask","cancelRecording","windowStyle","animation","headerButtonStyle","statusPanelStyle","flex","whiteSpace","textOverflow","recordingTimerStyle","fontWeight","textAlign","micFooterButtonStyle","isVadRecording","disableMicControl","maxWidth","initialMessages","alignSelf","wordWrap","onPointerDown","setPointerCapture","onPointerUp","onPointerCancel","disabled","DEFAULT_CONFIG","isValidHexColor","shadeHexColor","hexColor","amount","toChannel","adjust","channel","toHex","round","applyTheme","ACCESSIBILITY_MODE_KEY","GEIST_FONT_FAMILY","GEIST_STYLESHEET_ID","BulutWidget","liveConfig","setLiveConfig","configReady","setConfigReady","cancelled","res","fetchRemoteConfig","remote","merged","base_color","agent_name","isOpen","setIsOpen","setShowBubble","isAccessibilityEnabled","setIsAccessibilityEnabled","setPreviewMessage","previewDismissed","setPreviewDismissed","chatActionsRef","handlePreviewChange","toggleWidget","newState","handleEscape","SHADOW_STYLE","widgetContainer","widgetMountNode","createdContainer","isInitialized","init","link","rel","head","ensureGeistStylesheet","runtimeConfig","resolveRuntimeConfig","containerId","shadowRoot","attachShadow","replaceChildren","mountNode","destroy","isReady","Bulut"],"mappings":"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","x_google_ignoreList":[0,1,2]}