@auticlabs/bulut 1.2.4 → 1.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -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\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,SUQzAwAAAAAAMFRZRVIAAAAFAAAAMjAyNlRFTkMAAAAXAAAATEFNRSBpbiBGTCBTdHVkaW8gMjAyNf/6sGyligAABNdov9UxgAAAAA0goAABKU3rSbnuAADqsxb3GiAAAIAAAgquxf5wYHlTszVr4DAwqOYEwrTADhW0IANCZE2vWLKavOz9/F6+/0WLHNWObe/zSl8YWU1ev+79/xhY5qym3vNKSw503Xr38Xv/lGKU5hYsp116+9KTdevXvsGZnfGFixzViztbXr743eaU6Zm97/jCxzViyk3bX3m95mZv+XveaMLHNWOdt1798vecpMzN7zNKUpqxyt9w2Gw2Gw2Gw2GwdBQABVAcMBoBkGhwGNiiqgiIAuTBxA9MCkAczDwCjH9MIMOIAQZA0MAMDMwTQITTYLGMDEFAkB1MAcAgzKFTDwgMKW4wGdTBAZchXKGCGJtREGMg8Ztfapl1NMAwbMMhMEgABCQzWSguBTHZKMgpNy7EvQ4mHgMm+n2hcmwYROJhgNAANBQfGbWnRzVSeUKLfmDQOj0EAgHAiQmGSYEH0zSBAaQRCFzDgWgNxnOhneWlYFpsnTDfZphe0uCUCUHCItMzMx2NZr6buq7sv5IKebl+ovKJYXYEYRMEAwAAkBAZrCLiryUCxWZndZ1ufjLLtun7z9cw3KV2smpItN4W7snhn+913//H/7n3+65hvuff/C5utnq/Vq0tblbOtX///////////Dfc/5rn833/////////+9Vs3OU1etV5V5WAACAgAAYAAgEAAFAoF/+f8HSOv/9j///+3//3a///////q4gYWT////Z2V2O7P////+QSOIY9ybsJFoAAgAibFUDi2RVAEMCcwKCMwYE44Qk0xmHExODcwfC4wjCAw9BwwEcw1RFw//qybCydFggF+WhNv3aAACQA6R3hjAEdLZ8fT2jzwJUB5jwQiATE8IgEDTbIKjSA8rAAIUJSHo6LhDiBSonoiRNCkgFwABzYNVGBeY4KSIMTx0gIrUCgEAocFwxsoyJoWUTSayiLNAWCgMBRAo7lsRogiRUc4vJJGRebomJdNUdFEuotUoySrRJk0FnEFNdEumrf/6nfUk6y6XTVFHRb9dSSSRkkrak/1P6Jia2qSLDatf/1pdFjxsjSQAC4LNJI1MuFEr6cABlkgU9tennKW+T/+/rYtHR9fq//V/SR8aF+2QoB2YA4BhgAAomBMB0YFAUZguhuHVm94Yo4QZhIASAQBwQgZmFMD0Ynbtxkbh7GBwBaIwJhwC8wIAHjAUBpMVwBooAtYaDgFQaAchmYHYAQe8M0Xbs1lVIwqk3tQEKxpo49+kGQNnPOMOuDhKBwICqMZ3IDEAFxFdfq+IA4cZLnN9hlUXdDcVhFuywKHvyw3HEzpLZyxiSo5Iy7O9TQ22ZuTzbuXJUoqW1i8O34a/eOOo831LzLtLAn75ickaiHSt2IsYRMvFIcyKaaDx0ljip9jTVGtytjXZ2/WKvoS/+pbugRPolAACAyNltP5hqksGTiM+fVqrQnJl6E/b/pNp2/J//0Rv7///+qQAENZNxEgwSQPAQByX4MQgCMKgymEwMufTDaZjVBhhweidJgCgWAYMsxzXNjKsC4MNsCEwTgHiIG4s0IF4wfhEIYJBLLoCVGIlE1wXMlKkY1GIHChGbYMmCBbBbFxdZgRwRCz3swlUvFUgONS6stlmoJUOkfc+SshAQwRR5at3Cia61mK2Pq//qybI6aQ4gG5WfF09tb+D8DyT0FJRkamZ8Z72Vx6UAQZPzxsZSlreu858AKFZ8yYH0AJdZB7wwJqsaDmd3CYYtl6dmgX1DjzAPMQ2cov63q9sjHprOd5a3qINfm9B99b7p19mD/jet/EkEvH1JlX/186jfz2XrEbP9ffUAACAlq5HJZlkyAOjSRLokDE0fB3vQjTZiHZpB8aLjQ4LMCvcnpQw4MXZxfo9We1f/mD02us3t/XXVvdxT8sAgUfa6sohgPKRxAB0CQMzAmA9MIUTY5xRygMNkChMQMAQBAETBCAwMP8eoDM2JhmBAAS0xppaowowZBoANLBt3kgczqwH+fH5tBptNMHEjiTCo6YbErUdJTXwnXNuxARUBKsId+BqaCRo2WSmdmJW6L+q1ODYylM07+E1II8jtDT90UfdBP5Gq1uzXjqnpbb3bwd6Hs9y67ZrXEXKmwfkl125QHYk5qDVai1ylU3Uvf3Xo/XtO/B6ycy9tIV8ufcR7TFG2sb1PzsXrnl//8fXr/PZTNRgAAAABTb9WZJ9/DCyj8OR/iA7OYhM73BCOzjkcgHq8HQtHdvZzmuezk6QlGaOBNXdyWLBwW27N/YwCxQsTCIuGDn9Qc/9PW3/9e2n/6/2VVAAIHDl32qcbC1UwqA8CgxzAHB4MBUSM2wBGjAyBBMIAAgIA5MAkAYwRgXzAdF3MoQFEwMwFjBQA5MBcC0wOACxQBEBBcpg9iMPNBJKBm0k2su/DsSXG15g8PxdsoVg/8QaNStwJaCXXPaM6FRrkC5UsRli8yIrK1WvxLXZprEtl92Zjw4GIYz8PwM3JHKH5+P0W5//qybPw7SYDG4mfGa9g0emKkeHJrDGgbwbsFL2BxyXYSIkidMHAOOd/8XpvTuVXs9Hsr+sJyb/FB6b9Gke7miYZ2anSnGsw2d7lIviJ7tJbXi9dpcrZhcHkJhBWZk62tof1907Nd8j1/z4/lDSkpsdFDXypuhACJTp9W49UQ2kTJQhAAYYQXS+mYMkSHwQN+KCKxuJtLnZRDFR2AR0OEsCritQMRWX+/C3gmPe98/uNnis4CJ1uGDziH+l5AoIm1SPRP4vWh/7NvR57//p//sZqWAAQY9yIPB3AYCgwGQeTBvDEMBUG4wxDRD5rfRMJsSYw0gsUfjACBSMQUCswC2yTUSEhMAAAhCcYGIGABAFQwMC0EOKsJTdkLBwq4sujqW2Xu5xd1WhTCpDliZEBY/BcJk7BhgAPpKWJM7bdm0rv0VVulCKin2bNBbdw1Tw09y/pmirPE881Wzgh0n+rw/jqXSqW3OdrSzHvLf08UjHEGAN2pOLMEmHS65iWnzx9pvPjsWWpDE6YpRJBNI1H84Vi8NPJwYvScUsvyvhsaMTQNSKwFa6cUeQC3424s8VnkMy1VQUI1VSUacJYjxGoZbu8QEIl0igAvyklXFN2T7VI3QNnlD6NGwcpEUFY1D61WhnAklkGa1dFa2zSjx4S0FfOORJ+vbnJJKDScV3WFt86mpHp7P2WWf7dXR9RlagMAggdHSXSxNxujhDABMXCEdBRKXztWCXKb8VgYmQgDmGheY2c5jIQoZGnu9ia4hPH41L3PCA1KwqKxhlT+ULoXk7nIgXPdNDq2H/kNPF3lQlMDcll8Fwuq21aOT9BXTIia0ncp//qybATdMoAFbF3He5lDemLkmU8HDA8cKbT+z2URiZUY5X2GDiyjO6Z/ZeIiyH4oY7QgOByyxBxWsY9ulihKhnFXPU/aWsxFKjv3z17ZBLXztSjLrG3/fUWMXv4i+5/1ixtR8114y+yfZ1jVsKmBNQhReGe22xOa6aH0a4iY1rqE6gC69RxwWQr+00xTqSIYgvihSUvHKkOF4tQlzj4KJlEXJJSOuM0EUdT6LqOVmk9AenkK1+7yJ7p+bc+ZB8HX/xrtP/6v9Ev/1Y7Rc/WIEWXAECEADB0AJBgD46AwYJAApgKhnmJIMEZf8fJjbBpGBIEqYNIGoBBAMOMHsxxBmTEdANBIDCKi+y4pgIBBmAuD4wkvi80aB7KHM2h55k6kkwzN4EnCQJMSDsYQ0yvRKou4+YXAIAEsDHCn1XLTYvLMWmQAvS8tlVF7Ifjjks5jHaSWSph1NO4zF2bg58/o8JVGj6qqRoQpyAG6QeHRYPVsUkoNx11TXcNbTaXyO0p6JlsVlRyJEE1MP1HytY2qx00KbXzzdUiy12W9zUH9ExA+9a+eLh1a6Ok/8C4eBbb+M+0hooKowrPb9q5N+6kNtKLfg1UdV+sDIQxLT4U6afS9mOKywmBJo0CyOxILBcNDAcQ9K5Z/YXlLUf+ORFBGYm1lspkZCQSAWaN44tOYk6HBLXrhWW/FL//61FF//7bnWOf+v+jR/AkTCs+Rq7WOOSm4QAQKFzBjkekzQboFCYyLGDBilJhgMZMODx/XMPCAcDl8RECgIhqu+dbkdZ2JRGLZoH+xk4fwKRVIzp5WsadO8mBOCmdFBo/EKkasHoxhAAlp//qybGdaLYAFAD9Ha280WlSGKW1hY4sTjZsbrSRcaleYoSXHijCYdL1dGYiFZJqmNwgmIT0afKnrbR8eH34WiARBD9/mqbvP/v9s8+KcvX37MrZrpOSqf6v7jAfukpn/eY28z0ukr/Un1dSTC4+2W2fSUa/CUJaOWLJnFay8ydyvxkLuYPNFXkgBgNuqss4fHKwdRAciUpPS+n1n2Og4hdff9McWHTnxUVGcAFiDhhq07Dpf3PlyE6vf//b69H7g0LhG7XJWW41KjsJxDoEwCU9n8ygQw5EMBGEDA40BlyxlfoDlduiraLBU1KzNIAZzADOZMzqAI2FCQ0AWEazViWEBVKbVSA4g7jkWpZjMUX7mLrlKJtDabQ2a1LCI/OzLyEURSLs2IULCNBf8avP459uWCMa6pRkp29rpM7XIUjkXa5FOt3ddrh1Kj/fotz2sxXI91rfbnpsl481LAAAABArvqPaJhhUCmDhoarZ49Hx4iAIYrqMIh4CwMCAAwYEx4BxF6lPrGZWu0rTAkbjtOpDlMaYtAP80hf2YIzQzSqDShfFevJNs1iBrE+T/0S99K3WVben7tdsSNL9xgs/ZtUibVe9uquLw+bFLmuTPJVekCqagDPJXNE4rSQTwyYQBjGxTGlDMePFFVUbmz41Ob0h9BYBlSEVb9/rdu4tFfs5PDFgL0pChVFGhIYIc1NWaKSnHMuq/i3VfG5IL7i55DEsVUtk+Pp2SIjIkjuDNyq+16zWi3xsFQ6HCJYWYx9LRCIMYOxQrnQ/ajfbhwyWtDTzEif6dDtCClhiix5I+hk92D6+ZvaaA0BUKFZrv9ZbsuV+k//qyTMJsQIADojHK+wwUWGsGKU9hIrURyXMbrTBYosQxYjWkj42CbIGTeF6kATrJxlzlmRpxp/Fu0ByWMRaWwZFcqtBLKRn6WMt3eq9DcSZcqkBCrj0Wd/rjQFASEFWLOVLohynimFu46VS/+lWG2oZT8NcB/GpsC1tlLRTZfaqrcvnKAkKi3GXnWW5OagtfKXwVQH0Nv6Y8U4AcABRBO9SsFAUJajt9riYF9QGJPa1hgML4+krrrZdd9d58mH7ppzc1MLTAuBYSC+NNBlAzeFITArIVVjUJMNrHMTA9WEtxK04UnuxjOa2m9XBp9hT+T6/KvdHMVmSDVr798qo1rdLOpV0ers5FU1AqwcebZc6wYQBISEhJejRRbyVGxlAFL4xRk/1AwwYzo0iCGWGGHEGWVjyWAwSUaQnQPAR4CnqzB1M30fpyJfFp+RLxYS4LN68qiLDsm52o2nwje9IkMdFxIYke4bfWcjM+lu/gsBmXsj7IYSj2/EsbAtZMmULcUTU/ZyorOle/IpoWxdIbuYMle2AZEoNSM7O3goGMBOOOamykewT/LtVuRs6R0byIUqZ4J7CWxxZGxiziDGBuwidiaMUYc+inJElIrdpYAVGZONHHni7AgFEgoFDQVAjJzUMM2ICwXDMfBIIGCTXYtyjXTAby4uxXfx8lnvBD0xbtx29qIzkjz6zl1bPM7euZU7zMhT3cl9YzZqU0/hLJEcLjuUqqXdGXkb3fOvsV3E40pYfVXInWHO7uWuTFS2rb/P4am1brROrIeTGWXmdlp58JoIRDhStTUZQ/nPgzRBBBxMLj9db7rLdz4jCAu0MKDUtc//qyTP2mV4AE6mjF02kfGHYGGT1hgosScV8hrLxv6oYzY/WUj41WFDZQBMsuOkxPsUZk9CiqGMWhg8OFRaK6EwXmRP8+emFe5VxTU5BuNAYRLo4HuYmXymWiqfd6fjGRA7iTB5zqRWK7al9uOx/D71sYzSIUoHo3WehzByQiRZjQKvim9lx4+1dyhKNB3bbv7Jd34AWGAiAg/K1GDEoRmIg04ErmOmgOkwkkpNnYiow2SVGMiuLFEXUA/z9NQrjzbYkKtXCM/it+TjOBrYdduw+unUdEDDUlYLefxbEMVDjl4Xla3CjMTXK4Oca5BuLb9WkECv67qf5ZTLPSsfFaz+AvW6kcyflLb8v/pkuUze3BTRL6v4dBb9ZClINt7Vg0Pt1v2sl1/ajiTpAQI2TXyZSc5AKKcsRmCNFazuoInTcEdNMopcr+vCwtlzIVHqS06UuMAqnbI693lWLurm+9T3RZSu5lMelMcnssKWJOiuadak68ZhqWRmBNoXrnrETG8nEJBBiOQ6PczLl/ZeRGJL0BrZeEZZq1IutDuRdnCPbolMpoKRI+i3tJzt3JYcXNwn7iLUodOQrwtRzazGnFVSqIglK0uhwMGKwoDiseEeZrgsmJweYOBaUBi8TjXYOEh0woOgg1KzlrTCARAwMLiMkfxkIQCW7oiIOQ0rhmZbAvUtdZsrlM812s7in5l7l3o/pPtMZNHGtRHCWyTcMsXzb9r8If6AqWevLLlAkKDTnzOs6SLyVQXC8rYbkkA2siY0IVTaTELq5AREzl/cMZ2A1Uj3GDuS4RclDrG3D3NydQhMHQwxvxnEAkkONlwA3UlN5Y//qybHoMWYAGPnc/i4kfEqas+J1p45tUDVkZrTB6aXCQ5DRspHwLc1EuczKGjZ6msZ9VUE9nEDoOCwAGYhG0Xm2Un9axFBEVCjw88A0AQxBkW5CxAwhI2F0CAhIi2BoexgeNQiz6SqT87SKQTkeGca7FSKUPSyPWtxhrV5EcrwqhjD7GYdCoilKpZnK5cR5GSSWZ+zotTmenW3PVt5ZGHDC++9KbGhMzYjgUKZyGKBHdTBL/WpFhzOJ3VnzvcGp2Gdm1MQQZMLNgbwhlIwvbdNtTQiWKMKCgnwp5F7XzsgaBZb94std0sbky2zFFcYfhQ6dXyG7xIUZkAZsGc6KI0Q8zcsBImeuYw4BFWMv8t+bXc1lpkSak9zlCgJTmnvVbMBp94xuQy1r71tWXq7Cx4TTVq81QNnRqLRaaTg5rHaUWL0rjKe5+cxV+CsY9L/IkQyfOekHv4IPsTdUsj+mT0mzRHlYqyBy4KSuiMZMj0h1rpd4FyGk5ZcuRGzYWBnXlJJSrJhbUpW0ko3FBKKAWMNooLgtOf8aJNG5YdzLD7OLEGIp3M8k8OOFXilekaANCI9fhsJsNKoRfAg/Jp31FaLnRWmj2odiCVJGmz3/PULyCWUc4mKf6vZ2//RZ31AECgkYnFGm3O5PC6xeUzE2AqiYMDgQFBASYiLGDBZjk0Y0FIiMRd1JwlgjpAj4O1URjcLmHWymmnG4/UOT/jQ1DVDlDlPFiDp2wMHiQsySvn5zGOdaLtCgTOT3cKMfsslMQYFG6JposVrPZdxIBxztUXVkv30fMZ99n0orlPLe29aLsxyEMsb+9nnFSdEUiDQuOFUEA//qyTNcFSogE4VzD628r8H1mKR1hhrUVOaMJTZh8AigpY/WWCt00PrRPI+rLB6ZHTay3Vx3n5u2kiQbOtkAJHpsj+ocUJsDtnTHswYucmNF5ZKK8OSOPy2pfiq0EIIAnKXTJgnpPpR4KwVwdrsW70LoBw9H933IUEkqsUWsSbVGkwtJLHuG7tr1v2SmBnTJuhGjA6igEFTDVi7CX8fLm77TD6yDTqiY2qYjyBZiSLSluUbZeICo1aXMS3g54AAkDiMaFzHQIYETQBUvSggVsbkIgpKBTy9pNt5oASsk8ucGVF20oV8KwR2GZDGobpe1H5WwpYhG4DgNYgqX7qT01RrEXU3Bx9y+1Arh0pjUHWEFSxgGm+THgxGpkSeFNx1OxRl4SXVT/1/COEjFAWAvlaUxNf/zL1nXC6O3DeOc0qA/rarFrQvhfdEzupUwd4Be7c1FU8gvBseSSeWOSc+UM5R+DpToRVopwcFeQOHCm2Z4Bi0QUbCAWMv9Az+u8w93nGf2CKWoreqx/pPhXOFTSw1MCWOA+A6Qx/ZKTEuHWQFR5BdsshuQNj/nYb24+re381yLT9DggPdrKhNOulr0s1no9tyJepjFR2yLWUjaODMW6CTuh3r9V+7/brtyO32oJASALQTLchGAotjR8bbQmYF5hhCAgJ3xgUMAR1eGJB5QNuuvEdMMETjWWs5wVWxS3F5ZGG8BgU8YHkti7ayo5dKZY+yqilLJ3Lp5fJJXT/csyxyGNu44cTk85Io3A2+c3rPP+673Wu/3Lv//6/nP12pwQIpx0py/8dYc/6pILsPdJ74+r2b7aAZ72hTF4FnSmPRis//qybC+KSgAFFTHBtW8AAqaGqCGuZAAfwXtH+byAAVkP5Pcy0AAK4W/5cjnX7v9/+P/zzuhBK6cqAMMCLnmdCQcciIkNDBAAMCgIsCEvSY+VpgMRjQGUzVkf8u8doKZq7KCAUgJKkC96m7iv0OEr7e6llkXlEov2JBRS1pcgZrIaKiuWv1ZqvrLXdm32pJTJ6KBa+vvzEvpLFTX49q7w5jy7+X/3+fvXe5f+953Opk9BsgqoJw4da42TjlmxRD3gSkU1DpAadirS1qRGlYq5BMgKDi4rHj0rD7cOURqAIAEQoZGiRpxey2Xa5mNzh3yakoaSlpHhBAZuJgabNoZAaSHeCIXBzHiIrADR11mZuZcvsBOKdmDuEGhcqJhwbN2xmKQZ5gEnRtmCARg7D2JyM5xEXU2gwZUcMwucV+/nHVQlm6AmK47YzgOV3GZHBFA86V8GQJFMwyoRLDwaHNw06GTS57ozua6rG+kCShgDJED19KTdWiTeLk03zvPkhfZdEhl9m3hLK9soAKoKtierSoJZb7SM4/Gd71v+xutLKlJyxXty+3TocmQvQ8MVazSsI0+3yR3q1r8u65l+ffl+sNYfhhyxzKknpJDDrSXKvO/flu5ae///9nUwMBQKBgMBiYBG7RaPRMliLiqWDRzzZMQ8mCa6lnEASY/jey1qvQ3B2lahxHQkQxwvqaKnplI3JUYj99QlJox0T1n1ddRi83/q1dBXjv+mrs/5q3xl/RXQAhU0EZfAIEAIA0wKCswvC4wlHQyvTA430MzoLkyaEcwTB4wNAswcI8zArUxTBYhBAYA8tqRAeKgD5VTLDy1qlr+v//qybIorIYAHNGdKV3dAADRBSU3npAAYtZ8br21twOIIZPQXlGBRd8vypKHYKL3GRYB3Nzlwv9ZoEZlrO1FqZlQJRIMINBwKTxFhqONDEsJp/hGEMqEMOEda1qUt0WGUua9D0afaHrP5ayr1Zbj+WVa1//vdWzjys+ymQQWrS61VhlyYrz/rymdxxx5VlVNTZb/WWW8eZRp/neh6VUuPMsu//41aWzllWlUNS3mu/jjz+//8///8f//1lc5///5///////+v//79xgAAcABAS7/+2MQSjP1DlVPpSHaon4sRYqKC258NGH3y1vrd+n/7Xf/RZ2+mxm/2st20X6CAAAwMgBvbmKgKoPAQCEaCxIABgKG2YezSxhEgcmEIAIKAMCEBEwQAATEKNLMksDUwDgFQMXmHCxi4eYOaH5gwYFuIxKSrpBheUHgOmTAgGNKAq3Gfjg6Dp4T/6hvH/u0iWyBq+oG/8HCty393GBKiUpg6/yrutIh9NlQIiciebhWMkUIgkh+PmSLmlA1h9IVknA/AaKT7LP1zPBnLrmC3d1ubPPPP5xJ/7H1Xto5xUvfx3EX7G6nzHv/mCr/+I///3L/1p1QAAAACAPN75xuDaeJlw698D1f3d4UKumdX2nF2etXyruH0mlilv+e9npGetH/R/4UIfWwbYprbXAABPfcsbZMA0AYgAFEQAQCD5MBMHcwmAbjLOd3MNAG4wHgJ0cyYCwwrQTDDWAZM4kCgwbgFh6UAkqUIozOFiEAddzCWYQCYwaGSwELcGkfYlDlEFEF9Z2taMICY8875xJNoxZFS2mkFPawZTRY7s07WWhx+XY08//qybJFAO4gFumdFU9pTcEukOQo8bIMSAJ8ZrXuEITKQpPT2IaTE5AeJx54LJxVzyIMQPEBObiaaqmGD+xmVMKGLlkMbYdpUoTsalipib0Xs9ZjlW9D+k3d0boyL9fOUif5v/1/IcAAGkriKT+M253naMDrhTpMaIdbyFv5MutFuNDQoChOSsZejtHH6kkhiEvcpnfM5mLj9FB058xhxYMi4xZLb4G/s7//ozP//dXrv3iBauJoFEmE3SQwasaYw6cEqZiKFwGDeBRQBAMBoTMkBQwNsD5ouIAaYJEwQA1KnNMcCVoEXjFNGCwEg4vqWO64zgAYAAIgsQeaas1X/kX1Z6Yg2G4vE61uo+fe67KII+1e33eVPf1r45cywy1jPViKhYqdJVCJstep7p7ci6grrcRexRe7aggJlrO5nA353I1gIDKazyxtzfhvIygAERc3a9dCR2EO0TAdfSk6138WSteerGCy6se857HVDmmgYaZyZrb4nD/x1QcIA4aGA3AAXyf1+rop///3f//7aBAgGF8njYKc3t+iIRMqBgLPiZUxgADIwlTVaQGDgDuG8hS6S6cnfZuw0JWrUjlT/ISnAWbGIxZnnHd6vz+Cz5nmpiEyFiYm5Ui8Fa0Ni65+K6U+3n6fRMglTMqpECXW/+z+j/32aO/drcLalAABBiOqVEhD/u4KHrCHIVxhuqyUGkrhFQEKQGmY6sWeBn05ZlDuubCIpRx+PSkEFLnfyGec8bSktSZCIF6mzvh4HQs+nDjDHGmKlUM/0hT////6RAMB1Kr7GW2+eJA8cc1wx8Otsww+AAqDk0mUggBGC0EXCdcvA//qybCcLcgCDYSRIa5tJ+FNkOL1rKT4OmI8hrHGFYToQolmWGeiTpMCJlHydyETzwd0yEWFyAc7rk2iZpF7LJTA/g+ErLTSF/HkM8JBSY/sPmp7YAqBXPRNtvyr6kb2cctqlTsdAjhgRvtemCFjHTl2qbVta+5S7CDzJuDgqhQTH7EW9a43Bm6PxmqncKxBZsJmhyCERUhGeODh1xqG4PLzpAz5Yra8pyWqES+7/zekdSQdPNuDzCChNbA5/r/RT/1///7pMQU1FMy45OS41qqqqqqqqqqqqqqqqqgDzScaaSSZ42JuZggA4hBIwMFc60NUILEBEOYBAAYGhACgRMVSKEioFgMLkqbOhwZBOfe9+pnNTpd+qJnQD2XweSM3lfQ4425aeJ8YJrHHFnmlzbzQW80FChmLb1mV7RiAyMjiBIulUn0/qFegaI3Mvta1pk68eEcOuW9kx9D741fFVdSfUZaA1Fk13kKSHYVcedAMxD49Ivk30QXjDMxMy+LPAijKqM28veYHxxhypDAZP1phgYM+sOAaHgH1BywdtV69NKpBN87IYkE1BoPIII/yGi+P/0/7QACBOdahIJWRsATtXeYRFkebpmYhiYlUKgSLAiYDhEYAlyZVBGkqMgLDCBqVYVBpY0+tjBajAV+SOJsDfkqASr2JwXlyeg6PwXBq/XnpmFQev6np43rWrSQhB4TAOKEUAHB0qf51osukK2VVrQpL/ynU9rbr3mSNinyMxUE23JM/5GmRk0TosY+Wn33hOZkSwsgdO8jG5BvhkK1muthETvLW2YFSMED5EaHosN1tWzjCEiVfUh4NZXNY0205q//qybEr2y4AENjFEU68UUFLEGR0bDB0WdZEHLqR6gV8Q5HQcMDzDKlFhK8SSqNCFpkpk2oHiCjD4Q88xdqERDTBhwhMLTzT8Ml6DvT7/ZA4ZD4YvUZlmchu+mRn6X6LX33Hk5MGVpo/H/93u0rR/fViv+hVMQU1FMy45OS41VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVUtDQVyy/WJyniDnZCNJqs8kHlw6iJKsl3BesamR7DZRZ+E+YKdVajRpTHhvSY25Xu3OTktxoNb0e6HuZOR1H5ZmN8OPmyIROKG7TnlyVv7tl3+UGLUtDv2O5C+YTXe8qkBSRADBM4z4rDR0tC6qd9uAFFCA8LAwYFFUhMXgTJBUGjgODn0aioAhMLfO2fBCGdQGTGwqkehx7J3LI3Sv46o8CKMMvxXI97BhteI/gM7mujk+YOH6vZ5oUKRneRrQLXrS/ndn+djghDUZlJV59utHe6Jk79L+mlisttHN2q3vM9n0aV8LTD6eGl5euq0P+vzn83j/CW9XpDo0Ve0ntbblHlE40FYzC8MS9HMvAZBbAw54mZaPGUQX2eFLdK6EQRNxx3XXY1Grb7SRajq0GGOSlCUL6HZ0D5oFwsZLmbtIoIIwkHlta2ocbpN6PrYrUypxu2X0S29QpTg3yKBURrmRoVoEwnMg1o49DzETgUmbRN0uZDEMOTlTJJTXCrQSiVMjaTTalFocWU/gOaBe2bNsYwWgFKChmSBg+Zgh78LNfuwDeFfZjUZXZDDWOKG8ZWsIel3A88wE4nKxUVAcxbAwEOJsoVarqYixm4o//qyTKRB5gADACHJaDhgaJiLuDZt4oxQoMcdrLBW4nCuoamnjfhRZ/l/TrHZxbmVge3hP8t0ka0F7XeCeUfYiKqcqm5Z3kPpf8K6zl1hp2ibH9+/amalllkXZ/v55eZm5KdPTpgx7Yx6CrA+DJnAydLvu2JMQU1FMy45OS41qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqgEEBEr3KAw9EbMvUcNDGDjXgHKSGxgAMXLCBkkTTPwF+DChFAS0AGAq8IBhhGm6W4qS6iEoo3S9WGYArQ00udOKabVItq1nQhXSpRAHY6pBhth5qtjC8YkRHTCvSC5g5jBTuYV6Q5NVqSzyR6hAtOEP2mbM33R9tX894mSkxAuyH0d9bquKFQrEI7jbNT8t4ZlIav25S1MlStDU0UaE/1KBWPqv6759LPrNSvOu2LZF9lyyxCYLHlpMMZc4zEWAiRl7aGO/QJ/rKr2rnMR4nLJGpLqc032WFYICTTmZnuXIj4JGAacvcs3c6TUNhCsYFtvWkOzHr2viKKpHxBalunSxn5IsNYhb2W2KxiVgMSCtqO1kEqEVK0CkIIYQonBEyMhgY+EBqKpiZWYYPGlh1ZS1LBBVnSrl5wtHOKsAdFC0ZAVxvFAF0JOwMLgjH5SKxCEq0kHCWCfj/Nky2thbI9FYnk0EKJCPRKqCRmKYZ6M1Xzk9bo2LQ25nu1lT7JCLmZs1XOCMyWkhe0j9+W0GKoR03WFmVO3CMoFK1JzTiZZZRuir0/emuxCd8N3xYscmE1sMSo6aqxbc97Ik4Uow//qybDD+3wAFAmhDY28cWGwk+Jlp6YQU7Y8PrbxzaWEQ5HQcMHSBGUeYuQiU26uIkh9JN9n55+i6Nx/SdCrWEB2EkFdYedadiduivCsBUoRrkq7q/N+hK5OKTjvL+5eGDAYYKuZVY/XyP1XdH//X00f/qStMQU0KCsVOx3NlOY/yAgShyz3NzS3AEGzlLQlstaIro8TQ4xoe4d01kvjjAVi6CHKNQqmPakN/nxKORpqFO0nuzW8O6hFMQDY1IyrKl2uG0xsUWUEReTFJ4rQWzZH/RS9JtFiF0PKuacrGJpYki5LXqNV1k3vECgACrajJJaivXhZQl6McBKCKaNdE1swiOkBYbLi47jSlZZMT3Wfija6wWB3Lf9wY8o4NThuG6lv7RHkckEtgxQo165RHA+ofJIlYdReWOlJYLUnWioQLhYEF7epoOXm8P7VZRZtEGofCkUUWFhRCAKZcTBgWNyUMCZSiI8NpDaidbVqWzyf3FwAjOJqaKSv5sIkw6FGIHoUjC/6BbGjDQ0SNAoxIGl2S+zBS7AMllISxBcHWdabUjSc+1QYD5UnheFRiYmx01Ko3h5DBSUdWMLKq2pJtdByqJCJWSbpwzF7x47lEexbW3ejzYkSavJljF7CRI6/Xp6+TbIZk+9bMvekaxaZU79zNO87mFMtK7a5JcqmqJKhMd4USSFh85b3vBwi2nNNA/a4stAAJA/qqsvqQ4xAFCQWDDh08enTFBUuwUGrXjBDIaQQMBEUC6SNCjovhOVlcvZ3B61E0mhy3VINTMRnFljxRFszYaGML2chUL+BAWTqCyO9Cs+zkxVp1DY0xWpnZmY/E//qwTGxE/gADoCdHaw8TeIcEOGphj7IURaMJTbxvwq4zIKW8DbhoHMIYC6kEoE7V8knKoWL4kMIMyOLVNuJa3oae5tHK+ZGKB3akbdQy8uZx+KRRBe1d9neTzBAlMyXQnIkjy5FPgzA2Ql61I0IDyEiExUxBTUUzLjk5LjVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVA1N1NleLfdVHe/WvsjKqSRKzBAR5GapbsYXA64clo8IJkWj+JheO5steEgkjyEL8z9fatd70IycJE9Zj/293Dcuv1mbwqV6Q5FGlQLD4De19jA3/4/tZ1f3r6drN97F7/oLJARcDjjUSIBWvrVXCIHjutAhDWy1L8mkqY/gceLFQPLHcXWw2JSB5oswJlzjQxDmppgTi3oNwrtJYY1TBeWDyDMnP00fJaZo0S154YLbRPmCJTIxSFRihFXnTJVU1V0Y5qw6n9/XyMyPt1R9LV15WVVmnutqe6Ovv77KiHWynDaTcNQOlUSK663WNJvu5QquPGm0OaMTlABcKjoVBkJhKGwMwt+n7ZmX3BRkabk97rK4YK1iikD5tEERahbWrVqicM1i8dC2MVgRh0VS8oSFPWX0QlrAAQqkgeNQlFZdf9MIOrSrWNWqRIYg/Z4e0FCiJ31FRliXOP7mSZ708qWcOUyi9d/MFbc/lhuD8tJRM23T2txo7y3kf9TlVADDQbjjbRJBw7QtxUoMebOajCEJQjMQGFgZhi5hX49TVEXiUzZov0MpyFzmlRNLZ4WGSaBYZfUFAyIyW7dKvRQlmFcrQ+ASL0DD6KUVosqL/+rJsbITmgAMYKMn7DBt4g2xInWWCtVLhRxessHbqdJth9aYO3LaPx2Py0STMrIW0yXj/GOjrdayx07JaXYeEBi3GPLPgV4OsFy5GKkw1MMEgoRDaRrhUSzzBEAFtQ0InmEXgk4QBJTQ2gekaGxq/v9TOlUxBTUUzLjk5LjVVVVVVVVVVVVVVVQjjdPkAef/UZgEnOEHSAAyIGihYguYAPU1FpIRxWnH8B7R6HTI6losEhtIYh28SE7HJnWF5ARoni1YGuBBtnckl3q7czTjv5csuHQtP4mhCIad/6/852a4Tvu+2Svq1P0RVO5Org2v5Fy3tblMe4fJu+rXoJJveuXtUM9mouDo23W+SNuc+1E1TgawqWRmAJeiNJLI2CzbzPCfJIlCvXCkUCKiKxjlYG5dEerYO46aFHK3LA9MA5eIu+drreBAq0Leim4bh5L8MHyKLigxey+4NDAorX4057d4CO+b65npt70s+GQAnBS5Sd5hIHMWNzv0cxtSMFES4gQiDqAYc6oHhAGECTD3DBpoPAaYY3IIOeTokI+xxFkR4SIpMLNjIDHl8jymsmy6TxcLQfkIOKJQJlIopS2XC6RQQlEFhSQnIlybL5kfImo+gRUqIFRjMqGhdQW27O7XWtbrUVkM7ZTsy0lpspn2spHUuvdkVKWtalqsiynqeg7oretTKW+gtSNaDGjpoLXZrppNemmi9kkDbwoFJr4K43oQzlNYDrnM0kIxqGOOQkgrmpxnCFBVfNnADPGKICmWYkUB04gp0QBiS8OPwytAHDEnsvU6bsTkFQ5FYIRNAxkHX1i92vP2JTRxF8HzahfdWpez/+rJMfwn1AAPmIcRLTHvKZ0SJDWHpaReFlQC1uQAKXJjiNrOABeDr93OIYvMrhxY3LaOfdmGYerf3Wvq/rP+591v//fNf/87z92uPD2fAhG8HQfpPvjVfOrj93+d+7O4Xt5dmJfRT5vDCJRF5TGgNI+HDlQAWkk0U23P0KWvmmlIHTYIEUFgQcG2AKYGDYHHJhxbmeAaAUuZ5NinRs8PtiIriDASYPw8QAH08QyJrgILeQtg0CATNjeebOAFHhr7ptnQ1aI3IkDBy7rKcIrvDDsuWU11TRvpVUIAGxNAlEYQzsUsrp5mWwLKtc5lJKmV6l7jnlTVqanvYWZvuFuft4byxzxv8zqd1bpJjmOOVyrav5WbdPZww7hc1jums71KJveM5S2fuVbXZnGkwu95n2p3uOVa9rOrn2z2n1+u3s9zMv3+qnPsd3zKpqzuvz8L9DV/s9evrPHni7P5weBQEHxR/8OQROEgqSGmpGk4nJIyTGm022mvsMQvCQ1pSFwwL0GaFhL0vmf+2OyBs1fM5eMkFO6pUimElwXXRpLeKBLUmx1xoKpFrbRIs3e3H5xVRPBlMOO8hXIbCbiKj9w03ZbyAWWU0SUPa5frQA/tDQ/rf2Jmir4boauHMd2Mqtq59qvnnvmXd4bt4fuvj2pUw1j+7+eGFJU7hSb7hrXLedek/m7VzPPHlevcy5e3/N8zsXqmPMqTeu9sWqXPV2k53eGfO9z/v/97C1lnh/4Ybt4YZ2sbWfd1afq7DZN/+toQllf17rUgAQBRgGCoHGKg7EADmZb7BYWzAKNjFYFgEWp8olRmRPptEdJicY5iSDphUEBv/+rJsBJj/gAenZ0HmcyAA3MzYbc1gACnt6yS53YABaY8i5zTAAI6+GLgGHeQRGGgIG5opgoQZ9lGpohkDu/hkwUNChhYyZSzp3m3ADMB4AMNWg4LMLCTCw0MDzawQcD1hAuoF/nBbYVJDHQlr0gU2MKFDCTQeKxIAFQo28lVE11EhJeKBgoYYEA4EhCFEBm0F5loUZoChQZMEDwEOExCUAKTMco2BSMte38sjalasY8LUBbqJ0YwAg0SuYvrZuPiFgtMNU7rrHhdh+L3kRmNApiYAzkHASqKpYcZq5VA59aX1bdZwn4j8D143PxuN23/l7LUbVTPG/DcorfYV81clcZqztbLuHMu/n2HL2dJzuGHMMJPGeSWJuLLKWU3vtRmaz7/d48/v//6/+W+8p+8t/+H9//////////wrVp+mlV/K1eq0tX/tAwwQQggAVRQV04exkPdUBOiYMKQDjkHr8SoGtTDwEgjqaMoK54MvBgrdaLJbhP43T0dviL2b8D9LQc/iQpsTObkzqEPxmt7mexR6xzQz/IXWUUs/u9/f92u1CqgEAw5IRXfaCAAYGB4UAJgMQGDRkY9IADkZWCiwAlmF1jCIsMvmA2IMTDwZCBy5CZDKT7JFJrzLoai60UDkQXduNaC5jBEs6qHWqZuUDU0ahphwhQmq1nHH9TdLLe7qvCpau2K8+tD1NuW4ZU12mpsssrfMf/+5Vsu/+ssv/cpcFFGXfj+Uql1rL8cef//vLLL8cccf/88aWUy2lq5B27ywM//z3/oKugAYhTM7mX2w9LVoJLJFDuAgaA7BMcfTbxR5nxVv2dOy//p/0/0df///+rJs6ChoAAU5REtvcwAAKkHpr+OMAQ98xS3uYG3g147ltBWUZP1IQAxBAM91v81jK5U+ocHU9hEGTjw8bQv2W1WsYIBIJJYOgqmQMSpejQ6I+GWdZbVZ0KKKNJFZyKMofBrm5yH/+G8/5XnWtNBhqT818twtf919Wgu1f5v4zUlw6OLZD9R+cxqJTyKNzcBPWqkfolnSZF7liPVYnpd/X/06oAGAg6u5rLNOahsBMVkxHYRPKTNvnbIeUvVRUwhYDO//jRXcew/7rqMcn/o61bOnZ/u//u3V1QgGBSvdu0UkzqAxQAhYIRUEzAIWjl1izAkLjB8GQKBaXgGBcEMSaFA+mSXhNLA6Y6Y2/XNDtSl4I1GcxuK3CEqUWAzTG5HRUlpekno47TQwgRXshOgbGpi06XWsbcTftobIZdu9AEutWCMoK5lLER7q+XrGVaapdVduJKyY16J947WanTNIeImXtV26Lu9zHnkhMCkQAAuQ+nIMBDtEwIELYkgFnwyIFAoXAM2p5+ilSSMxWFCzclkr5oS1jPthP2nB4pQEhOhbyV5V42AodJpRRPFRGGVC70f93///6P9AIAAYkd1aTSKAGGGhcDYwjwFQIBKMhymdAkopwJA7KKEwBxgYArmDwaqYZgM5gBAXGJNgKAqmv848hEd8oap1AEIiZKFQCOTJUUkAbIXVafnXsuO50DOXJX+GBoKXxtO2LyFZO/oXdqx5PVYZlL9RZ+adu0BxJeiggG9MKGY01HRl4/vrQJxz1dRLxkM9ls+kxFvW8qDPjKrtgRXrNvT1M+fV2lKkT7Z5Zgzv+btxqfUmsJVMKiRqr6n/+rJsNNbMgASLLcbruCt4TkQohwNJDheFnQuvaG3BKpCj9BwkfG7TvYAoFGcvsSBFno3iDNuOkA0qld5WNitxx9S2vdz995qOOirWQrnFHXiSOFb+SEoaHDhH2mryE7Uggj5ulUFgIcJmP7Ggfs6////9SkxBTUUzLjk5LjWqqqqqqqqqqqqqqgABCW0WSEAtG4GgamCmBQYCgR5gsCYGTfEiYhgQRhdgZmBeAiBgFDD/ALMO4+MxoQWTAyAxEiYKEJCgRCf5qVjJEyFPR/zBC3QQ0YwtBwl2t4qOne6VX2iT8ZpYrtBKWu40KJUM3Wv3aky99NAS3Lr0zbRFivzTnlgo04aOpByTu++7ZcubG6zlKwqutc8+GiSTrxEz7BfZtiFWk/qjJXaL0slq5IvTkzEE/BZm2hMOdSDe5k6djDXLPsH7c9vZb3q4Lo+Cc5f5fPRgBszKAwxHGdiaacqE1gKC7a7+NoycoM4HxXqJQnqGah6H6W2GIwCMFcxktyKFW5KNhUDZR1X4rvSgvghEBKpK2fXuAwCKA8wTOik3tePHnP7NXdUL3O/2J/+r871/7wmIRFJLGyCUhc2ULASTCYYXBQYxhSZV3MJEOYliMSgwSAKYlAeYfDOUO+zUwvA4vgxOIEADVWAxp3G0bmuR2V/sXbmwwIAVebF/eJSF9QtqSSHnapCiI0ZSfRVVQyTPV+ILe3o9Vv2tfRBuM1cUWnsCWZwcmGsWUrWqMsCPbTaDFXGSX0aVJhTIvAwwsQ2qA9YqGQlUttC0ENREuGBswYSlFCUMBMwpHx8rGCr8zqiAY5CMGGMkkNTXBA0/p+nRXBL/+rJsl0/1AAa5aD/L2jNyUeQ5HQXpHRfdnwuuvHbhP5EktBewdIl/2/kbkuZ6g4x64Rqym4H6nGDEeJQ9hYm6rixsbNPQnr5IUr4V1YI8lusKZEfqb7aC3zbldyYvRP4jq13pbeSV67f//2ckpaSKuv1/qkxBTUUzLjk5LjWqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqoEUFYXZo3/skdqXJGXRFSIYFjWLkSETNwdO0dDAiLAhoHPUrNAbRlFsIaGST2K9PhkJsnEUyEuD4Lktqtm22juYEMQ5cEjFhAYUPmY6xWH3q3OQn5bh5nifkdOLpWnAwCiqExhdBCxp5JtWI5rqdBpOqZLaFCzfMpkl0pNCBnAzo4IzCFCXI9syKvTMz4kpcoyKu2xBemXm2QMGeM2ZEDusyTDEoKgMrxdtYm4uDLoYYcCGjUX1IQYwnDlBWTE4ZEKQabBcJgUo/Vpgbe1uLFK1B5whsISvar5DgfA3md1mch4nSt4uj72/0eM/+r/sfX9IcFxs/1+jbUb2nXI9xAAGRixzs4NHw6ACpMYWPiToYO5DxtF0AyvGipkDLYyyRAEyoDhLkCQHUXJLEX42RTTJRyfuJZSZ5IjZk78uyodEGPRjbuwLdvUs5KmIsgThavBcO1HeTdc8xHaCNYxWbYTb2c1km8xfQ7H8PdmFp0VZKktcn9XKIVbw2dFrZkYh3LlOizmHTus+zS9N2oKkkzMb+8vTs+fEtWWqB0FNqAw1iXpmIXO3K0fKMLgBkFd1uaQKX7u8pnVJKw2X/X/+rJsXEreAAUVZMZ7bxt6TsRJLwnpGRcdoxGt4M3hfRAjdYYKJEI6CWqyJmTSLMddrBQekrKamyQJTN4zYB8HkwQ/NCkqYudkozKZ3Gna2DKdeGRcOvcxyErRfuqD3/sYuPvRdk3sI1ogMs5l97vN6r0eykxBTUUzLjk5LjWqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqBQbDjdliQBV288TQklgQOnQN6A0wMfHgsaCAcvGHgSfSFYYAyxtm/Cg4XVfV6IEZWzdaU1VeKfLzp9tsp+YyppXFLcP4Rp83VVy51FH49LqKr8M8gJuLAmnvzbkNPKX40pM5bvEaxe7lZKIjw2SXfjVhyyhJXNW6j5E+ocq1O6ptlm+SRfOG/mHWnXEMTnj0pEik9NUydXAQrTWKaDJ6G1TivBZCV/V+OiKP+SVpIO8Y6scGBcRozLG2jCz0HyOsEhoqi8yJNxcRFcrKN1tMNCelKdCN8DVWPfxtsbkOc9TT3162hKUhxf4zNEbbVkWhrhpuqrRhpXVq/uOf//0peqpKre4/oSFRcNfv95G26PKiWkICxDkN6cQiMaOHAhMCN4ZFFjYKJLVGzBpg6dkrCFjxVly1m6snfK2/IwvW9Rooz7yKdfOs5zlRa2UhWksVxqqqZacH7Wfp+iQj4PQLqOp2MbBslzaWpBJTFJuhDJMYtNPwV3dqp5QQ/ns5muI/ZTaG+N2+uhmXtUYapITrGn8teZynrTrS/NV6byUVAq7un5/NzoPWadrVBiZzIJm0QRJcoLW9PbtK23r+KsH/+rJsxpnfAAVGaMNrZh8YXaQ4qgcPChWFcxOtPNapZJEkNPMizIAmEVTkGMlNBPDJQmv8pCTLktmGn47yRnViHCVZlHvqWlSeIFhqG1vOn0xQsDh7M6OSdWcQu9Nyid+mV6Vadet0jre1q0+Vk/yXu6mtRUxBTUUzLjk5LjVVVVVVVVVVVVVVVVVVVVVVVVVVVQiyvslJAApqWvAEkNK7O4ZMGHLcjQcEDB68ZgoJUIPVhfx/GzExBfDuN7D7SWhQmIV4dh0RHw5o1VXs9OPmcvSsaHTLZIuyOwhD/L2TVDoJGLQErPpTnC6RaEl+zi8eLvHh1dbp5pQjQjcupHClTONuIaX4SbmVKKEbjG3hrtZtAfSZGz6zkmyvh5l5GTOMOA1MwShICHkkTzRYw+luW3rdQAABV8AD8sBQIS0QjtqRwIoNA68UlTCRxwIgnVgzpGElwKR43gZU8rPBsdiSfiKPYA48r9b9amUFg2IaY0BsSY32RJpdzUNeVTOFPVYZNLrgiZbCIAUFZgVQtaDdyVY5jSj3ERdqXw7LUaZOlA8+t0OkUuAToEOhCMHqNVPaNfvx710iVAAAQzyCLeRD1ivGZIKnO7xioMnALBqMoUQDRSw0IDMECWbtckyAc59WmvyBpWyiBF6yiYblG0hQhsB17EQlTsTE5ate1psDhwLEqJ/q0s1N1oAgFUig7BI9KbkahuECzQYwpkxPgKG1Ij+NVbuYrtht2OboWRzrpllRflkwbBTaWjAiWES12PKmSOXkZqVQU6FDoDhywY/B+jRfrpiRkLd2V4Z1i2k3PpViPUSORoRsMSCLYkkttJBJlg7/+rJsMEHwgAUNVsLTTx24hIQ4OT9MHhYh4wEt4G3BXxDjNDwwbPpYABmpI12YzAQ6EmA2q4ZZJIgbttuOnJ+ieMjyoTgCHYkObiWKJNApWjltvsxbe+jB6AyEyqxZSqbTuUqr9Per+NO5Ovnuno//7dCfGkxBTUUzLjk5LjWqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqoAXgQ7tLdhqAcEkBvVGY8UhcIFhJQ8MHjIloFfLX3gXY6hfUFCFFL31lTWZZbhchjduWK+qSiBOWJ6V8sIUIGg7MUVEvP1Yiq+RQEFhxiNM+oMkYhTjRWZ7Pcr2OlDs7IioCEdjI2tlK79m0d2Ky7SoJuZ+QOR6Mj/Joo54958l0EpthpxqDJ0VXMLj8IwZfATlQ3R7dw66ivcSmLnttPtG24t6tj8RGMXEbo9gPgJtPMI6nJyfjgnlNqqomhycUSQJrS/WOMyGJEY4J0Xz1H4lkjhZhA3lMMOhE8i7ij0/9G5Dqr2v3FqiC6N2N0/rq5Uom2kiBsKRO2tAA5/VlgzWaggHiHigQW1hQxDkosTUw7OzVpDqKkrojRirRP7oW/svxVlTI9HVh1O903sbWvHaNVCn7HLTb7UK2SQMSgfxp2pdGBKnV8jImQQMSTeVtt5cLx9JgjmQPoy/ZI63jf/9qbP+i3av+sjqdeQVX+V0NMjqCmGfXsv/////TCUZcmmubJK7/2pW/R36TWU1Gn2C2QzFfDB4dtW4cU3cSbkdWkftxIq7zW3ghkeBFHXtVEQdE3/+rJMoHbZgATSREArbC2iWYQ5DQXpDxEMoRGsvHFqECoitYYO1CKPJfJQ6gfOzlI9QvMSo1sdhBBkivMTqdJmjy2KI6al0+k/Xhep0jI8nnpDO+0PLLIysIj+X6cKd5z/Jylp8vPBjajLSZEZDJtuNm3XVUxBTUVVVVUGJ1SS3bNpJvgLIW0KULpe+VuqnoF8ppvJJbW5QwOLVEc5Ll+cbhAENUVbITF3z1SQWUac8+ZZ9q+SnRh42YMdVpM8qWSm9BCNnDxneB7NTcUU5IMFBda4oLtW6pT1ie1CA0YS18VRKXGbXrIIABFpSMokm/qiciKqYDagyQ5T8GBc5wgg6E8VRLi2IM5QAIZCHp1TtpLD/NZKtDtJAiEqddp2FEHg9u4p18JaA6lblbCgPpKKVSoI/UqtRnFkvFO6xY1ahiQVMIXObubshaoizFM7vFtLdn4WNUYT/OufIQ5KiS9LHRM66pNgBadc9eb63qEIDzG7//+O8N79791CyUEna5I02ssY5AzBjGQgSjCCzKUCl7sPSzK0bNJ52pa+IXCTThJhSx6nLla3n7U3jRZxAXi2sP3MZmzl21p+WrzDyyKxOzveWNZKoMQ9TR0XHy4oLOq/r651u7Or7m9IKKU5WV7C810m28/pSaHWl4xtGeHTc57WLwvzIhOFUzpzPbMnFKda460///ptFYW4+cW67TrIE+9+NgBAduNAEntS4/yCYEHBxY4YoECICSwSEEIMZnCiIVBw1bi1OooOhbYn4ex9lhaNk1Z+3KfkcAlhWKrudujkeEbj1+pLIFGgh+5TAEthUXit2xMz0YgdQGV08qrSyRv/+rJML/D8AANoIcboWGDokiQ4OmsPNFNViQutMHpCrqsgabMPgf49kVhS6Kcosi2EWZnko5VN5KxTqRc/qS+cWBIRDYpxe6a0lpjsVWEpoUDleflNKVNEB0iOVEs2ZQ5JAYeIL+Mam9XxxHvHPg3+Ix6k6kxBTUUzLjk5LjWqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqoFJRKOO2Egg3vjziNdMOPOs5MqDUtU8KhwaHBhJggWKvLFZ1NFeaarhNZyoYxEJLfKUSyJ8EiWVclmEurYheWxREYPUKuWEkGV42vrxpqHOI3M5qW7YwdSeJUuHzY3+/GVmNkb2wzPR8PtZJu45ynTne57tymJs0f4IZaDxZ1NvvX6Vz+2y7Tzq+zjzdUl9eee81rb15W799VTn+XnxWWml/tW7uUtYyABPrLkEwgMOvAGLX0vUz1iGQEBrGuu67+24kwDmTaZaFIbGFrmyg6QWLx7DV1+6E40FDyAk96fvt2jN1DWqOhS4yxwW8s9+v3ZY1jmvFwn7VKG/v0htDkPusM1U1x+lb43/6unryV/7H/j7Wz/bfpny9Rjf06o1rrz/t9CDaSmtk1RJK33dNBYMMBVQak7bcVK1zxNLBvLUQkxhKIXJqNFbM+EEOrDkPW5BZaqy15J7Pt2/fwtZSuSx1tYesao8pZlvd+G3htUtzCmppq3+8sv5vvOfcNEfK2ve0QTZO9y300xy3CZKhzSS0gUodZha97jDI1OZGx4sYWqJwW17tsSSa/lyw3WZC/0l1dqCMeBjTOIfLQvZP7Ug0SJPWb/+rJsPbXigAUzZ0LrTzRYfUQ4IgcsDk/snxW1nAAhvRDiKrDwAGNrbnjyJ4psCxKlOMV4jCzTNt1dBR0KR5u8ff+W9QxHJ7mXcKkJar6G7q70CpBJdar33ZRK0rjOLwuPa8eFblg8mNbuqu9aAm8oK//6KkAY44my5G24UWnG2225KFxPHxUDxMCAICjAUAAPXABQQk2TH5COiAMLBY0ecU8Tz5+CA8ak7XDVmdY3j1y1YlOKGqwpOFQpE0uk6TY4Dm3UeuHZW8r44wy0DCdxT5XBLIxKHLVC/sYgmLzd36lvtrtNawrQdFZfy9bu7oJmkqzdizzHnaXedXWrFmU270emMfsf9qrW1Vy3jPSu3VtXJRN0W7V3HtNhdzkGVPcqW9S3Pt29l3tNjWt26PvOfylks7NTNLPWLlq7hVxz5csXb893Va/YuVO0XyuxNWs5ykyzqY1sfy/X51d9vAh/g2IRdR47/WEwMswbCpAablSTTTkbJKLSbjkS2goJ4afWSkgiMwHIymMzYw5AAVNXD8eFxgsUlABNlIoWNJzRHkxtUDbVG1pil0whYqm1p1JJKwYV+GSPz85RvP1p/qqOtAjtrUiL3rrac6sMVobUdjEnpKdpMgm/72tIbVLhftU+XPxt01nC3jcu/89c3b7Uim72Nmg7WtY/U/6+NS/e7ctU9Wnm//Cxfpa9mvymtcpeazswxWpJbhbvzVS1LeUHbtW5qtl27fiEh72nqZ57sWf3Kp+lt/PUdmfjNipRzMhpO91vffvW6KWfeyvf3+83n+WXNf//////////fDcLlRMHP8OkwWCJgTsAEMBRdK3WuWb/+rJsMwf/gAfJa8HucyAA/I6YPc5gACRxZym5zYAA1QhjpzBgAHJY2QAYPBZhQ7DgLMCuoRA0wamjGgQMcB40U2QYOje4BEZQMGD0yyJzggEDheZtLrcjQCwDEhtNCZ8ckpk4A8ChlAZygjSqYcPmPGQXAnKMDElCjEwsw0TBQ+AuIcHzGBMwosMCDhQBacFxwSHC78DBAYBR03JFGAwIA30OSWwcMM6X+ncCh8BFZjAQxyNhAA2UzcEC6GENIMFQICmHAo8FuQRAsESJ0i/biNzYPIFDAwAQDPSmrEryjRhITJeP9TXLaOqp1jyNY7r/9TB/BEAAomTRTSS/UumWpL9giFfnGbWMMv/R2H/jd+np7cOYQ8vpp9WGn2jO4w/sZ3q1/P/8v////33D////+Zd1VCS3FiX/Ln//hR4iywGAAEGMAEf0AGMBagHUyC7uoj86duIrryV91Wj5Yz472Ir1uFhpNRwuH7KH0/9v+X7EuR+1FQQAAAqcgrFC4EMqNigQAIIKpHOA5IyORDIYmMEAlOEeBJjxiG+yAYvEwODTQmZoCjcjLQq5ZzSwKgwvZGCXRFpNkDGqAurjqXMYWtajTtP8Ih0hW4tNvZdeqHn6s/jOrqYE409+UljL8y2z+W8sv1larZZY7xpYzS4/jjM2ceVYdwWk12W8yppVTWjwlCcsCv6v+66Wup+kICEXtCY1pOf3GRIgJC8IzNjumM0SkOw9C5Tr72V6vtJA4sQ1ss8c3/3f/vZ//7Ef7nf9ARCYonjebKTldylDhKIwACACcQdo0HB4XxtfAcHgCvjLYISpVk+mbsHCqN3otWlxfZH/+rJs+UF+gAS+NcdvcyAAM6MJLeS0AQ2shx+uNTShBJEkdMGlnGFnOFJ6UMAB8NLKzf0xpGUO011p2xGhceNlookTRCZetlZ+1tVuJaNX2L1bvFe5jcWZU+59tamW0orYO4AwEDl+8iQc7s5H5mAgLLauH1eHQ4JLOSFVtiSwdLrLqza+yskdf7r9dtGgDD35DFE6Ct+umSYZ//V/r//+n9nUTEFNRTMuOTkuNaqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqoAMCAAWWQTgwCQwFwFyoAYYHIRht1ohBAyxgjgIA0AgLgVmCEBoYUqGwgByMDsBoIAJul+BAVOguLas+pngaWIwZMMZRTvZHlMgCAjMGyibuyaW8ynZuKudEqPX8nauH1bEfhyMSCpZs8o8siLLpg9jQjN2SLWh0qpHGZnDB/DX1Gr7chcj9ZqzLV94m7lMqrPSPe02psxVO8at96xZ1uX2JP82LyZzmVQwVaX0CZa1ts3IhITpAgEO230iRWf5YUwQxqRjQgQ2b5+lqNzwMEzdTNSXwWJMn4M8+kkHx3E/FxEhyQTN9zB2TS+Kro+kje3R81/0/+z//WEhKJLtdmik3ynVMh4jJxGHCafaToODoYhjAYNEIaCgHMPpIHOBN1kiTTYE3DFwtfy/A9NDJUA6oU7ahjsIePSooCgw7S77O2hEm5o8m2WIyKlixIwwZSYq5sgxHzk7a868E/ArJn3GM4xmxRSasMoY6/vgUbbPDlKVI5qaBSLMVuYaH/m5UWgcdzSJO2mCiinEA9F8zn7IEbdTGosvUZwWQlbgADJqJsrBkVL1kr/ukz/+rJsIhXVAAWoa8Az2htyRCRJDT0oSxRFhRGuPHMpb5BhCB0kcMSgzCHup7FSAFyQmbZNZUtmxYCEuk/gksyijdo2gpAl2KqdKqyIxAklKbnCWMPbf619Dn2U2vrwp+9vsbetyjlTdplUpTxvS8hb3DLFVUxBTUUzLjk5LjVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVCQfFt3/0badDTIeq3BYGgknFKTZezLhjgJmThqRCsIbKdTC2tOsOgHSI1uH5mIvN/tPlMGWyAlRxDxTeETEDLkfuM0blQBHUloFg9+5t9IcjcxM5XqBl7AYRQU0PwuHbZhq3I6GQMKdS6QRKqV/3iVN1/MZnYlkKUuNuK3Gxmg2LJtCFlVeEyBDU08l6vcbM+TrpU1a6VUZ0MdmQzVxDiLq5MPf05VO9vmd7hBnpkp2AAgBlSSJIpY/vczAY5A8KeOGjMXIah2TY5zB+pyZ/FKzDzgKDvJtu5VZENUgzu+ulPiGJmt1xcGzxn7LtVzV3ez/t+e////iUKCYXbb/SJOPNHWwiQasIYW/n8KyMqbjjjgQYlLiqCa4AwDA0jiTjGaGavV/s/kBbBpTWY/L4dlpCDsOTcWpKqZZLGq1I3RifFQHOfy0Zq4VSLPFQRIJ7HwcrI1tnUqkfGIVJNEKZMJT0wwgwJggw4mXzz4CSA+jbkUkkaQ0YpJZDk5mJzXKPcQQ0264WSN83SCNh4wyhLHYXYPRigHJxMtE5MDMySjkiJ+4YMKIDGTk9EkHOxtURGgp+yxH1ZWORHK0q/trC6Lv/+rBs8Q/ggAWAZ0RrmTN4SMQ4nWXrOBixmw2tvNahPJDi6ZeZONrWmm//eo0qqYMaGDz5QFYbpeXipzq6r3TNfvFK6wXQeaLVniUfMrzVoSEOZbRn3HvTiJn93RQTRc1vV9gqun/9G3TR/cS5u31pfV0KTEFNRTMuOTkuNaqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqpQIxBDxr8FASFC4btlZMXAMCHIQ2MNgcxo/zLAbLguFTX6NEpqU+sTMEormCSJwknTZgkgSbHKIu3WIK8/3Kvbb/ePxgPK5WjiWH5PmjSj/21I/cngcByJYebmCMLm3GJBLjiiMnODgDgJ0SYRgSkjzkEkJ44M3BuRlNbFNDHQukSsuSZCGM5YHMyulczKZtkCpLlhqXnI4vovotQsfM6UBsKu0JxhgeCEM8kiRSNJQYTbTw4Ad3iTAIYYG+wKBGGjlvWPO1yLRJS+FTefN2nml16UxVWBOWvTyK+WOCzy0UIZZBWU0JCympUyAF4uJkLS4hIwyNOeifkUm7UrkZ1ffbPmPN/HzK/OUQB+dXZpZlLNv1zejHaSiqylu1eYSZ1/Ib+9SKJ1J/ddp1sK7Y+8m/mwoZW5tts0kne3Ul6qgFRALSX6vpIpSDjRDKyeAp72XRBptNalPxabHGJPCJWGQh6dnhSmvZSCqOBdqSFd0mfBUKFwYRHtaRaxrdr2lw/847H/d71snqmJJntPEqCl4wNCIv/6fi2YkZ1LCEnc09PAugN7n9hN8M/cGTYrgoSaa7b1tJJdXYIlo4ZoUHMlgl+SUIVQWZm5Rag8Buh6A1oqHgsjzEdk1P/6skx66+yABTt4PwuMHGKLJphKaSO0T3SNF6y9LSngkKL0HDA9IhAKMWG2G+u6u07P4TIzeZZYyG/+kLStHXXpdSJbAHPULHx5qPLaKCWHR+W1arEZKmZl129FrSd2uyS106kU/idRemfWv/70/3ffv/6qTEFNRTMuOTkuNaqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqRYbUtt1qRRWeuy5myMpwK57THhgZ4gO1W6Iz0kzoGb1XoSEtaKEDo16oJllz57FyRPWzsJLdBtt2Z3e+Cm9sdZ4WsVDCnEj9Il1UjmxkSIH0XEGFziUKvKkwTH2EiqYUsECVsUVIARg19DouNIw28JHyEo23bbs0SXvHdbMsDG8CzdnLAnikorg7sJXG7bH7SeAwnW0q6AqlGpDTJuonVcZV01VfmHCHmuqxYDtzpH1FY2CkE0ne5m054qbHt8WktKVDaxiNOTaK+hJ/LqRxDBJUUodkJeExRZobnsW0mZ+0LdOHNn0w4qGlI9+6oNnU0FvkXWhVEouNxzW1IkPuVfGQsPPoIeU4KDIJQaYx3ddn0P1cqSJzUEfXna8StdtVGhluoNpO2y+hXXF9h62PrFKykTdZPNSCsRFk0XvIzDig3/uQaSpgzhwsiNRdJQr59fznHLpWJt9RTJTq57SzNDvnZM/TQqX81IjeK+wNZ7FX09VMOHDBHJXeHqQUb9ADDddlmtaRB73HJhiw5owzqLDOK9iegBPB4xp5c25nZARaOdaqasNsgNsrMJ2iHz9wy3uT1uT9Tf/6skwux9uAA4wiRWsMNDiEqtidZeNvURmfEawwdqIYpCI1p4290wmuDiHW7FvM0q5XSidOnCl315wdaWhlcNQmAGpIVQoX+b0M7TQqMllKkZyRs6X7LnbffQipDyKbF0T256PSvbQaK3cWcNMpRe0Nz3KiQTccsu1rZKX71exhk1JSBlkff1lk2huw1qanNdBzOc253Fig6rmcqR0sT6tquXw/Z5FWfis9azVncOuNwsjRYNGTThY5VaG4pKhFvna4qlBvxaVDaXuLzhnlWB5g87VSly/pqTP7+XVEAnLHPNdwwaEYu+uVkFRfhjhB4q5pFzOrT0dijv09ap/K+VExWtP4amVbPkpZY6AAfCTba8/iLUIrEgUXVgqJ+hUxz0egOxWNmZNzGVLu70090uzHSuy36InR5Ga+iU0JWZ8lrxbWrkKnC62VsRhQsh5oABWXGyQSJzB4HaQ7jsBj0Fng5ROV+H7NZxE4CKqqJgQsUCFmHadhZU+qi1lD1q7VCANR+jHLm5uk2jTzKFuUSdCcEkKJqUkGHFW3FafSmWhqZ7S3MF4MDMvTy5mDCdwxVFt5NIaSybOLdTtbHTJ28zxy8eNpCytmDqJudkpM2er/sqCiGSm9Rp0KZJJjco8ZbJU9PDbj3ieWe/3Y9NqXdfN59IzqBDVvtIaNF4aZDHRaa/R6E8JQAJNHIy00QgZAbHavgC2ACACQImsJAZhLiCm0HFaPD92VbCqDR1wGvTLxRZ+4Ho4rBSZDcXypJPXkKiMMCdHNAJRYBB4sQni7bkY2NigVKYmR62kt85E/deVrCmveU5aBVE5QiXyylo8jUJQrFP/6skzJd/+AAx4hxmsPM1h3CliaZSK1Frmo/Uy80wr4vN8JtJrR9lbJ8y+oGTRmEu7UduGzd6ak9pORMIzJe6ldMSd86jMmVqZRXOOnDsw0rETTznQ8rghbItj1DSCF6ZOE82dSXM/W6eteJbdIngSRFriRLr1MQU1FMy45OS41VVVVVVVVVVVVVVVVVVVVVVVVVVVhptNyy2ogE3v7TJEI6mFGHKqOsZfhxTHvVE9p6eIy2DckxPnRcLJNQF9zRWI4zTb1GX1sZiTGjwupXkqnf67LBeEKM9MdcbVEubM1W9zvxsx4SWnlcplzuSScVfLyNsliSv5Gho2tk+lyY5wv6lvoxFhz/98uef53ynXYm/IQZuQRSRjdlrTTfObutIWuK5MLf5nkPIyAgSjkslNhjGUq25TvFExOoj3cVvEooS1khRlKaU3mxSTmzedNlJhhcB1BG3enOgRnRm5Frs81vujc79InbiO2VR2hvoez+H3edPhx/6f97F+1G5MeOHzvOd3dT+R6ec31VAttqJyxkgA55chuHkOp10wZWCoCIPQMFwoHA15/ItLLjMWgq7y/KpSQ1KMKOuxkvBm5EifZsbGJkWj0UALIUD/R4yfHqyrbLB9WKcureespud02YyQy7AbfLIH6yoIhprEUaRwQNysMyXNarnXypzqkW5WmEqtFMkpaEhn4KkVeMqySQ1IiYISBy50zMwaSNNuY6ullyBRMbbbrJABxzmXpa+pQbLWX0hlqcvTeNqFNMahDqv4/aZTYIeboW15uU1N4dUrwsGiNa3WFXCfyOJJA+ZAKPGcI5wpQKxqITR56b2PoLhpibv/6smxf7++ABARmQ+ssG3h3BDh9ZeloUr2ZC60wdqJ8s+E1phosofFU8kNU9WbD7ebJVUg/rdbvlns25G633HA2LbvGV61GvFd0LtZew3ya69bW8w027TjKx1UWrc+6bXiX3dzcRe9c9jdKMoHpVx/04t6VTEFNRTMuOTkuNVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVQbjclluzZKdvL9vqyYzqkEKI0ENeb8zGFCadUqZRNQnr7Dg+Luk2imYUVWGrHcYla7/VE07k2tjRaPGVm8uD9gbRbGhDGWHaZ2f4XmpmwgFDhAmrqiCFHZku02Xz6J0up84Z2uQnPIikLhU9cuE0BYkmIy1qyq5GMgy9iwyGHGYFIa6VyxyMNWe6EnDQZBFRt1yWJEA95nqHy7p0JuU7dVXogNMaASST4b/Kco1fTszMSCFt10S49MIAWRCRpNNlBFJZ4nAUjOUgaXY5yUVgxJvJIcRxWUid5HJiLB0+Vk8E3CnPDltFfU/b7NDOm5Pyfxf55XzyPQl5x8l7W2J8yU0MGLzqsWUMUQqVTvqHW//1WU1HJZbWiCvw5hjXMzVsOpIIduggg8mUvpQYSpZ7/4rjV1cWSxp5YaY1yPZedU2rEfHZnJzSNnaMw+cpjsyOY7PNXQhaFQx650EKhWLPKm50azTUpbdVreqoZlM1Lqe6H0z71aWpshUa+/0t8rq5mrk0Z1zNw0FNdriWRyS7WppFZUu8F4ILn+SYSEBMVjLDCVIWCFhngqP5BqampyNxzsJfy7Xk1VRoWXe+SxnVgMZRoV8AWRx0VHJJcv/6skzkMuYABGxoRGsvG3iDayh9ZSOZTy2TE6wwUWo9sqI1lI7USpKlWrhGZdmPXPJDIxw/iQRwrTo9gM6CqUGQxH8nYthAjJQmCxBk3g5VoyFP3PPu+E6FS6ssKQk82yNyZDh09yPyKFql4obOBgl3d39STEFNRTMuOTkuNaqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqYcSjjktrQJXO3OPwJBmiem7TxqMxQ1aBcxBcSpEyYQFZ1m2Ia53ojCit5lqYvC7LJPtyiYlEaeU4lUopDw5etk52+Lu0x//idQPYnuu1uz/s296cvw/6Wngjve7qLQd3n6zk+Cpsa7WHi/Oko/3Wl5Q25HZZdWgSlLQLRAUV4yiFtaWFBLW4Iy0kxfxR3huZyZuZvFFkY+BTHqDUshUeoLmFg9TCLEEbWyDq669484WCSQyAgggi5BVbr9qFLcUW6u/MA6ZsvYLAM2bdYs+MSKtlzyuh9IHAhHQnARVW40SScOzD/w+nuZOBd4WIWJDSCMxWw7FEt/3nqHyFgl4b140trVHfzVWy8HIUqurvzvlmrcqyHLyXiR25wvHnZJVGnVw2OOMblhQY+Zm6Pf4ivrPd3pS9aY+q+tKZvrFPnFt2r7R6Zpr08+cRLUvTG7W/r7/Vs2pTdc2xuurY1nN8RL1976hyb8etYWK/79MZl3a/+621m2b7xJTGq+fGkjuSXh+LNboOPJrFn6kwbcrstuiZBPN7uqpp2DSpK4MIbkys5UGio0y6WT4+AQRc4+Xh0Nz6zCxsBLYyYVzvVoL68v/6skxsXeAAA4MmxOspM0pqZDitBwkdFhGZA1WXgAoIlmI2sPAFN0ywzN7i9u2NkBwYtaq5y1tLFhxK5vmuK/21BvakuNb+rTWSS5axw+JR2txHGS9sTgwjY5m22fsY66ShTk3xbu6FrtcBXRpZ5FH8vr9VIKkjiRbUjjbabbabbTiZAA11izwhCgdMAQAO2JTCEQQQJjrUdM2NZOUP1YjdUsOWwHo5gozWCkTRO4StWp6HOkkovsbsRwuKSOwRSdHrCIJexG4tkLPpQMjCUBqXPpsUjSwx8q1f6kTVm9XtbM8cpnrVhnQlhW4F2R85MsGCrFbR3OwxXzLCgzMFevMalsrmNleue4sJRwpFY2zOMj7qW94iff1hueF2pHbAwMmLNjqZ7V4uXcS6oUMF91y1sTY4McJQPlQ251lk26bpXFadTw5m6kdhgx1xlAtrXDiWxI2Rrf41DiZ8HOf///////rOY9YFp9X3Ct///////+6K0TjAwJOONxKNtuNpqNRqRuP5JXQQVSA4DwlmQFiMCHwCKhGoUrsHKw0GtsWASz/TD5KPVUwDn67N0smZDo1Ows2ovpFmYEttjY0+5XjezduuZo+Kavi08KJLSmdYtp5lxiZzPM7exvR5maHun3eFHtl5E3uJaJrwa2zff9c1jRr43S8Su4u83zGgQs6xikDFM33h9d7XclpYO/b11bWc71G8djli+BEtLPqBa94+M3gVlpAvtq+dYYN/1k6aUf7kCHNAACAAAGCIthxrmBxDmIzGGAQbmMZbmIghGe4VntL8mNLkH+JdGAozmVR2GXwoHeLzmUQYG7rHGJYZnVwJr//6smwUAf+ACBSDQO5t4AK+7NhtzLwAKeXlCrndgADwBmMnHmAApJz0EYuAGQuJccy8HMPFxIjMjeCAVC9UIgNWseJjCgIDF70QyRLxYEzGBUwxZAwgmTXJCUzYgDBCVmDh4YLigiYgJrQIBE0OAL2sJVgQZM0DEHDDwcBA6sYCEGumWiBjBm2gWDVAQIJwcme8jwSfiuy7CRDaSJwJAnA0pZ7XaOTmMBcN8kNmZgwVCERI3KFN2Jy9icbtiQyIwgODktXcXM5UnbyleKLXeYXvhpdjEH4zl/Zfnm7ksfl2xIBpGDNKdmUrRmn+wwnNdy7ln/KSpSYOW/8/GIxYp9cxxzlM7HodyoPyx+ZjNym7/7y3vu////+xiksQ/K7dJz6SpY//////////u/Wp/5h9ewhn8zsQ8DCACBFLllFBHJsde6+C3C1jXb2KpKmc8LIGpLgHArSYhjzjr1HrL96lF16kerI+/r+uxmpVK//X0f+mlRQAEAc4i9uRpuYpnDIhKephCp0KwKHIDk5VASyoAppAuKY4CGCUACqoFYrp1mtQHcTCFgpvRZ9VbUbQd1TGHccs5ZFrNK7K5Qstkz7T3f3KbNLllKmlV5+W81Vf2Uy2lx/W9Zf+sssvx/+9/X/rXf/KVP8/R0RCIOsFyTq/+vq+//1dAWC/Dbexpvt5dz0AoFTMZTxNpgpJoZpXV+gYq19F1sa/qoIzjIaPESorNH+m/3/IM/7/2///pAAApuMkEhw4KhwIBlngNFYzvj0WDVCtTsu4EDUYiMOY0gqlJS1rSZJiYCLEHW1QsUHAPEZQ3zTiODtTrhjWktTEkVXFxP/6smzcO3+ABBMxyP9rAAg3Y7kt4zQBEsS/B068cwDZj2S0F5TUEFRmi+RgxqLCXKKQouqpgR+nl9W+Z/kZKhvnOQnkmYRgu5FU8KGXTJpwhHKFygAVKCBoQhsWKEh5sIAYa6xNr0hs6pQAOtKcXsbIVmE0r1oUGBZab/txE1ORTb+R7wo3BrGqeuyqomQ7kAQwqc3Wk6rav6IUXGkEA1//o7f/rq9l3/+SV/p6VUxBTUUzLjk5LjVVVVVVFotN912raTeW1kBDxhwFeAdjhpeNwZCTDAIXKL7TXHj0DiMAJb1Ap2dMBVcnOlhBCZdbqyac7c4eJI1t32y6ZoOjVQOaULzRibdqYzde8czruY5xkWUpe4fHAPQkNv3Cq588zO4FnJVV+ACIV6KjfYHx8AMhDKKmCb6HCjkH94QO0e8f2JKG33c1zyQNqla4l7ujjzW5TyXbGDq/+5VquzorM6Ebjf2//1/RZ1evWEEEtfKKgazRTcwpBIw/EAx8Ho48/0yQA0OFmuYeAQZVg0YbFkRd+NAK3zkwGKgqYQicgWvsuCeNMI4QtWmISU5Q1Qnx+P3biqC5NEZ44PiCBOqlbc4zgX9l6IQ0dqWLkWUVzUyiR5oGUrFtPJyK4I0+ILK4rtmfUvTMCYmkJltkjhMEROWQkAw5kRH1vyI5ibfW6EUFU9RkSMiiz+kx0Tqkca6z0oLJFHlG3beTaRtswW1wqJhsjEKYoSZbFjKlUzFHEITJCurztCzPZhmBZhCinFx1QNHzPycWCqSBE209TKnHEikXlmGYtF5tLQkvsAANJRolErg2Z20t3LlEnhmLCjEkreM1A//6smw2FtuAA0sfRusaWVhFRDh5BegKHfno9y69MYGaj+FoLBhghdiHByIm4M0RqaEen2/j0BAJuhSChX3iYN0ziEOpEgiAZEEw23qSOEhVAu4Vt6T4OKUWzr7b8ZvUQqNue6qFRJAl7idBQsKHznW6S+3oTEFNRTMuOTkuNVVVVVINjPtt/am5dybi2rDZIbuUtcSGOgDQYCcECwaXRmVc9P8BDZbXWhoOD85JLg+GSM4RM39RI1U1mSoILiAkRaj8aVMBv6jMDyajGqWjmR5H/1TGFdHFjB2jDKYlzg0NCc1CNPKpOGQPepmDIYlBCXbctdFxRAkYh12dz2roPGpglFVSJvREMimWmLVhiQgqLBjo2FeAAEKpAHPy+L6JOBsPlGm4mSwAHqmMpnZGASY3PamQ/6InRs5jyosJSb15MvBOkQDXi6MKCOc7qaPd3/62rVdsq2puUuMRToICpttwP7gn/RVq1AAAM9sqpnNhiYKClY5hUGJyI0YcTAkDKdIkBheowrWIxBBgBAeZOjpOUEtg6UsdSEGGfxNDqH4hYnheo6+3Q10hhyq1LoBPlyYkY4HeolO0RG58ZjyCqBYSeJs5mFfQKCYpAp3zY+YMOZdHslEjDm6dccENT02fuPhKLK8rMVRfRZlCOZGix3y+XaxNN3uubJhVeYdfVGdDBPAkhM1CiM8NVqWU1ho8u3gWePSwfmsUJ/SvWdOTFw6Jjzqt7Ts7LCtpE6fpl+sNML1KxednI8Hh0ocPrQnJ/Cfa/9Ty9bps1QfRpU7br8B5Z+yetejWQRSQ6zVJKkklvv5OUw0TGJBp3hfxlwB61hwXwv/6smziqPkABKBoxWtJHGhS47hZPSNoHjHm9S69jcmeEOGphJmgWg5BfHKF0MdlqoaVT6TXyysWyFxc/tXJBMjwigNOODB11MEKypAL0IWq21omaXSx9d5KtOLkTrErINabtkg85KWKW1oSMqTBB9s+r/VUTEFNRTMuOTkuNaqqqqqqqqqqqqqqqqqqqqqqqkCm7cjQBBnKmUS4m8dKdVysGWiy9WwyFSVwv47GfZIxGVEtO8Sr6qxHpKhpNzpjNq81Nl12pGxbNAw2NQSqFKv3Oi55EroVO4iI5igfRoi7l2BPC2kOkepS3I1mQSvupq8SYirUD8j6UJQeTS2UY24jlBpdVsb7KJ5LBumzrptAkrK2nrrWuwjYlFHUaMoZK3hk3HbiygVbSgrSk9MTRrrYhVitNPFUmy7OY7ba1px/rqYlKH7re+JzDf2qOCpOfQy8Y2+ztoliTjx1QuPHnACgFTMFzBHRoGD6crTn2jot5ZYvnbEDa/Tem/pO8v+8Ymus4n2PEzNvcVO2HCMrkYM89JGWnPJD4WvpP50zaZh5bJflPDXZzMuKCtPK6FnZPpGNtl5H0nDgBmKEgYKqZSUqApFRNxyVEgq93ecfYGfo3S0bqXWlg5WJGBpOeboDxSJ13IDRpHGQmiFYLlKqLs0ooOfCWKTNk1k1WcBAAIUg9BBrue7Q267v2Qj01VkX9+41pfTHm0GM3tjmV3S7fs/7RPZ6zrqTJzPuPO9m52Ypm6OaOn4bdS79AZ1wdfPNbbO1qd78PGpJTb8sHQ3069nFzcCRTTTkkJAJ1v68EsNBZ4fwllE1wZq309a1+bw41mufDf/6smwObfGABcxoQNNvS2p3rbgAZQNuUiGbC60kzOG6KeI1gwot6oGBSadFenk846sU6say++c1EPJep5F7bU1qepXorqVDPumQ7aEkzWRO53ZFmp3JybOhUIW7urAmdqG2eD+3dXX/2VlTumbnF1Fanf3VTEFNRTMuOTkuNVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVYKbjbcljYBX5b+29pvU5TQIDoVBASdaExKKZSBSLpjVW74ogy4q37IPSBDjiRL0BIYCH2MKI+8vcIxh+AMIJXRDCs1cEqb2ankZlnvNzyO098sr8P/8ygIs3OHudI6CLoU130wf/lpGvvYi5Yac1u7p+SAIpRNOTWNNu9EOAiAHjypzIYquwQqEUKZqN9kJAvuV3QlP9sSPzcnk6jXQB4jOUKFUaKKc9gjWTbakkr9+/a+2vzLvYcan/wV5Z+Cbn6w8w3lEbhpscadxKWFo+y5muTR+aQ1Vjv73N3dGjMVrgX0f/9///7ahTbbjktqZIWWW5YzB2jQTIgXDY1TQMYF75Q7y/autTgWXRtqNE8zL9BYmRTofkoSNyceGBQKjKeGlWpJFz4rEUis1WQq3a8mKvGfHZAquoFDscHi1ijmCMcICMFStUyu2FjGF2aghnDEDeQKyq5zzelEcEmC43bV6S0WKU47Agii2jg9NmIiCqKOEooLjf/WABETkbSRN/KUxe285zlxQjlbdOyEeLEV1Xy4j7TaBPZFT33Oq6w8si+Rze1QIj5XSu26MnVhYgs8R3EVDjddNA6yJMgPyk1UB68pETMKLYQaJLt+eMQYyy4v/6skxsNekAA5dPRGsLG0p1pNh9DykYUf2HDaykcWKctCApp5mxznO+68EkuRt3tzs2CRh2rkbVghyDGQYkh2Pwn0MvXisOS2FtVRtTESWujM9YlK8alIx/p+7LZp/RKY1txouvZp03un6l6tP1/SuiOW51TEFNRTMuOTkuNVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVYUTicdlrIAWsN4YrzOU0DLSShhpH4GNvDT3O+XLlL0d17Ln22pBFgjdAaS9eXKvsoup0P1oqxXRAHNWjejWVWwJI77+v25dNaLEd4WRmRw8prO5nW1OM/vlzLp9LM086l4puTHc9mLlm0W4I7n7Q86dZfGHpoSr0WuVnIKNQuKWOW21oErqAsniGTIP0mbcXkUvK0wkf8e+yLCtVcGokTwnkDX3ETV4o0rpaxQFUGFl1MjlNdEGbYXBgEEJexZxiBGkg55S1iReXk87JWnLFcNHyrDSIWUy8XHAAslFtSBSwUsxKBQKctjTSWNukpqdCaYq4AhECQ1IWCpuEwNluVLuy6prTe7ZZ/tPsRPF2wsERjbj+QrTKg1sv4cp2o5SsDzK8p15TMkNoY3jCzyvrtTVqHbd1VNaRslxchrx2qisaNekT6PzlFJ7mMRMMlTlhm2ln5ziNJV0yOszlPjR4ciqnTlhGlM6Fy3zxhQEWdkL5xu5Xzr30ta18pqM+X2yIV2aZKCLYYibFSvq/vHS+2oDGao5LaiUXjvV3UkAwMAAHlgGi8ASkU1bLfMHhaHhm6zr2YR7lER5OTH2TQsktpZRBLvIorjtXMf/6smyhSuSAA+tcQ+ssG/plJKitDwYZFbGjA608z8oZM6H1pI4sKYJFVdSZZEkU2UzBIxpekxdWKTdbWxAvnWAsosz4jotBkENT1BCItTS7Mx1CSkhcOQlKBoD2I93MUahgeNUYyMwjmzM5pTYZCiIKJfoVTEFNRTMuOTkuNVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVIUcaTklqQJfM+53n+BN0AMLay3ZRVj48NvEGV8zHLtUevfBG82B+FbZbEmt3w2iM4jv1zBeU3cuvduhRIkJ1YkOWEjiHoNzcxkqrjRKMT6boZFd9XNcrnkpqQiK7Ayh7EZN7EydUkM3pD45v4Xa/12/OmjhSI98wSkwoiO1RtMjCDS+oae7ltbac/L7r0w+OjZfF4bjsqFKQC5zaaR4ACqPGW2IpUZbKF1HI5TET6VcgTJp1UDUmKVYI0Rn8VqofTbhVmtkCn4kvNNSrmxcEmbV4DRac8cpOKLWQ73NkzYyeV/5qxh5iNiWbHVnz6UQWwGZmUNIoVt2yoOyYb8V6sLbKjlUdu0aJCv6uV2ftLMuBZTYJC1JuIKxI6lpjesbB5zXUc1NGy+tCUi2hJSw7sPzRi4TVYltoniCdIJi9EzEeLtv73us8C1FIBIBuFIAjOOPhTDAoEOI+eLvUHHGwTeOoTHcDuTgqV1D6Jq7EECO5K5IMdeGa9qET9eYUkhZpBlxOdQshqAVXKRhmobLtYYDP/XSgLLLciKSW9cvzLWH7g583wguKHFrrs2E1zGIsfVSiHIz6NlMiQwpRppJqmUkQoOmYtM4iTV7ROv/6smwpguYABBxhQ+sMG3p9bBhaYSNuUmmhDaywbeIVreDphI25olYQw20CCmFE5BsjLhUE5FmlWqd0YGa3MtcGaF53Y8GxLPCYLJsruSG2qend6f3udQYoVr08TFA4MeF+HP/P260HCXM9vy7uWtcwf9PVTEFNRTMuOTkuNVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVwAQAWABq1OajCCAwgWdMfaAlglSQ7BBxKJRyvOHkY6S9NbT5eDa2q8anfxE08vOSwZBmwx8ueYHJEEVkAsIgKpv25ms6v9i875AxyoR/2N2M9sivW+WWtaZ8Ox1eYaZ0u6/Qvoo6jTd2+7F3p7/ZmrxLYrqnJMf9rg+Dh07KZrkCfYvCc6Ydvk6b8O0xnjlB7rBkuToiHUZOD14FoAtOSxppv7OVyIvociqoX5cL40VVHSsNSsFQME8U2vG3rqKDQ7TTEZIpu0t3BZAdFscI4NDDRlB0tmCPxoKPDmVutKN1WabiYni5q0lJn2WD/Spc1kpH7qrg0xekWIWvvmlgYrpsNu9BzuVNolHV5UlRELTjmjxIRHERehKzXJ4IjwwDYGCru5lSDyEdcEEKuRpIl4dypIknsa4IUPfK5TSiplEE13ZbArIZxiK8S7e4OQHiRY6KFVCcgRDq4pEkzBGKVwOEzeJTQRVyjaNQ8wI4APG1Bo2YseJQT3BKCBOwMOZBoxxKQxNsgICpHpykiz7ePy5cQiI0xPyi+mpU8+sXeK6C+EwQUYEGOMB0NHw4GgoCyFatSgCJRvrgUbyjssqZJP63qCtm+8zp1pDbcg0bBpx/8v/6skxubekABNVrv0spNCKOzGhNZShqEd1xBUwkbcGfJuJ1lI2kqKCK15fNXhy+FEbT4xcqgYO4EHDXIkhZZAWCQGRJnM+Fk/8VKvM7bw8nmul75yfLT6n/lL5slUk1Pv/l5vhMf2uYs4KGW5BUotBNEYyPTEFNRTMuOTkuNVVVVVVVVVVVVVVVVVXGFBXI0SSvsXKWOCEEGZiyj9e37NE/EIZ+CLpBjd5Aq07YPU1YnOLoVB0wKRHOhsDkNh8VlFDavOoOywiYE+HRUyCDtQ2YDQsBJcFoWFqMdE9GKzi2QqEVHgWER+yx7I8rPm4LoMRWMjGhFFpZGr1J1jzhrBBnGBkwcqdENl5KiotWmSQPUNY2TQvmnklgoQU5GiSVjzVeaS1Oi+UUnY5LB0MTJVvnLFzLPuOpXFZTc+pVxghjkYys1jQCASKFgyWEgiEZFNInH4MK3iiz8TPvE7KlrIKY+uTYc6lnYduDfVruxeb4SYc8KcKbJTY0Pf8LwlOTOsh4TN6lHpGxwrH2u2eS87MKhGMcFHxTLo8C1xMZiw6Wf6Alj66Of6MebfYEL5BG5r3DbLGTU4jbvOBKGRmHCWrh6vXTDWfQt35mNr2sQkRot6JKuOCsVXGzgrJifZccerWncWLZvVY5aGhyWFYGAbe6ONVLC966886JKx6IYGPbBLHnXQ8rnEqCAhUQHSiKDPDhTYy2Ka4jeHTzqg7XtysZ7SLemTqFQxZIMgJCh2MIuEK9PqZ28M2J21f7sMI6XiLSiSckiIAV793ZLMFiZQeWPtJJQMGtZZdS8ys567LM3IN8SUIMnYqHCRhx4L3Mkk+CiP/6sEzGgPQABGtmwNMpG3CSjEgaZSO2Up3c/sywbcoAsWG1lI395K0snM3Ngym0lBJBBJ/fjFSWZTS0sV5Grg63iwpSFSeiHJKsj3e53PagmGJymxlf2Nbf9bOxoXwvMZ7lup9RKTllkzKQbUgdGMGRTSRMQU1FMy45OS41qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqoGjZnLG0m9Xt1XQTsBuWls2XnP2jGone73LnxJX0v1iHfHzlAuCPfr5Z1E0cyLQaN8mBZdAbMRbRPi1R6emND9IXegKPhXJqLEkxs7AsIL6iU9NXDGtmkI7kxmLF9yV4xAnGOMO6YhKR/SDKwVIb11EK0EjCwTzYx1MKrHGFhmDIW/AbZmSGoRgdosRoxjOlWEvdySEgBax1Z5oLHeifv2MlM0rJo1N8ATJLf5uVuHVURKDpx1LTl0DRWrRfFYmpTcqhSLl0t1XXt+IuxmbkO5XIPiborE/vuZYZbaWOy9yMjqIUU91BoQ9UE6Wv05KBrbclaEipqTnXSnseRlxo+ZgpmBZwJoxNuy1tNvC9n11kyjHUboyCCuzp7FBizgynD6jPKamXQmMr+5h4Um0RgX0tF3LVk8hLYGfMaIa1ieqtaLhOfiOtdLmwf7iNwzCpnXzMly26SXnfM07evGZ+7llzdM8u29DemLMjcK0eiqofzGornMimjn3pcrxnPbKNvC2U+PsbGv48vmZ0b2X2/jI4xTCn01ePpZMRyjktjRIe9fllLyw4XNk1nlcDGDciCme+4uPe1dppruiLESGPspXYk0//qyTL9J4YAEf2fB0wkcUHQIqGphI29SjZ8JrLDRQeMsYjWTDjVnBEm7kFrc1KqkjHs/fnxF1oXJcFFcgU9IyMPCJ41Wk9pnJoR+Zk2Xb5ZzTDLDe3Y5DhomR32hnTfMz0IjhkbsgPqUPTpjkm1MxsAP75dMQU1FMy45OS41qqqqqqqqqqqqqqqqqqqqqqqqqqqqbTTrhlkjQJeeGOEEvaWda5L6Sy0oY4yGDKmHKjgeQTnbLeRUDsfTUwRoS2f/5bcpzDzUFrQ7FHrj8fwrGLHD3uwruWwLGFjzDbG4kHkaXFWDg6Z7I7Yx92P9W/4oXW4lTiPGzwTGsg94/7/Ts4n9hXKxuQuMTotwUFanHMOble0LWHFnLGkm7nL1WVvygw1XmMMv6azICorlQOW1Hsa/Fa94aSXe2sm1vRISxLIyjiJ4oSyJJtizxqSfG0ZQ2AwPdQRhBAXcWc/7LQbWBZDj1NUsK6bqtjVIVeFD8lp5mlvFfEkQLkXsvhrroZh8qC9uyTzOFh8mHDAqJahQUbp/+gkstluSWIgl7t3e0TXibQZO9D8aTqaG/i6HZwgEtS8pxKcJ1R3ZSRD0aiOoPGCa+jWD4WI0ARbunhuUhY+uYKqseyw7B8MBwfloCaVm3iQsMMGqdZsllvsw6mdenF5HbSjLf7Lv4MLkNMsead6+S/6i7b12+pLe9Z7mVdfxblTuUUc2pTtvdwNLuXfLLMI28y1ZaeUrNo/0d02/1BNNNNyW1IlOSm7l1L+VZ3HMu3Me4UELg60T9tEcxZljMLuYXUigIESoTDDAnZFLkKAsKx9dIic0OkLLxCgBJA8QgMVN//qybFcN8AAEBmPD6wwb+n+L+EphI24TdaEJrDDN4kezYXT0mb1ZcZn0fPWnqe91oZ1kyjS2ualGfH90VTHvm7pD7h2u03bozXX8i2dOtiyjUVMddUt7N7f7Zk2+R7RtBDLTzMTc35m3N12hJtto+NRIPBJMQU1FMy45OS41qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqkWerltjak3ly9LogTNd2rP6lpINLF9ZPjctul2/b5xxexo365hJlAfZ0gZCihxGXVNvTEqpmYq1QpIiEMJq6hlJQ7B2aneMDXGKtvh6YcKxHC8ylT09R2J3eExfTn8sOSwnT4dfoOTy4gnIK3zHIThtz6RabOR+jfnReoNTkVCidbdltaSTwx/PsJCwmCW683krGylMdnJSUY2G1dNU9uYl18qlT1jq6pERyYSI7rDMpMXUEyL1a2kJ0K4GgRlBjtmUVjhvTnloxuRgsWj+WhTanNK8Ic17Evn7/ggR55/C/8D2pdKSYr5/lVx9ud/0TahbcccsSID3vGzKoHPMEoExlsOsKXUkDRI2YyqGI7oo4D/8deX+yP18Yk8ciSQOJnnC8XjAtOfpwHfrFolKO0lH6KjNrhXlZudM3CyyjkAJ3xZr8uzWfMuCbdODWyIkvfz5v/l7TN/F5++zD3HZi6nMjzO5Vyztt/djxslexuFIvjsHx9aL5q+5Y4Ab+6aSGKW5HhcxswQm8bsKFeMOQU08sux7Fe60UQAXVhqcnyPet7gnqaOokzFbNc1c9dcWOCMg050qEQ+oJSOA/iOzhDOimUXRaayKCiWC//qyTIPa5QAT8WPC0wkb8nFIGJ1hI29R1YkLrLDN6mayoGmWGbgzsszaOO8oZrq5pusyNTeHye69UQmiZm18Q22pU0+nfFpNDdXZjIxK/rPTeqjcVGSX9Q1O4qmqMW7zplNrO5rZsatYLC4ADtshpXUbjk1MQU1FMy45OS41VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVWTE6W7LYkEX3WXLmKgDv3qOUzxpKqemedc6m1yKiB6CuDrg8uxR4FklkdnSlAthiCG4x1lNZbYR2D5O+RlJqZmJiPqweS7sqcuUcs9oXmkcovFVb0nztD3PsPI3/b5/wt8p2+2UpTPHob1Oi2Fy3vKsFsppRtyzVohPOfTCnTKGzW23g5iJZ3fe0/PS2xu5xGGTiBs+e2vKDaeicNiRxVDCCqz9Yi+bfLsWLrAwTYeEHO114Zk7mZuW02o5uddSPMoX00f+LxDPO0zPz/Yyn13Ii8k4m4gsvMbSMSHEvQ0/tVl92XkmE04447a2EnqhrX4+vkDGXe7N2Px0LJh905Xujp2TX404usqgjbUV0KKo7yImE4BgqKIEAdFAcRqsFBgT8ZeBASEEA0OvNqqKCvCdHQRJEhTJaAMTJng0EQUmmlvG6OEVWSr4T6k5b0/+0cgRSbVlmZrOQKqi0k9jpGkC3xmnL6SCKSSRKXW1Yak9h2tHwomU8NJE3IfXi9oGxazbIrXMlLnbCBibblsakl+vnYyqBQbBqteldEDlE+N05Z3dUEnrTcJic2UvPr7Uu/+GPNcmohGg1fYeV7B/642MiurJbOnryE+ee0mMcjTHdbML//qybCek6YADj1vEawYbenOq6J09I29UOZ8JrCTRqmO0IPWGGjCZQkGWjvKoACAy2IpYfWajqXMd4N+bv6n1knwrd9kzlmtZvkzTqxrzno6lytlK4STO0rJ1ox2Q7HZqWY7ZqMMx1ezt6TI4VjNVzSdf9apMQU1FMy45OS41qqqqqqqqqqqiLq04yAS57YttWA3DScbK0noB4qTJgziZLDtXHVT7RWN4RaYXc2kjfpAfQRRIxORi6xOpuyhFPDbDJQvggesMWIDKxbYjy+k5I9NqxmDHqWEV/qsuYUjIQZmnPXimwgVIwuYcEURKPsV19Ja+L1ehjUlUGhO9wqI2pBlZEhiCAkoscyoVE3JZEQUsv5jKnZOQ1q89lbmm9W/XubwbJoRihjVNLSUQn1ihtJgbCbxC2dKkqN+NF1TembmmaMNqU/UrKw7R7WZLx1Pe6nW8zjqeeNQ/0qzPD2Z9BBlnBpiaRlSNjE0qnCBozJ1vPQ1FZMaBrFa+Nqy2Gv/dtOrvJW/HEAdUi1O4xuIuI/R3PORKQNcjDcELHGotRoCjByNR1MjCFDcWGSgcBAJZ6emJBMgMlItdZGT1xtryw1Upi1GODr5EjiKpoUquBgRM0ud2gJAKGLS1zt+02pmnLN0ibYMfFRM4GOPal3SO3czccg93JrZtPiCp1C5mZk4oFIas/09TelOSTNe0ij/DtKiVlXkiomu3I7VraoPsn5x2V6c/dxMmfsC8rCEU8gLLbkjtrZSe6Zi4N4D+Ll2s/DrEstObrcdFFLVsKDLDTfRI1ifF/IrGnG5fwaiOoK8JEHZ/isNZ9MlJmJ02eWXYWE5Z//qyTLMF9oAEFWfCUekben3qWG1lI39VCaT4zDDNykk0YXT2DjypEON9zGcsydzLXJ6XWtxZX9cZaoOMRfvDI1uhrkIAGE7UWDGuLhwneKDUFuDRyFwWOYfGrFTiiRBHGUXTFHDtM4ngsMiZ2NFJbgrpkQNMQU1FMy45OS41qqqqqqqqqqqqqqqqqqqqqqqqqqqqMCxR079rBlRKY3oiYmYzpj7PB2APIVJrldGcXAD2vqQtsNlkVj+SGteA4WYlWtObc3q9SrhFqRufIuMpm6KxnIkk4I9OxskFhOZWKg41ZMjIrOYl5lrTtTIappFQYTYMTJhIcguJhwkbPFWi+lF0m3GUdCKwTSicajowJ4EZrm1wgMo9a7yZdibQuFCMLpoDJ6jpRMkbnQ4s84gtpI2YMoH4QaijCsnXpeYrtQ4kgzKRbRVG6Ca9amle9v5KKSr4rXs1vJDVK7C0idlZBcnsNAzEDe5RnVqw4BtgSJXI+Il0WR5tP9dquB13d5vnW7MebAfLhIuPDCRml1x0wIupR5Xl1k/eeP9bWwZCYOzK5QFwriXg5tAQSOwkEQUIFF+hNXokzzhlNzyNimTJuUIKnS45NY2lSOJvSdBKoHnnm/3XdxZUiiXunXok+8XRJUxOuze4zrHX0//+SO/BoYrr3ckiIBbSPKlAnT/j0tOcMZ/v70h28NPrtlVeIBOFJ2LSpB4BZZMht+FPp1X4eRmtr14TjVnyYflBQtM+7/uIww4m1/fktbVi/rKLzfIZ6+q3+9y3mEBqzE2BquxDlZ36dTqBCEk5Ek2/ndeuQhznE24xwK4gaH/72G5+4XXq6XKe//qybAzv8AAGjXg8C09L8ovLyAY9g25MdJMRQLzDqbQmoSj0jbk3ccYesfkvabbgo9ucIQJ4kDKplKS9M2Zgr4kMRqFWcKZbne/xx72SamcLpn+VzL5CyzhKTTzWz+FkI0Ihb073Td8nyvLKQ7ltcUGnXtoCCHnJGik6W5flHWsGDotqKQNDjWQNWifEpHldNQxKh8eYr8q2lZYGg7xrBOJZ4dALWrBKLxwXx2JJuVCkvwenxwBVcpXoSIqg6KxUV0NleOi16hhlTB12qaWBI0oECBpgI64RXB/PKl1rl7b21nHPsIHlqx9hzTulh9Di4IR2eXKKNxmibcpN9y8fmYWWyOnlWmgWW3LiKZzFfnVpqR0uaYyZhAu4JKm1GvQ8ro+qcz6GmSiom5LakQVb3jUoIg3eSRHGfhwuCLykF6phi4MvrXgjdOoqwJyoOJ24sm5uXWXS0WSSB80L5IhIS4+hTn6JYPpdEohcmEhWXIH7Fx2kKOKFtOv5iOWLw8h/F7vz5w0JxxkEqIIRSDAgtIYDQNqsnHuDlHXEGhGVpzFBCOQRmL/FEgpCbKkPGRDjQ+xKSMcgOsMtJjSrHgIEv6P6QIDSiPefOQC1czVZS88lyXWZolpnvvZbtM7le4/L98geetqiltqjVW4/K+aUzszD+JWTzmBGtZHtUpw7SiQXbqV3P8pT1evRUnYbabS1TXN1p6mWsLSnAuvC0qHlWaTzL2SkdZSucjsoJjdSo6nQQiFox7oMn3zG6Fln8uLXvmsa4r5NJYRfUDZg84yIMmStW77zId/fJq1nv/aVU6lL+2BG+sN1mQYAZVfqWqtfVLfW//qybKuc/4AFkmc/0ywz8pwM+E1hg48U0a76zDDRyou0X+WUmjmQ4BbjMlZQzoxpAMm5nameENS7JKLDTaNScxphFTcAJD7TLBKYDxGDmSGid7VkJMsZxN7DLFQciWyUkpXAiECfg2gZNivqH/osvNog1IsHdP04JBWBkrzXtSmMPZ9NTfnXdVlF1e42z7Sx9J0jEsrSOZgnw7/Y845sE2TS10TPhf5Tq7NnsszVYjHL01DmM9/ajtiu+Ps6/zXgBVm40kk8rfy5whLozxo7AWVSSfZ79+rqu6BM5ORUkI0mhCZ7Y+u5GkbD9D7JvCdETRProCd6BNM6SGn3Gb07xNB2c0UCpwWdB1iniRH7EOPaSuS51yr36DW3pFNrk68zNV0/KmWRZFvT/blVUEQm2t4puEXMjEXcxZmywPFPv9PQAhKzkiSTf4a3erJxY357OwQMe6RVNqYEvlc00yb0R/mJye2XPSJieZEZH1y2zk2kfQnCIkUKs2sFhOiUQxy2UiMh/BqtSNhCpZde/3QokbjyZqrc9mzKspsVp25n+/EKnRRLwzJmyqS4TssPiuxFGrE5HL30xz7AdYj//QAAC18rfaI1MOzzGUHK8P/RI5ULYFdbD2o47Ydr5+35iyXB8q1X9BmraS2WPp1BetcS4ikuHm6RMX7wrYUaNWskCFxrYjFqidPFJv5KTe9SqOidc7yT69YqUI+5LGi68OzpISbKUHXPU/fJmoNKIJ3KF+U4g0lJ6sXO0irH1WbItJPG5DDHy0Hush60tsmECipPbELRFCM4KZ8wkWAilFLEQSuVLtrsfNxXVsfW2n1y179IylNX//qybKnU2gAED2TBUYkb8HyMqDphI24TUZ7/J7DNwho0YTWGDbzyLFK2tkJHFHXqIy2rOjhrFxjEIwlpDAKVxkfxM/46JY4XhLP8FmYcVQSHghIgZouAqahylo0Ql6qmRIpm9dG3hq5Sg1OQWpgowT1r9I5xCIqSCzNMnNC6rK/NGyYSef5SEma4PkREWtGoXWpBRyOSS7NpOYxvFG8GFIq3sVCSYoNibnkHs5NiWW7LnadrwiVIk1EskjGMQGEleyTyYJlyMrBEJySRZcGkEEU3A16THOJpYHOPHc4EH571HZDYje6w+W8hc85O2GmLe5wrf2nZC8iIqdmXdzKeDF7qwNEJyh/bUOKzTfqBVccPmbZiC7WHJbHFsPhL7H7LhDrQSbKM+X4ixJCnZ3lSGBAaBKyWMiNkhZQomGg4amKpEqSROgbQR1BNl5emoRmDNi+x2AAqAndilTwoBZ1pkqBhAPJEuqdIcmcZkySm6jcKyOL5etTJd761DMETUoCEOUtBhrBZl4jirSIMfX/Q4aAFpbOExk3EcjYAsZ0ofUcQQFEz8G5jzIalk65Qdlep2vq0SXT/sV1LMJCSpDfROXiWsDpeFTYnnp8Jp+ej4ThsvBsnIxKJG2PNlMlerDOILtVrcCSYA0QSP8IuLNXlnQgEUYBqgGisXycoQbZerbpA+t2JukdD6abyswpOB+uUgnkClgqsyi2dI7LD2syW3HTZ3f0ExZzS5Fuj0iuWfGYVOpV3c6o3uVnhn8+MZpvfqUoIUMnGyk3d7hcsPGF9MepoxlSGEitLJfwvz7Fn2kTN4Tq5+XmnitBHK9fpaPmjg7Cu//qyTFaV8IADt1zE6ekbeoar+DlhI38WRej2TLDNwoUz4CmGGfgSoscowlQ1iyHhGXso7Ib7RmdIl7g5WWuKUNakJLIfyo+b3oZrZKeOvVvWTR5VwpjmxTJab9k0vIr3nq2TbqSuxk0YeZ6LMwijrvqshRt9B2LrUGy5MOn4qaVzN5eRF93QaMowGiiEpCSpEzPBS60fTEFNRTMuOTkuNVVVVVVVVVVVVVVVVW1Qq3ZJI2Sm67mhuE9CWoUVgZyFEZ5A0NHUl73RJkqMLew+ooooK3S7Mjvbot3dfmOxrI9Kjz9rUNNLe9ORVh7U1h9d/lvLUjdDJesWVr9Lw8uXn88zpWWag2VNmGhJn5F3pMR8BmnCCR+2OP83fOLHW7BBTKhRbkiJJf49ygp3RClGmzJ6V9ggAlSB89/yV4YRizOFsPSRHVz9IVC0Tok1oPt0QNFIKitt+MGaIVDCIsCWEisnCtOKyH6yjZwpF+x92v19+ecQqadMogGYIEwU/YEUFj3p82soJICOsbKTOU4k5m/iBAoYqNTlQKUoYu6TBZB8h8QZVHeSCnzDljtt2/zkk176zg9wUsjxqrOQ1ue5sWAfat8WIn1VF2S8kNNoQIbsiPFCVLhpcQsKF2pJSbjJldZcleqxAxFb0zvkf6PAfQVaRcl3qG0YZmz0rBLwyRYbGSnHp9hobxKzzhQtVHjzJu0qNSVUPGdjzzRlNJRyigjUMZqQtAqiAqQVkOdexHYybkFBqbLHBba/dFplDRVUmm1Bl6JAT8KOVdHh9MSi6IGBNIPTLvSIWDI3sYGCUNEEhUGhS4nFL4k4kRREwik4LRKN//qyTGpl44ADmlnEamYceooMyE1hI49PvZsVp6Rt6mQv31mEmblFdKKUSTqd//6Al2d/X5cvWe9yjT6uDP/WXnu0bsizItcWx8PmSVhvfSjbNmoNyXlzmrl9ubJ1nNElrDBRFZiLWV/gno/UAooLM6h+TipMQU1FqsFG43Jbak05d3lju+BnNAp6lqWLDqQpJo85FSWLRcqovjs+uF6tYS9JpwbLYKuqJMJdzC4fHD5stQYzs4PkNg6vqL38uEKc5t9anfJZp3/J4+shDVD1TbVrpnFu+M55V5zPsTG1Hb7m37v+FqZ+VkxFf9m1SdbJs71GHu2sZjbNPEaqif6Bc4Fcm8qQk4m5LY0SpFn9vocGYkkZSEpRj7+K7UpRtayOcmzBCJFSM4kmS2GiPImEa0CNEubMFd7NkOz7coE6YpDGFM7gYgPxX9TvqdL+ZZPaWilTpdI1KEG/yP6X1cu/H5OZkzkykVb2pGZPxPrYJt5QaORKU6De+fgxgpFlKOWJEpw6UhNaZASCwrMmoY5SOjXlixl/UW7fvfVUrKwQlXFWKJOId8ycL+wtemNzI2wKdXFgcjQYp4jmQA0RqGEqIGUOOXpdBiC22ZPAMVGFEMwdA72gxYJXH1B0DDHByBu1PGVAkxtgYchyBqbjUuKwlXdwxCmACizXz1IHB4ModK0DNIJ002DoiPEGMjZUPMwgk9f/qAg/IrzksxoZhqgTdjl+XyiHWmCSIiyRFpxLirFzAc5dwINmBm2ipFXI8P1TjtJ04OSfR5lIS1F3ORxH+n3FRMp+LhaW04edVmaFITEDBiNjqyJR9weY6yt5jNd4mbYT//qybNtU/QAEVmPDawwzenYLmH09I29TQaEHp6R6YrQ0HxmHmbnWyEFuIvV40MKdsy5K5A3pdm5WH5c6Z0EiW5s9z0vtLvtRA3Sj5XaXv8jhWJaYiG1ZM5ucYDVY9AmdgIbUFylqBNGw+3XlvfuRa4Q/+xJMQU1FMy45OS41qqqqqqoAB1f+bvxZabZRCVQj6s6PI8ylItd5IbL4jyl2WHG6XKgYAeMDUqllQgFk7dIiIEJrGaJhWTBNl+wkM0yM+QVpgbshiwjUHmMZJBmL0qplyn2Lq27HCjp09qKd1bzfbzii07J5enWhdapcEoiqy/rVHj6i7offu3luTwp37wyKyCda/1ruGiJaU7KN1qLYus0M7zzWkMdyrZKxGakoyQCscbtnlcSY22p2Pw2whyM7UXrV9kjGFq9XX3z4y2FTB9SldciiaiHtkPzwqHTpZP1kRNUNj8YMu3XOPj0EHF4AAskccqwRQhMBkaGJpAezoonKMAAnUUSmYsOYgJUKVZAarw6YSjrDOOcbqwZqCNzwjNiCqmdIoDRQq5I6FawRHsjkMh6ZgSKCEgKRO5Gym5jc13GOCM0OwxR41XTZo8uer5ARo1lIWwohCipxQBCs5ChGLCBsfBFYiJsGiMYQqkTcE+whtK3NNLWcckgpaaCLCUWFPyVmma0odfV9oeaPsmtKCO0UaWUGYPc25Rb14Yk2z6CS6084alsZycMEDQDFuFu+a1JfTOmQoY1OURFO//6nNdrckJJLz1qtn05hV5lL5iMQqeoHbRRrFtl3U9n1LK5GiTGSo4VnEcRdToS8cj5UYKZfOkRNhKidYcF842ge//qybC/M+AAEyGi/yewzcI7tGCphg28RFZ0FTCRvwjS0YOmGDbyrcVDDAaAgeY9w6anwKos/RnKgAiuQMEGpDKcQ/UWrUUbhpgGj04DCsxm1M1ouAzMObXxGdsLmLzOSDMtVDDkCeBlW4MFpjWsCDESwyBVMQU1FMy45OS41VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVUC22W47Ykk3qSaPZzElSDOnDkJSWxIHjsHoJ6SiE3Kg2mQrY63nK1CPtJigEgCih6ASQAoSgQfgbbLxkaRizyiFE2MdaTdmXTLLxVJf2VU9OvSUycUSI8w7mX2Mw7WpkakkkhZLKe6vf6l9bLlrqTTVasw407ZTCTrLw0ZicTTwpLMd59EZ3MyYc482J3Mm2zzkcqwAIBMaRJKtdv0r+Polq+D6083mgkDaw9NUuC5lHzK56fyjX5HhAiiKQlAyBERyuHI4ic1AfvnZ2TSc06Q0axTUmO0hWvHZOo8qc9mJM0yiZBsgMQpDrSCFzZXi+SOlWDjvB6jmHlqG9krbmZkaL5IrqTEkEkZCazQi/U8hmkIOIEpDzdS4CJQZ3ChUBiywZI1rNzDjrdOtCyRCYmm5YkUpV7zO7Rlxl05UOWhwTBHZelyq5JFAxlTUUUl1Vof1qQOtIlSPQDhmRkEW0ZGOxXvSM3br6MYlMfgQEeZU8ihBWdzN20Y9A4cz5k6PdzPDqHY1LLZHOEXCNqAkZMEBlxIme5lmr4JGiHi6HMDxCBERCI0G8bMhOPZMY4M9lRCar8Aam5PZqIVFxNH2OovrPkIkDjWvxtDJB9TJ0JBA3ETTibBpp4OmWNsg//qyTGPn7gAEnmjCaekzeJhMV/phg34QcZsLrCRt6eczoOT0jbwncTs6JSEyadaT2osMlWMSpm1p6/wq2pqaXPi1j3cmLjAypP+BHZhk7kRttm7EtBzWKmi9B0gcsavgTRyWZOrHdu57ZzrVjjFtmHxn5VVMQU1FMy45OS41VVVVVVWCN/LVWn8r1SlQkup2PUr+gFSEMcpuVoSCrs52xIlmKW1kZ5CkLIHNLKySgJYlMlMpiw8FTI/mBTPAZND6P69c+pWrLL3bKIbJeLRgPymLjT/OLA5rpThVlLhc8SgkUXbxW/Sn++zKPrKkPKC3vp/r+OZsXcopvmo70S+t6dNVFso7NTCmkp2pl76JylDyzUTUzfoO3/5yem1HjdP/XNraJ7bdogCa/5RKy66ytRYVOOE6cB58llnC0GRuw0tKCCSlRdOF50OJ8RBLCwyXwFpKpQVw9HjzZ9WNwtoaa2WU3yu5mG+fOMekU8uIjN7lF9zaR+WpWKNEBCVHQ90JKqGw7cpmBhwbuUobLOhvOV2Qh0CA1Jb+bKZuuOEXp0AIjOHLVqcG5qoCfiQUlN37kiIKdcfS8oi9KXEOK3tIzG9TjOGEcV8vM3z3WWcZxMIBZE2h4XyvJZZb9n4y/qwgldmGAmtSwxdSebAX0OC7CrrzhCDRRz+f13pJ6uREb3pElLI0Bt2IiCSQk5wR2odK1n6wSiVrs9qlIj5oEPeDWpInnRbNIPmq2AKuWvZ21ufEzME8EXOca8ZI90JgCdNVUFEGkRK4KNJe9BQ6Rk5KKhAOD3SfR3HBslQiFGjFSzCUjyRQ3QbIkM4wMYM4JhQpdiDW//qyTBwo+AAFHGi/Mwwz8oZsOBkww9VPeYkLR7Bt6mCyn5j0jbiHviz0fIzgJRIc8ho1x0WBAePBNCDAN4EGTEHFBEGWlDBJmKFCgrlYeHo6YR3Xe3uIzJRRu6DsMBsIKAXAT4g1EkDQIkjyHCjeffkmpklMQU1FMy45OUAjSCuVBy3J1irqiF3OWsZHXtBniTGneWFl2jVrJBwQVbXvwdmvLi0l2TN8fH/OU4WE0z1hMcDoqO4HiEIsnJYMSGiIuTOTicToP9zYY3SDvnowrWnIm4ZuXW3aa91yqm0ntSSdGv41oM/75JaTVOslp6G4ZDa3aS1R5K+P8o02be3+P81u7Y7Tmvz4X+qdjyJv8QewqWOM/qkCLORtpt3my9iNYAHDVPtQXIBtON9PB1M9bXuIbZRqjzbcH/Q5iizsDKj09HS7KnmliWmS0YkmGV8KnDTxKZUioKm1iGTYgvqMIaINckjMs2SSM0tHvyAL+g6U7D7QnPT42TuJ1OHcq800ruB7uuc2xq3uW2lTiHdsgftS8FxXm8K9PHJ5G1iO6aguIdUsX2nzllmDmmqRRpoTUClG23rUiU6Wnyv7mIRB1uI9oRwrO7UVoKkZ3mao8msf8nWnGnyCBcWgWCkOyAKjID5weHumziM2MisTx2EqJEvjWLfXSiQoXJRx0HN/CDPkYjkMPXUmWm7pHi+jDjpmOSQjlI3gg1Qsr0wVLCGyMtEqetNfIjJVKtLEc5nj3fBly9ga1Zg16BbcAQFuNFJy18v8VANFfN5pi9DyjTerJ55OtkvTGzKYniQZ3Vrh4LF3z06OAOpnzJSfE47XGqRO8Z4k//qyTJIt+4AEyWi+swwzcprM6Ao9JtIRLZcLrDBt6hyzYCj2DihSn1mrzhBAJtzMZgLahLD73ORwuQ8+pGGbM3mpLHaquT+ZvTpFEsJYUByIYhArHmWo+TGAtubludeZJwNyBBtjCuCsqlUKgQeIjkJ3fQpMQU1FMy45ORAQCAUm2ipHXMSDl8BJmNum1MQM3HjeYm3dsoY0bb1ki5IQmmtgKBKHGdTWUJJsRTNImXgONNJHgYY8seK80sgQRYqcd4+RmRfnSttn282nf+JVvrv9ab5S4R+JoeLxNmsyYZZoHHdoO1gpCOTcOgkcd2U77uU1Q5Ct24aS9d81o9PfxmmF3MNIut9tr03oUCtfgA5Wb/KfYCWyTDLGaijnbZqvkjPOR9e6yF5Dta5qsYJZFJItWMO4pH+ApuK0yhNCtOveQx2dEAsD+hEWMCzBHjQhAUWNCeILHGLCUoXTGYFREXIyRVNByF5CRBuSB7DgschpiBsVqW2lDu8OjkrsJlI1OwfjFS31FGT7Fr+sH9KUhmWkgSexq7O4Vrf3Iyik76h1Y1IGZAms8Y0aIyq/uvJIULmWFhy4mTVYWML1p+t8cklm1xWFBTRvxrTAps3H92ZHsq8Rctf7MkZyua9YQhdnP8cvvcfrNU76uIiKo5GjkbZm+SeWY5fz1d3LJ7+8/cOqm1FPc+kjdS70vnpXufWzxsmUVUVii5rMeI8/ZltX/T2cUUAVuWmyxaeVJGCkKY64qpYAZwgbLPFSEDAXKSZR6KSASPLrhs4kiVEgmPgq5EmIAcLQTNmR4KvH1iEqNyWIFiYYJlRk6b0JKd7KJuJYCWju//qyTKKQ+4AEc2TA6ekzUI1tGBlhg28RdaMHR7DNonOyX5j0mbmjdKr1TyHg+U0nMqcJWxl0U6jrt8Vrw6JZUJMXBmmy73TU7u0z1Vhz8uXzZn/30yNUzY0qxszn5e6XHaWSw3iBq5mNl7d4SXs983f5aqpMQU1FMy45OS41qqqqqqqqqqqqqgEprcjSUk8OPpwUg54MfTShRMzlZ3KSoHdN6MwxRYzOU64aBIZfdbLIlQKT/Ix5Rqlywprj07XlKs+1C2/ZiC7jZvQbZZQbOSDZSU6fnQR/jsK72dtN/a4gWCBGaMjrcqEgowgajqHI1Cuh2DDSxlCQq51UyRKGp5L2rwOh1ayAg8eHSGrABeWr6kU6TkkHnjMemVQ1BIT4OQshBEfZhFJ4TxKY1QbUmjLBQLgkPDY6SoUIoOKsrzeJ0Ore3vYZye8N1HVUAiBsGYCTAijOptkCBGJcSO0JTAAQAG1gjYGAZfTYjLYiEGGJGLY2dHFOjCwBGiMZKaODNkERiFEQZYgMM0DpsIJEKkEg8BGGGYOCMkze/ZZfjwEVqckTUkjQ4We0h/P9vlafRI1rsiVIhaC88kjBAqnp7ScqQpCUoPCYGgvBDBknBRM7aBuu4naRBSkRs3FGYJQwzqaKwMxkaIQyqTYCgUxih0wepRg8IsmH+EeGlcOQlHeDglDwXRT4UMpRZRzUQxTI7Gwix3IhZZOgn5lBIxCicl4yFm/1TEK+wf+1pq/P6KES0tgGFTDRcHgtAz41WHCSl6Ow6jJQ9rZHoHjZW6J7gNomVhAmG+PJrMIHHLNBjCybm4CUrSjNHU5aRLi00A2Mgo94//qwTMWL9YDEK2NBUewbcpGsp+YxI24ReaMDR6RtwlQyXwjEmsCNSOyUzsswgtHCGjqPcy9hDNT0zVGwYHCoPcOdj59rt7XGflae6GF+pfYnTrXaW3A02dIm5N/GIYGn6szL8Il9JIxXgwJzZf/vG44JrkxBTUUzLjk5LjWqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqgKttJJxxK37HfFUdEjflsGq5FDi5IuTQt2Q4mc2NgSwMssHsiSfrzc4L+vFp/kStxh5fRKyF7Yg9Ijdai3YHrsKFbGKTJ4CcvHoUVfEiB5elVIOzRbDI6Ao9isqKjyVDzoWLBYkj3kwwIBE7gnVopgjQZObP+n8JjMyj8lI9RDWaBqvQv3eY9epIUUpuuLahAYEbiu6l2JI/mpesz/UyC3M5RU/KPFibYdp4OHjCeHgCZGJ4FppZSRMLTrkYQ0zT38cgd/MtsEvdKXT+l2QrckJKznvTr5PP4ViOR9SsiHlTz9CMv3QXBuxTcgUS1Y4y0+fzc0B7AlpEpKIxUKpyhF2Jcg3t4Z8EATjLAhMdEWwuq5iQFtkjyzM6XfOEBtLu3nYkF0oIh5K12zXXanb4N4tkxdnFNSJp5O3wwQJyuMGHJCxBjRj0VJSJGW3M6EdQ03aeizUKHVns8t9TNIsRxrt5hC73Me7KNm0/PhBoYpQ10uY29z097USaGhVzs5y4GEChiiSFNhnLt4qkoVFRx9rUtd7qE6TdcJRLbT/6G3sSseAXQHOidx/BE3Fpf7apIfC4b1spjzRU2oAh0LqEBAyhA0+1BSCY1ENrTkXxTXc6GSJ0DrJ1ZTLM6z/+rJMSDftiAQraMA5hh6AcKzIWjzDbxRFovjnmRtCQTPgsPSZvYEE30sJSZC2ReXxaUoWszu+Z9tpabo6ezQbRU6ZiN4gVmJX3/Y5de96fR1+IVbo7hzacgWZPzscdLO1QZZUHYz99iSKu553pIva3vCFFQS0o25Ja0ipTNc42LavbzScwCGRs8Zky1yvImvePYCiFiOKpml6pzwZJE+aJEQ8uebYWXRHlz3g5v7MhBCAziEEt9r+877Ayvrek2n5Dt5Ci7OBP9jlL2/57XXN86eVz3kNO6b8Jcjb7lJ9m2taTBabAK1M3zPWVjmOwYBoKhXTODLrMa22ovBkIZDYbsTus0GJMvNzNWWV0tRn/d7VjxdTvWGFqDCmEbGZNuRFp3MnVjXMsQhvw0NGbW49RPo4ZzUR1sbYlvq6IJ4LIzlhOD8hZuuITDQQoKGOLYYUwcLKg5tg04KghGIo48gaLY04C1RwBCL0wwf3sczVFrkVqc+HKs9bvMZCTOO1554suVCJMWPrEwerQMCSR/ZwyEoknkYnrFRjEqQg7KxbE5mywIwSbVLHEu2MlKEXxoYNk/HRPURlzhxp2Pomg5MxFXLSEvdMajYV0KfomaxllFKIFFcgRMMLRkiSRoYKPWgu8PRA4ctJCKLfTZ1HTe5J6dFNNbSUSts1VWlnRayKE35xOK0yhZzuhFm/tqe6Xq9R19p+0vjQdy3WweEJK6QBiLVutlDdehfhYVnL84yyIg5aa8Qfi3BUNVLMMrVBGPHbHBTEwKBiUyOXhYmLQyKxJhIcPLi0SC4aEUrkM7P2z04cSx8lNIzOFOXXlhs/bTj3+43/+rJMohb/gKOIZUPp6Rt6jcz35jzD1BW5wPQsMM3KzzMe2YYaOaG8ssP2n3lFTlurIMxIzU0CR0HAhqwpiZMIJiEFSijktTFAna5MnS10mBi07A7tkWCBxJibot0Fxk3b/UVMgwWsQjUVrsRTtmIC1iggJXQZAkSERNjFpTxI9bXrplL36OVVTEFNRTMuOTkuNVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVUQEhlJuRlpOXN1oSXI/qgBUfPftT9wVVZRx6JSaqwtEuSgoGJKSlzq1HmxauqkuuO+g7wXI2mxP+TS8GicZ/x4+b/l818Xp3TYu5jtm/ktbHTZo3oLZp+v/yW7WrtyoLaoUm5OJMpzYpS5EGl2b6olLE1ylauUqze7Jq4Ipxu5PlaFmkwq8KsyQmUKFYUoezRtVzYNqWXs2pKUYzmVEygOe0Fa+vF2bVfY+qqlw9nVG6v7GU56qwEx8jMKNas9jtZjxImH2Go07CM1El8Z40Vkwwz/7bZRak7xtfTSOL+M5xIA9xa2Rga2M7RS3kZ1fZlWJaZDaCc+JBZOiEVQUQFDxdI4dhEo65RkwjQCTYrMzDYURi5KfiIDDD24pMfbkgawgLpUy8bQnE5vTWTSf7UTl8pReb0GI0oPYRitSaZpwrQaVHlZI4ZJVaNQtGKGOp3CvdpMgTQThAuzyNaM9QCg+qiJFMUpgk1U+5KKi/QJO1d67eI5tsbCHR+v9u1kFJqKOSOuSnWxcFiCZAQE5AFxIjQPhBZpibL3Dx88JmVhPUSlA46zTZONNO0UWgJMQNQqtPUWTUeQSIJhj9U+bW//+rJMx0LfgAMCG8NoKTBacGw4SiUjX1WNoP9HsTDiPjPgtGSY9ZT01UGErsU7Afsqss5zDTDyiZZhNj48Y7KZVOm/ty65WQd0MRSdI0skBsJEcCdjmdE/rbF1apj1GHXpeaVK8JKojUkYmruZjlxpVwXwFUQam/2m7U3q7IlpYusytxFHD1mIaH6n5fo1C/MJTBgZHSJQPJqoVtVliz9JWJXYDlQ+mL7TxJ5TZOu1F2bJ9X4o56tExZVfuVsdny9lyRpnRS2sp9pRXeqnDF1UFomJw+OjEx2toQttdA/plO3fMljrjeRr614oG2NbMqa1n8scV3+tTG6LTVsryrSC7Co5BUUU41aCo6hjMlJWgmyCo5BWOqqyClRgJjUKrVQq7ATWMBHVVaoUSUYU0Zj1VSVVWMzOwZjVVWBRK7Mx1mahQEThgokoBAR0BDCtQokmDCVjATGoVjUKJWMBLsGY1VWoUBE4YCFcAgI6FAVwokTwUBHBQY9QoniqBNNxuWRtuWbmd6oYEy1RGSYI1M9rG7OSxCOS9/2LiooqTx2iqI/POLy0tDpCiRFC1YmRInFiqKh+ctTiEkdnSkm+FErOpyi4erovI1TOliTNxrSce6JQo+GWxKnmeuamr7PRx7F5MsYeRO3kdMMWxGsSl87MkRrmmgVtpsFkWzNI59L1EquRnfjIq+nF4AAQKomomxIRgCHjoIUI6I8X4sYoBnEFGkO80C1GMOEuxKx6DHJyPonqlPArzFN4zzsZ0qcIGhkKAmLBYBSKR8cNKlE/J7snTmlTihsyTKnF3GiZCcIyQ0QkRVcwLkpYbUeZJUS5IbZIior/+rJM45L/gAQ5ZcFJ7DN4f0z3qQxjb1HpnwmksMurFrVcSPSa4YDhiQGIuUl5Fwz7DealrUkSNMTUSBRR6YYcCgQtAcEhJxMIWRBjTEA6JwszSKSToJ4079h9+XjFFtqKRph60SRpRNSREiYTQSInFoKSko+EoUGNwdrZyH0XWKkVlQAAZVQC5IsXKWfEgfITYoRio8Rw7KJZplVaWolkaTh44VXN5hySRE8zSCRKCymTWS3TEyWH/WZZ2EzEoXVNdKMtKNr/xtNdRdDjL2K3y06Zu5nmzvcet9QeVCZSMX43cdpymvM1m2H6Ftn76otlEzzkT0C6RPvov5NmJzXkjLX0sNUZBUC424EpqWQSjZ1LQHJzoJBBEfaNEysVScsmf0StnrPdUHYhTyddPNp57j5DZBkWeTsmm9ra3ZpgrEz/p9085led3DMKstqnFtsw04334UhhUfYwwhkEIrH3UDLf4zKgpUP0y/p71BWIFfG9ebTe0z0EDIQfh1rMPwM09CWRGk3HY43ZVJob0VqW5RqQZKecAiNfYLSCQUyhIqctrIgysJxYsXsvmHoklIjl70L1VPh5XnpDLnbiCeM+e+z14xiynzbMh2fseZe/Li2fuyamvGupkkj6shEByJ0FnRFIpUikW1x05ON6SXh66Cyz8pG2z+U4VjI5+IzMJ6dsCTV5nvxW6Gdls1QS8DUYdKL0aiAUamy/8FhcGOHNFeR244F0ZKleF5M0fbgrVlTvkQ3HQu83EWGMk3xwnimDTVL2DASTx4+YpHivHOir8q9Qr51JMttY0weK3FC5ccU5aXOU+kk8PmeiGbJutuevoTD/+rJMVY/4AAQ6Zb9JKTH4eCuH0w0mBFAVbwmjJNYrKTRfZYexvM8wtXwMJEJ05Mj2pwrfL2wlZ18tVpRXYv64kaODpfCWk7UaGVDyxzCUmz+7RYdHt6E/ffOXLVZfMG1K8xOB5vCtYWvrB3ddgeiVLTmNDYq7iREhF6XSiSe0ilVMQU1FMy45OS41VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVKShLSQyquBMJDxRZkK60cXBtlnMXzE3QidqdrC3cy7Q61UNslBdFFzcQnmW1ROmPZni9QulOlZUnlYe0Q60HXErPpA+iB9IFIplKJlYTLWYWsyUzKQPpA+kLRTKmysPK0x00HXEqLqC6g/pxibIpsiYbphdmOmnqF0os6CpPMwnGJuuJXBumBBANvSXuWm5Bh1+wXcn4++os6xb1VmuT8PTGcfd5f7x1J24Kg+jHU2uYJ2C5ISERMBRQNDRKAguJEo6RMJKJvepUaELkW+4InKRcQzSQKQh4dhBGV7yttppyOTq2UeQxn9mUmNWOqTA6SkIIJgmZNJie6drZo6h1aIRG7KF2gdI+wqlSf8ugyMwcU6e/eRVNh5X11m5OgR8EJ9qUgCKqpbDmEAECKBixCAwN3MIIcOaCAgArkhUeHH67F9pOLeIIQ4SIhYGBluBnCRI7xCTDlTfCFTCJXO52hxYtAAIMYhMpk79r6JdN3miaXmiUOIEOBu2UjhzghOoTuUQYwCFnk76uB6IIIzVjAxkPIeIMeq9tpIpRFj5RXBlpJROzAFZuXANM750oJtvwIgNIsmrJwMknDJCrSwi3Bi//+rJMyrjggARBZ73gYjAKm41noWEjrE4VevjBiHQp57Og6JMO3B+wMf2liSbebyTtN0q3cpRnaoZoGpORK1cisVTV8TW/N55sj9OQWJJb0lClGuDTMKpAzO60lrLV6TQBQclVnGIKJKoaakRqsPY9jlE3Kh2RVSabSkOkSYmzeKSXMAckINY9SChHTcPNGCHHUn1WgAUyjbobaGpMBDFGdKlKAesUIYStOlvMUNUYJ6HeoGsRUdBjk8FKYDzHC/LkrTmSLxEoScpnHCiThUwhRXn0S4nqvOk9BMkyrE+ISZAmqsdzEqNsQk8YMpui4nsq3CO8cjBJqdRvCHR34mqpQ4np+KdWK9ZMEnAxY5kp5FE2FtXCZTJ0k5HcY6cPJDT9U59EKgn8/P0TVENAWkIK4jCLVWJdKnKnVgbxCjiJ6XE0W8gp4luOpXTjBFJOV02q1wOokJ4HUnTpIKUAV0JCmEnpeicm8p2xrwK6WxApk4Y6QKZCXZknL1m1jmXBS4izRT6lSQ1icQKmUCSyli7Tuz1vcIInY+lrpCIIEAiITt+naEe7u7Pu7CIqTtaRCQIIKOZ1zyyMXd38QAPUCGHjpKDBS22IuxKSnCKQZ1cW5Yvek4G7iw4gkCISJzKIiBEFu7udPz6713CDDCBkMgzftkfx3b9nbMf9owpC0wABYQNOPFQh5dwAeQ5CCVpvgzAJSHVzgqEXNeev0PUiLIQM4Wj0+IgN/MzwmJ0JlpYYMkQ6gvlAA/TEDyewhnQcmDp/7zCBBAgaPQ0meTMLrG9lIMWmeHCGsrDC15b22NESm8Fp3SHjT045hYWTGe7YhBk4nlz/+rJMHsH/gAicbztR7x56dY0X2hhmzRX95O5HsNKC5jRfqPYmzBMw1JcRKeXpi0CbXyYhEIYAISTZDD15ccyWXFsWssLaD0sKCL9oH6zZuEy6yppVmJ/23e+Qmp3GITjhCVptlFKKFmbbP12fx9MC9t+IogW7e24ujC6hODUrFkx8PWdYKkvcWKjJxzG6Yv4+JcRAL9jI3YEcyMkx4Qk7AiDOnKVRELEZBgzSDkRiLbekyqoqxo9RMROkh0iJb1dRbqn1CNSSFtGjcRmlBdNlelBTMVpJLJlGmMyKAiJLkWKYdXZWEkSRU2fYYZXPjpcVz01kz7GujCVtzW1R6EnUV0bP3i7YXWRlEBdnHigkLqIGWCD/P4ZutRVMQU1FMy45OS41VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVUpAgpuORtqS3JbOleFTkUTn6gIULYWKYjIdxsPES4AH/m0NFHmxSxbSs6k8m1iUIax+iNJvcDUtVeJRjxU81BaoVbGg0mhoBaccBtaIUCcCTUbldccbt6u8FhJRZOeCkAqWtjGZnpZaAqjCWR88KQIECivUNhmNCMKSUoIVIJUJ/52cApNEbiE5OhDjNjCEzM95UjCzp2M/O54YyEzjFDzP/8rnWfO0vkhTZUIYy3TdAA9okgqVq2XPXYsNsFG2G2ET4sKeLCml2a2iyiyzf/3ONNGioUKLCmt/9yhTS//7mllFHX//JNtsN//nGnfeUUMGzW//80o2x+5TTiRQ7//uWOQCRbUlckUTcn/Ltmq2KWEZ+V1qAq5mLD/+rJMbTONAAJ1FMToIxh4Yyw4jRgjy0ocAQeghGupkiBh9JMOVZifSI1JUJR2oVBSUnX1pWhmgERDcOQDylQr6nll6cWA8ljXbTKyThl59iFD7ytuhMKROpF0/n2fl7l2nI5d+PtUzTZbvXRN9+Y+Y/3zKigaQQknK3XqszIcmcQDGGEFF4MgxB7vTEHIRz0zEIcgo8nsR3ISm2XE7bEC0/ZSBiEYemYhkEMPJ6Yh4QknsREkMvv4lOzMJ0q2QjtBZPTEGMjD04htIKPvsQwhnc+iGaYEGhexEPGPrPZSsswYLTZzEzEHs/SCEREk1xGQgjHgGBE/yJEcpxyWySSNzXqDMoMrbWYseuDKFw6+GyU4uZXTgPC/Y/frnTjBYYzgIVkWY77SArwqKHcdQ93ZBsqghbIe5xj09wa/ATFNd6vbVSERkzdPKVzIjha0yWmVTfW5DGpIk/Mx3tGESuo2etg5ktUTkY5I0GGIAEpNSG34aZYlai0a1JjLH7YMth2qWJotBd09oRG8DulemGUVITjQBDoRaupIULpAa4wFRJlYuwYKPCgEgSGaSsKkS+6ElXMEInNXXbJnhdcs6rYhUlSsAmcX9UMVaWeTLEgo9MzYIWaLAS6S0YEaqW9EZAhy+UxUvmhlqUBrZC4SSSeqKLlPuCBqIAkCnMghYMGtcwBXI1dppe5TctCgQW4j8hNU0L5JaroR+WBc6KuUz1XL1LDLqYymNA11SlWFG5PqGbqaSogoFVqxraqynIICzdQWkZC0wtky9TWkZkw8siuRBafuQC4tWUv7BEHrtU6ViVteNriAIYCJFLrMvZAhUDVCzgL/+rJMOAf/gAQoX75owjKKcyz4bRkjeWv56tRs4TnBzzRgdDEORA1mNLUiBVEygAdf0cdsAFUgAQJ9TKaKDzhoSU6WwIBm/a6+qmS+y1qjzHmWpVLnQGo2roDQKkgmEIgBoBhclWGRKAw8hWFTYIiVIEh4QioVFwAkgJNIgVNZUQwIinJI5JsMGAmYMxtAwExhhVwomMzAQroaidugJM3DYUzAQEzHGZmZmZRJQCAgJq2uoUmb9hR/s2zMbCtvZmAgJeMx1VbUvZjZgICAj/Y9gJmZvUmbjRj+qv+wYCY6GAgIU3GZV2FMzH67alQwo+axoBVMQU1FMy45OS41VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVAQIAABWl4DAwMDA3NEAwMDAwNzgABgYGBgbno4GBgYG56OHAwMW58dw4t3P3d3dz93dwN393d3c/OHAwMWc/Of/xERETiBAAAABCFAiIiJ/EREQviIiIXoiACIhaIiIiFxERET0CAAAACAQggCBz8Tg+D4e5WInSggooSOLEOl/8jJ0sInSysJHFiHSxTIr/KxE6PKwkcWIdLFMkef2ERpZWEjixDpYpkjy//mTyso44h0sVhhDpZn//LFHHEOlisMIFpZmR//Ypjo6WKKGEC0spkZp/YpmjpYrDCBaWViN0v8pmTpYo4hOgQyUSEk9ZPDqqoCAqzaqoCAgLNqqhQEBZuqqqrN1VAQEBZvVVVWb6qqrN9VVVm/VVUQnhCEIv//+zMql7MzKpfGZlVfjMyqvxmZVUvZmVVL2ZlVf9mCiQVg0DIKu/FgaesFQaVFVop5v/+rJMlOSpAAOiWTxQYh+AdI9FkAADAAyJWvehhH4BSQAhKBCNLVFGSxFphHhHwknEDyBhZniTPDOUycx+wMZpPTJ/JH6LO8sj4kn5HEunIvuj/qf+jC1IxYspoMn4kv+zPnI/Uj/qe3ZH/Zb69Pv61+TkFUxBTUUzLjk5LjVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVQAgqRzTCgosiUkaoGwkmRgkWicics1RLSJiLEi0TqnJwlaLJOiWidpuU88BQUpbW5q2vlYds4dZErGotE7Zw2EnRZJ0TUTlkYJOi5Epc5Wmui1ai29tn9rROyqNUSeZNhJ5ZI3JytIwk6LonbOVpE8bSRaJ1zRqiT5/9dnjZqTSlz2SNh38qhAASLjloKZCLyaa60J5raDlrvQcdRaDagUZb9U6Q6KZZwug2Np8rct2y95dOQxCHIYfhuag8LwuMATEdlQeBlbFNJaaCRELH+YAmCw2FsBThq0HEY9yF8FwH+ny5qMetHCEF4XAh51i3knbILt5mWOwRGxQQS/lzNAggtgagQxUnXHYycCSA5CSQC2HQoEWDkJJIWwnBBEoSs+zTbjkFsMQlaDOQ6GlOMIk4h6XYIqvdE/BzixqMlYm5C1oL8TNRivgqwj4N9Dmg0D3Ms3xD0u2mm7/+rJMaEetDwAAAGkAAAAIh0z3Vxhm0AAAAaQAAAAkgztbXYebOFGZGNqVEhfEZ9vKH4JIGoIQoDkHGtogQgTBDBXAkAuBJzcPA/0UIQJoIYoTgH2XtgOQhBnj/XBc3cIFhe+yBDD09smFhCHjDyZNNiCEH0xBTUUzLjk5LjVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVQARo0BDMNHRUpEQqFAVLc5RyBIMYOCmYBQKZAg9MvkS9IQVo4GIEAgEKEDB90ObiDQwyQIDMCxbB4YSUqJmBJmPMoVnyZdZSSK68GVLkF2xQu034hCm6sxqBaxBous/QcguOuZWFeReIFHAjlVAYZDkw8UYVAp/LDr3LbJPJCoImTTboqxKpJ8qu7AKLJZ9A9IRXD+JQp7vurA7z5K7VVHRomJeBzGvMCVImCuwvfRNmTBbASBXUl+oPDyUCsKmTDnQZWX7YaraiNAS20UHnZKu1IsiFG2npeOC1AvwtJdjdYAV+osHQWEcklC1RG8cQVBJ8RAiCDAFzXXViclkCbiJyBjDU2Xll7bKQWBDANDzWc5zGCYjW2uKoJbLAI/F+G7qbOWlwtImM7jaIZMTUMasPEVXexD6CVxu+hquZW5V0sa2sdhsnhqGIZjrjrgh2bly8Ux45FYBjLbtq9MsmXoqQpkjeRRwYWw/u5eI6rbUy0dbLtUIKktGjo3Jp1b+e09Xa00+eko5UviTmRursosA4Rw2DVEnKWCjWamotGX/+rJMn//PjwAAAGkAAAAJbC9Wsm9YZgAAAaQAAAAiAi9gJMMO/apOSOeNo1zrw2OdZajgEWhaMyVvNVVP2JbLVufnXlNR2eNmWW2bJqtbZq0Zx5rs6AVsozn2YqWJHpP/s/uy/rq2sYUuFVLBhPTZBWKIUkxBTUUzLjk5LjWqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqrgApAnrLri6iHJnEHggWFlIZZMve/jD7u9MUffbTMv5bZnMkm0Y8ST0ydy5pA/XohJCT7ZCb/whQNw4GYAKHOgiIX1wQhEQGLBCPSi4ThAY4tKfxMAr+hPJuaJQMwMWEEKHNC08nNCYAUDNBFPzkSTlp/wmPqA5CKBBVVdOlJJoLd4ynyZUDA2gQ1TBQ4gMUPWbAMdYIHJRyX667cHXlqYqN0w/K5mJDBUIE+nSlccQHImxRpSj6wikmsuZ+FOBlHsOpWtqEqVQ2aj7LCaS5aCckiKtDHJjJ4P8ZqoJifkMgxyrsvBNzrQhPr0hNgcqSUxkuAMIYY6Xp/GkTMmzgu0qoiel0GMSFpSBfwrSRCxDlVilenaTgaw/U8jhbRXiRLuCfhplsOtOF1PlQpwxy8FeP1dI4hQ+UQonKKXU8BvI0fR5KUtqUIMzq2yuP3/+rJM2XumjwAAAGkAAAAId+s3uhhD8EAAAaQAAAAkijyc2YebPT+O1YL8haoGkLGHKlRbpDLEBPJRpSGSoV0cx6xTsLYWM1GlPFtH0Zp4khJwXs1CXHqbRYi2pFCedszgpABFzMgx6HhaLxpwlbo6YHR8lUxBTUUzLjk5LjVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVGSRpT5OTULFxQbFhMShYZOhQVoDZlEQlg8RoEZIfJRUITqi6iMwaQlki5QugRnmlU4JqIzxpCRHG3NIVlVip0kFxLJVZUscRsNMolSxUpnCtE8tXJUyEvcjdtVpKhrI3bb1q1yGC7ioxOkydhtYrPTIqpUiGkXrEZ61BrTLC+J6rOMpk6x+K0zm99VzKGsVqT49MhxFRwjP/+rJsyNJMD/WuZbZRLE+6L+AHegQiAQAAAaQAAAAgAAA0gAAABAfMoiERAqHyAnPGiUiEI0HiMkbc0hIip1A27QYlDFBQlT1KSwJB40sUah4q2aAopmh6ha/1t6kPrbrFP8U/gIXZMhIVFZn//6hfizNQukxBTUUzLjk5LjWqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqr/+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":"sQAAG,IAACA,EAAEC,EAAEC,EAAIC,EAAEC,EAAEC,EAAEC,EAAEC,EAAEC,EAAEC,EAAEC,EAAIC,EAAE,CAAA,EAAGC,EAAE,GAAGC,EAAE,oEAAoEC,EAAEC,MAAMC,QAAQ,SAASC,EAAEjB,EAAEC,GAAG,IAAA,IAAQC,KAAKD,EAAED,EAAEE,GAAGD,EAAEC,GAAG,OAAOF,CAAC,CAAC,SAASkB,EAAElB,GAAGA,GAAGA,EAAEmB,YAAYnB,EAAEmB,WAAWC,YAAYpB,EAAE,CAAsS,SAASqB,EAAErB,EAAEsB,EAAEnB,EAAEC,EAAEC,GAAG,IAAIC,EAAE,CAACiB,KAAKvB,EAAEwB,MAAMF,EAAEG,IAAItB,EAAEuB,IAAItB,EAAEuB,IAAI,KAAKC,GAAG,KAAKC,IAAI,EAAEC,IAAI,KAAKC,IAAI,KAAKC,mBAAmBC,IAAI,MAAM5B,IAAIH,EAAEG,EAAE6B,KAAI,EAAGC,IAAI,GAAG,OAAO,MAAM9B,GAAG,MAAMJ,EAAEmC,OAAOnC,EAAEmC,MAAM9B,GAAGA,CAAC,CAAmC,SAAS+B,EAAErC,GAAG,OAAOA,EAAEsC,QAAQ,CAAC,SAASC,EAAEvC,EAAEC,GAAGuC,KAAKhB,MAAMxB,EAAEwC,KAAKC,QAAQxC,CAAC,CAAC,SAASyC,EAAE1C,EAAEC,GAAG,GAAG,MAAMA,EAAE,OAAOD,EAAE4B,GAAGc,EAAE1C,EAAE4B,GAAG5B,EAAEkC,IAAI,GAAG,KAAK,IAAA,IAAQhC,EAAED,EAAED,EAAE2B,IAAIgB,OAAO1C,IAAI,GAAG,OAAOC,EAAEF,EAAE2B,IAAI1B,KAAK,MAAMC,EAAE4B,WAAW5B,EAAE4B,IAAI,MAAM,mBAAmB9B,EAAEuB,KAAKmB,EAAE1C,GAAG,IAAI,CAAC,SAAS4C,EAAE5C,GAAG,IAAIC,EAAEC,EAAE,GAAG,OAAOF,EAAEA,EAAE4B,KAAK,MAAM5B,EAAE+B,IAAI,CAAC,IAAI/B,EAAE8B,IAAI9B,EAAE+B,IAAIc,KAAK,KAAK5C,EAAE,EAAEA,EAAED,EAAE2B,IAAIgB,OAAO1C,IAAI,GAAG,OAAOC,EAAEF,EAAE2B,IAAI1B,KAAK,MAAMC,EAAE4B,IAAI,CAAC9B,EAAE8B,IAAI9B,EAAE+B,IAAIc,KAAK3C,EAAE4B,IAAI,KAAK,CAAC,OAAOc,EAAE5C,EAAE,CAAC,CAAC,SAAS8C,EAAE9C,KAAKA,EAAE+C,MAAM/C,EAAE+C,KAAI,IAAK5C,EAAE6C,KAAKhD,KAAKiD,EAAEC,OAAO9C,GAAGH,EAAEkD,sBAAsB/C,EAAEH,EAAEkD,oBAAoB9C,GAAG4C,EAAE,CAAC,SAASA,IAAI,IAAA,IAAQjD,EAAEE,EAAEoB,EAAElB,EAAEC,EAAEE,EAAEC,EAAEC,EAAE,EAAEN,EAAEwC,QAAQxC,EAAEwC,OAAOlC,GAAGN,EAAEiD,KAAK9C,GAAGN,EAAEG,EAAEkD,QAAQ5C,EAAEN,EAAEwC,OAAO3C,EAAE+C,MAAMzB,SAASlB,OAAE,EAAOC,GAAGD,GAAGF,EAAEF,GAAGiC,KAAKH,IAAIvB,EAAE,GAAGC,EAAE,GAAGN,EAAEoD,OAAOhC,EAAEL,EAAE,GAAGb,IAAI6B,IAAI7B,EAAE6B,IAAI,EAAEhC,EAAEmC,OAAOnC,EAAEmC,MAAMd,GAAGiC,EAAErD,EAAEoD,IAAIhC,EAAElB,EAAEF,EAAEsD,IAAItD,EAAEoD,IAAIG,aAAa,GAAGrD,EAAE+B,IAAI,CAAC9B,GAAG,KAAKE,EAAE,MAAMF,EAAEqC,EAAEtC,GAAGC,KAAK,GAAGD,EAAE+B,KAAK3B,GAAGc,EAAEW,IAAI7B,EAAE6B,IAAIX,EAAEM,GAAGD,IAAIL,EAAEY,KAAKZ,EAAEoC,EAAEnD,EAAEe,EAAEd,GAAGJ,EAAE0B,IAAI1B,EAAEwB,GAAG,KAAKN,EAAEQ,KAAKzB,GAAGuC,EAAEtB,KAAK2B,EAAEC,IAAI,CAAC,CAAC,SAASS,EAAE3D,EAAEC,EAAEC,EAAEoB,EAAEnB,EAAEC,EAAEC,EAAEC,EAAEC,EAAEC,EAAEC,GAAG,IAAIC,EAAEkD,EAAE/C,EAAEC,EAAEG,EAAEC,EAAE2C,EAAExC,EAAEC,GAAGA,EAAEK,KAAKf,EAAEkD,EAAE7D,EAAE0C,OAAO,IAAIpC,EAAyV,SAAWP,EAAEC,EAAEC,EAAEoB,EAAEnB,GAAG,IAAIC,EAAEC,EAAEC,EAAEC,EAAEC,EAAEC,EAAEP,EAAEyC,OAAOjC,EAAED,EAAEmD,EAAE,EAAE,IAAI5D,EAAE2B,IAAI,IAAIZ,MAAMZ,GAAGC,EAAE,EAAEA,EAAED,EAAEC,IAAI,OAAOC,EAAEJ,EAAEG,KAAK,kBAAkBC,GAAG,mBAAmBA,GAAG,iBAAiBA,GAAG,iBAAiBA,GAAG,iBAAiBA,GAAGA,EAAE2B,aAAa+B,OAAO1D,EAAEL,EAAE2B,IAAIvB,GAAGiB,EAAE,KAAKhB,EAAE,KAAK,KAAK,MAAMS,EAAET,GAAGA,EAAEL,EAAE2B,IAAIvB,GAAGiB,EAAEgB,EAAE,CAACC,SAASjC,GAAG,KAAK,KAAK,WAAM,IAASA,EAAE2B,aAAa3B,EAAEwB,IAAI,EAAExB,EAAEL,EAAE2B,IAAIvB,GAAGiB,EAAEhB,EAAEkB,KAAKlB,EAAEmB,MAAMnB,EAAEoB,IAAIpB,EAAEqB,IAAIrB,EAAEqB,IAAI,KAAKrB,EAAE4B,KAAKjC,EAAE2B,IAAIvB,GAAGC,EAAEE,EAAEH,EAAEwD,EAAEvD,EAAEuB,GAAG5B,EAAEK,EAAEwB,IAAI7B,EAAE6B,IAAI,EAAEvB,EAAE,MAAK,IAAKE,EAAEH,EAAE6B,IAAI8B,EAAE3D,EAAEH,EAAEK,EAAEG,MAAMA,KAAKJ,EAAEJ,EAAEM,MAAMF,EAAE6B,KAAK,IAAI,MAAM7B,GAAG,MAAMA,EAAE2B,MAAK,GAAIzB,IAAIL,EAAEM,EAAEmD,IAAIzD,EAAEM,GAAGmD,KAAK,mBAAmBvD,EAAEkB,OAAOlB,EAAE8B,KAAK,IAAI3B,GAAGD,IAAIC,GAAGD,EAAE,EAAEqD,IAAIpD,GAAGD,EAAE,EAAEqD,KAAKpD,EAAED,EAAEqD,IAAIA,IAAIvD,EAAE8B,KAAK,KAAKnC,EAAE2B,IAAIvB,GAAG,KAAK,GAAGM,EAAE,IAAIN,EAAE,EAAEA,EAAEK,EAAEL,IAAI,OAAOE,EAAEJ,EAAEE,OAAS,EAAEE,EAAE6B,OAAO7B,EAAEwB,KAAKR,IAAIA,EAAEoB,EAAEpC,IAAI2D,EAAE3D,EAAEA,IAAI,OAAOgB,CAAC,CAAjkC4C,CAAEhE,EAAED,EAAEoB,EAAEd,EAAEuD,GAAGpD,EAAE,EAAEA,EAAEoD,EAAEpD,IAAI,OAAOG,EAAEX,EAAEyB,IAAIjB,MAAMkD,GAAE,GAAI/C,EAAEqB,IAAIvB,EAAEU,EAAER,EAAEqB,MAAMvB,EAAEE,EAAEqB,IAAIxB,EAAEQ,EAAEqC,EAAEvD,EAAEa,EAAE+C,EAAEzD,EAAEC,EAAEC,EAAEC,EAAEC,EAAEC,EAAEC,GAAGK,EAAED,EAAEiB,IAAIjB,EAAEa,KAAKkC,EAAElC,KAAKb,EAAEa,MAAMkC,EAAElC,KAAKyC,EAAEP,EAAElC,IAAI,KAAKb,GAAGJ,EAAEuC,KAAKnC,EAAEa,IAAIb,EAAEkB,KAAKjB,EAAED,IAAI,MAAMI,GAAG,MAAMH,IAAIG,EAAEH,IAAI+C,KAAK,EAAEhD,EAAEsB,OAAOyB,EAAEjC,MAAMd,EAAEc,IAAIpB,EAAE6D,EAAEvD,EAAEN,EAAEP,EAAE6D,GAAG,mBAAmBhD,EAAEU,WAAM,IAASL,EAAEX,EAAEW,EAAEJ,IAAIP,EAAEO,EAAEuD,aAAaxD,EAAEsB,MAAK,GAAI,OAAOjC,EAAE4B,IAAIb,EAAEV,CAAC,CAA4uB,SAAS6D,EAAEpE,EAAEC,EAAEC,EAAEoB,GAAG,IAAInB,EAAEC,EAAE,GAAG,mBAAmBJ,EAAEuB,KAAK,CAAC,IAAIpB,EAAEH,EAAE2B,IAAIvB,EAAE,EAAED,GAAGC,EAAED,EAAEwC,OAAOvC,IAAID,EAAEC,KAAKD,EAAEC,GAAGwB,GAAG5B,EAAEC,EAAEmE,EAAEjE,EAAEC,GAAGH,EAAEC,EAAEoB,IAAI,OAAOrB,CAAC,CAACD,EAAE8B,KAAK7B,IAAIqB,IAAIrB,GAAGD,EAAEuB,OAAOtB,EAAEkB,aAAalB,EAAEyC,EAAE1C,IAAIE,EAAEoE,aAAatE,EAAE8B,IAAI7B,GAAG,OAAOA,EAAED,EAAE8B,KAAK,GAAG7B,EAAEA,GAAGA,EAAEoE,kBAAkB,MAAMpE,GAAG,GAAGA,EAAEsE,UAAU,OAAOtE,CAAC,CAA6G,SAAS+D,EAAEhE,EAAEC,EAAEC,EAAEoB,GAAG,IAAInB,EAAEC,EAAEC,EAAEC,EAAEN,EAAEyB,IAAIlB,EAAEP,EAAEuB,KAAKf,EAAEP,EAAEC,GAAGO,EAAE,MAAMD,KAAO,EAAEA,EAAE2B,KAAK,GAAG,OAAO3B,GAAG,MAAMF,GAAGG,GAAGH,GAAGE,EAAEiB,KAAKlB,GAAGC,EAAEe,KAAK,OAAOrB,EAAE,GAAGoB,GAAGb,EAAE,EAAE,GAAG,IAAIN,EAAED,EAAE,EAAEE,EAAEF,EAAE,EAAEC,GAAG,GAAGC,EAAEH,EAAE0C,QAAQ,GAAG,OAAOnC,EAAEP,EAAEI,EAAEF,GAAG,EAAEA,IAAIC,SAAW,EAAEI,EAAE2B,MAAM7B,GAAGE,EAAEiB,KAAKlB,GAAGC,EAAEe,KAAK,OAAOlB,EAAE,QAAQ,CAAC,SAASmE,EAAExE,EAAEC,EAAEC,GAAG,KAAKD,EAAE,GAAGD,EAAEyE,YAAYxE,EAAE,MAAMC,EAAE,GAAGA,GAAGF,EAAEC,GAAG,MAAMC,EAAE,GAAG,iBAAiBA,GAAGW,EAAE6D,KAAKzE,GAAGC,EAAEA,EAAE,IAAI,CAAC,SAASyE,EAAE3E,EAAEC,EAAEC,EAAEoB,EAAEnB,GAAG,IAAIC,EAAEC,EAAEL,EAAE,GAAG,SAASC,EAAE,GAAG,iBAAiBC,EAAEF,EAAE4E,MAAMC,QAAQ3E,MAAM,CAAC,GAAG,iBAAiBoB,IAAItB,EAAE4E,MAAMC,QAAQvD,EAAE,IAAIA,EAAE,IAAIrB,KAAKqB,EAAEpB,GAAGD,KAAKC,GAAGsE,EAAExE,EAAE4E,MAAM3E,EAAE,IAAI,GAAGC,EAAE,IAAID,KAAKC,EAAEoB,GAAGpB,EAAED,IAAIqB,EAAErB,IAAIuE,EAAExE,EAAE4E,MAAM3E,EAAEC,EAAED,GAAG,MAAA,GAAS,KAAKA,EAAE,IAAI,KAAKA,EAAE,GAAGG,EAAEH,IAAIA,EAAEA,EAAE6E,QAAQvE,EAAE,OAAOF,EAAEJ,EAAE8E,cAAc9E,EAAEI,KAAKL,GAAG,cAAcC,GAAG,aAAaA,EAAEI,EAAE2E,MAAM,GAAG/E,EAAE+E,MAAM,GAAGhF,EAAEC,IAAID,EAAEC,EAAE,IAAID,EAAEC,EAAEA,EAAEG,GAAGF,EAAEA,EAAEoB,EAAEpB,EAAEA,EAAEoB,EAAEpB,GAAGA,EAAEA,EAAEM,EAAER,EAAEiF,iBAAiBhF,EAAEG,EAAEM,EAAED,EAAEL,IAAIJ,EAAEkF,oBAAoBjF,EAAEG,EAAEM,EAAED,EAAEL,OAAO,CAAC,GAAG,8BAA8BD,EAAEF,EAAEA,EAAE6E,QAAQ,cAAc,KAAKA,QAAQ,SAAS,UAAG,GAAU,SAAS7E,GAAG,UAAUA,GAAG,QAAQA,GAAG,QAAQA,GAAG,QAAQA,GAAG,YAAYA,GAAG,YAAYA,GAAG,WAAWA,GAAG,WAAWA,GAAG,QAAQA,GAAG,WAAWA,GAAGA,KAAKD,EAAE,IAAIA,EAAEC,GAAG,MAAMC,EAAE,GAAGA,EAAE,MAAMF,CAAC,OAAOA,GAAG,CAAC,mBAAmBE,IAAI,MAAMA,IAAG,IAAKA,GAAG,KAAKD,EAAE,GAAGD,EAAEmF,gBAAgBlF,GAAGD,EAAEoF,aAAanF,EAAE,WAAWA,GAAG,GAAGC,EAAE,GAAGA,GAAG,CAAC,CAAC,SAASmF,EAAErF,GAAG,OAAO,SAASE,GAAG,GAAGsC,KAAKvC,EAAE,CAAC,IAAIqB,EAAEkB,KAAKvC,EAAEC,EAAEqB,KAAKvB,GAAG,GAAG,MAAME,EAAEoB,EAAEpB,EAAEoB,EAAEd,SAAAA,GAAYN,EAAEoB,EAAEA,EAAEpB,EAAE,OAAO,OAAOoB,EAAErB,EAAEqF,MAAMrF,EAAEqF,MAAMpF,GAAGA,EAAE,CAAC,CAAC,CAAC,SAASqD,EAAEvD,EAAEE,EAAEoB,EAAEnB,EAAEC,EAAEC,EAAEC,EAAEC,EAAEC,EAAEC,GAAG,IAAIC,EAAEkD,EAAEjD,EAAEC,EAAEC,EAAEgD,EAAExC,EAAEyC,EAAEpB,EAAEE,EAAEE,EAAEG,EAAEiB,EAAEE,EAAEmB,EAAEvB,EAAEQ,EAAEG,EAAEzE,EAAEqB,KAAK,QAAG,IAASrB,EAAE8B,YAAY,OAAO,KAAK,IAAIV,EAAEa,MAAM3B,KAAK,GAAGc,EAAEa,KAAK9B,EAAE,CAACE,EAAEL,EAAE4B,IAAIR,EAAEQ,OAAOpB,EAAET,EAAE4B,MAAMnB,EAAER,GAAGF,EAAE,GAAG,mBAAmB2E,EAAE,IAAI,GAAGb,EAAE5D,EAAEsB,MAAMkB,EAAE,cAAciC,GAAGA,EAAEa,UAAUC,OAAO7C,GAAGlC,EAAEiE,EAAEe,cAAcvF,EAAEO,EAAEqB,KAAKe,EAAEpC,EAAEkC,EAAEA,EAAEpB,MAAMmE,MAAMjF,EAAEkB,GAAGzB,EAAEmB,EAAES,IAAIV,GAAGuC,EAAE1D,EAAE6B,IAAIT,EAAES,KAAKH,GAAGgC,EAAEgC,KAAKlD,EAAExC,EAAE6B,IAAI6B,EAAE,IAAIe,EAAEb,EAAEhB,IAAI5C,EAAE6B,IAAI6B,EAAE,IAAIrB,EAAEuB,EAAEhB,GAAGc,EAAE5B,YAAY2C,EAAEf,EAAE6B,OAAOI,GAAGjD,GAAGA,EAAEkD,IAAIlC,GAAGA,EAAEmC,QAAQnC,EAAEmC,MAAM,CAAA,GAAInC,EAAEJ,IAAIrD,EAAEQ,EAAEiD,EAAEb,KAAI,EAAGa,EAAEoC,IAAI,GAAGpC,EAAEqC,IAAI,IAAIvD,GAAG,MAAMkB,EAAEsC,MAAMtC,EAAEsC,IAAItC,EAAEmC,OAAOrD,GAAG,MAAMiC,EAAEwB,2BAA2BvC,EAAEsC,KAAKtC,EAAEmC,QAAQnC,EAAEsC,IAAIjF,EAAE,CAAA,EAAG2C,EAAEsC,MAAMjF,EAAE2C,EAAEsC,IAAIvB,EAAEwB,yBAAyBrC,EAAEF,EAAEsC,OAAOtF,EAAEgD,EAAEpC,MAAMX,EAAE+C,EAAEmC,MAAMnC,EAAE3B,IAAI/B,EAAES,EAAE+B,GAAG,MAAMiC,EAAEwB,0BAA0B,MAAMvC,EAAEwC,oBAAoBxC,EAAEwC,qBAAqB1D,GAAG,MAAMkB,EAAEyC,mBAAmBzC,EAAEoC,IAAIhD,KAAKY,EAAEyC,uBAAuB,CAAC,GAAG3D,GAAG,MAAMiC,EAAEwB,0BAA0BrC,IAAIlD,GAAG,MAAMgD,EAAE0C,2BAA2B1C,EAAE0C,0BAA0BxC,EAAEhB,GAAG5C,EAAE+B,KAAKX,EAAEW,MAAM2B,EAAE9B,KAAK,MAAM8B,EAAE2C,wBAAuB,IAAK3C,EAAE2C,sBAAsBzC,EAAEF,EAAEsC,IAAIpD,GAAG,CAAC,IAAI5C,EAAE+B,KAAKX,EAAEW,MAAM2B,EAAEpC,MAAMsC,EAAEF,EAAEmC,MAAMnC,EAAEsC,IAAItC,EAAEb,KAAI,GAAI7C,EAAE4B,IAAIR,EAAEQ,IAAI5B,EAAEyB,IAAIL,EAAEK,IAAIzB,EAAEyB,IAAI6E,KAAK,SAASxG,GAAGA,IAAIA,EAAE4B,GAAG1B,EAAE,GAAG+C,EAAE,EAAEA,EAAEW,EAAEqC,IAAItD,OAAOM,IAAIW,EAAEoC,IAAIhD,KAAKY,EAAEqC,IAAIhD,IAAIW,EAAEqC,IAAI,GAAGrC,EAAEoC,IAAIrD,QAAQrC,EAAE0C,KAAKY,GAAG,MAAM5D,CAAC,CAAC,MAAM4D,EAAE6C,qBAAqB7C,EAAE6C,oBAAoB3C,EAAEF,EAAEsC,IAAIpD,GAAGJ,GAAG,MAAMkB,EAAE8C,oBAAoB9C,EAAEoC,IAAIhD,KAAK,WAAWY,EAAE8C,mBAAmB9F,EAAEC,EAAEgD,EAAE,EAAE,CAAC,GAAGD,EAAEnB,QAAQK,EAAEc,EAAEpC,MAAMsC,EAAEF,EAAEN,IAAItD,EAAE4D,EAAE9B,KAAI,EAAGoC,EAAEjE,EAAEiD,IAAIkB,EAAE,EAAE1B,EAAE,CAAC,IAAIkB,EAAEmC,MAAMnC,EAAEsC,IAAItC,EAAEb,KAAI,EAAGmB,GAAGA,EAAEhE,GAAGQ,EAAEkD,EAAE6B,OAAO7B,EAAEpC,MAAMoC,EAAEmC,MAAMnC,EAAEnB,SAAS8C,EAAE,EAAEA,EAAE3B,EAAEqC,IAAItD,OAAO4C,IAAI3B,EAAEoC,IAAIhD,KAAKY,EAAEqC,IAAIV,IAAI3B,EAAEqC,IAAI,EAAE,MAAM,GAAGrC,EAAEb,KAAI,EAAGmB,GAAGA,EAAEhE,GAAGQ,EAAEkD,EAAE6B,OAAO7B,EAAEpC,MAAMoC,EAAEmC,MAAMnC,EAAEnB,SAASmB,EAAEmC,MAAMnC,EAAEsC,UAAUtC,EAAEb,OAAOqB,EAAE,IAAIR,EAAEmC,MAAMnC,EAAEsC,IAAI,MAAMtC,EAAE+C,kBAAkBxG,EAAEc,EAAEA,EAAE,CAAA,EAAGd,GAAGyD,EAAE+C,oBAAoBjE,IAAI/B,GAAG,MAAMiD,EAAEgD,0BAA0B/C,EAAED,EAAEgD,wBAAwBhG,EAAEC,IAAImD,EAAEtD,EAAE,MAAMA,GAAGA,EAAEa,OAAOc,GAAG,MAAM3B,EAAEe,MAAMuC,EAAE6C,EAAEnG,EAAEc,MAAMc,WAAW/B,EAAEoD,EAAE3D,EAAEc,EAAEkD,GAAGA,EAAE,CAACA,GAAG9D,EAAEoB,EAAEnB,EAAEC,EAAEC,EAAEC,EAAEC,EAAEC,EAAEC,GAAGmD,EAAEf,KAAK3C,EAAE4B,IAAI5B,EAAEiC,UAAUyB,EAAEoC,IAAIrD,QAAQrC,EAAE0C,KAAKY,GAAGvC,IAAIuC,EAAEgC,IAAIhC,EAAEhC,GAAG,KAAK,OAAO5B,GAAG,GAAGE,EAAE+B,IAAI,KAAKzB,GAAG,MAAMH,EAAE,GAAGL,EAAE8G,KAAK,CAAC,IAAI5G,EAAEiC,KAAK3B,EAAE,IAAI,IAAID,GAAG,GAAGA,EAAEgE,UAAUhE,EAAE8D,aAAa9D,EAAEA,EAAE8D,YAAYhE,EAAEA,EAAE0G,QAAQxG,IAAI,KAAKL,EAAE4B,IAAIvB,CAAC,KAAK,CAAC,IAAIiE,EAAEnE,EAAEsC,OAAO6B,KAAKtD,EAAEb,EAAEmE,IAAIwC,EAAE9G,EAAE,MAAMA,EAAE4B,IAAIR,EAAEQ,IAAI5B,EAAEyB,IAAIL,EAAEK,IAAI3B,EAAE8G,MAAME,EAAE9G,GAAGD,EAAE6B,IAAI9B,EAAEE,EAAEoB,EAAE,MAAM,MAAMjB,GAAGH,EAAE+B,KAAKX,EAAEW,KAAK/B,EAAEyB,IAAIL,EAAEK,IAAIzB,EAAE4B,IAAIR,EAAEQ,KAAKvB,EAAEL,EAAE4B,IAA0Z,SAAW5B,EAAEoB,EAAEnB,EAAEC,EAAEC,EAAEC,EAAEC,EAAEC,EAAEC,GAAG,IAAIC,EAAEkD,EAAEhD,EAAEC,EAAEI,EAAE4C,EAAExC,EAAEyC,EAAE3D,EAAEqB,OAAOb,EAAE0B,EAAEf,EAAEE,MAAMe,EAAEjB,EAAEC,KAAK,GAAG,OAAOgB,EAAElC,EAAE,6BAA6B,QAAQkC,EAAElC,EAAE,qCAAqCA,IAAIA,EAAE,gCAAgC,MAAMC,EAAE,IAAII,EAAE,EAAEA,EAAEJ,EAAEqC,OAAOjC,IAAI,IAAIO,EAAEX,EAAEI,KAAK,iBAAiBO,KAAKsB,IAAIA,EAAEtB,EAAEgG,WAAW1E,EAAE,GAAGtB,EAAEsD,UAAU,CAACrE,EAAEe,EAAEX,EAAEI,GAAG,KAAK,KAAK,CAAC,GAAG,MAAMR,EAAE,CAAC,GAAG,MAAMqC,EAAE,OAAO2E,SAASC,eAAe9E,GAAGnC,EAAEgH,SAASE,gBAAgB/G,EAAEkC,EAAEF,EAAEgF,IAAIhF,GAAG7B,IAAIP,EAAEqH,KAAKrH,EAAEqH,IAAIhG,EAAEhB,GAAGE,GAAE,GAAIF,EAAE,IAAI,CAAC,GAAG,MAAMiC,EAAEuB,IAAIzB,GAAG7B,GAAGN,EAAEqH,MAAMlF,IAAInC,EAAEqH,KAAKlF,OAAO,CAAC,GAAG/B,EAAEA,GAAGN,EAAEwH,KAAKtH,EAAEuH,aAAajH,GAAG,MAAMF,EAAE,IAAIwD,EAAE,GAAGpD,EAAE,EAAEA,EAAER,EAAEwH,WAAW/E,OAAOjC,IAAIoD,GAAG7C,EAAEf,EAAEwH,WAAWhH,IAAIiH,MAAM1G,EAAE0E,MAAM,IAAIjF,KAAKoD,EAAE,GAAG7C,EAAE6C,EAAEpD,GAAG,YAAYA,QAAE,GAAS,2BAA2BA,EAAEE,EAAEK,OAAA,KAAYP,KAAK2B,GAAG,CAAC,GAAG,SAAS3B,GAAG,iBAAiB2B,GAAG,WAAW3B,GAAG,mBAAmB2B,EAAE,SAASsC,EAAEzE,EAAEQ,EAAE,KAAKO,EAAEZ,EAAE,CAAC,IAAIK,KAAK2B,EAAEpB,EAAEoB,EAAE3B,GAAG,YAAYA,EAAEG,EAAEI,EAAE,2BAA2BP,EAAEkD,EAAE3C,EAAE,SAASP,EAAEmD,EAAE5C,EAAE,WAAWP,EAAEW,EAAEJ,EAAET,GAAG,mBAAmBS,GAAG6C,EAAEpD,KAAKO,GAAG0D,EAAEzE,EAAEQ,EAAEO,EAAE6C,EAAEpD,GAAGL,GAAG,GAAGuD,EAAEpD,GAAGI,IAAIgD,EAAEgE,QAAQhH,EAAEgH,QAAQhE,EAAEgE,QAAQ1H,EAAE2H,aAAa3H,EAAE2H,UAAUjE,EAAEgE,QAAQtG,EAAEK,IAAI,WAAWf,IAAIV,EAAE2H,UAAU,IAAIlE,EAAE,YAAYrC,EAAEC,KAAKrB,EAAE4H,QAAQ5H,EAAEY,EAAED,GAAGA,EAAE,CAACA,GAAGS,EAAEnB,EAAEC,EAAE,iBAAiBmC,EAAE,+BAA+BlC,EAAEC,EAAEC,EAAED,EAAEA,EAAE,GAAGH,EAAEwB,KAAKe,EAAEvC,EAAE,GAAGK,EAAEC,GAAG,MAAMH,EAAE,IAAII,EAAEJ,EAAEqC,OAAOjC,KAAKQ,EAAEZ,EAAEI,IAAIF,IAAIE,EAAE,QAAQ,YAAY6B,GAAG,MAAMsB,EAAE3D,EAAEiF,gBAAgB,SAAS,MAAMtB,IAAIA,IAAI3D,EAAEQ,IAAI,YAAY6B,IAAIsB,GAAG,UAAUtB,GAAGsB,GAAGC,EAAEpD,KAAKiE,EAAEzE,EAAEQ,EAAEmD,EAAEC,EAAEpD,GAAGL,GAAGK,EAAE,UAAU,MAAMW,GAAGA,GAAGnB,EAAEQ,IAAIiE,EAAEzE,EAAEQ,EAAEW,EAAEyC,EAAEpD,GAAGL,GAAG,CAAC,OAAOH,CAAC,CAAn0D6H,CAAEzG,EAAEQ,IAAI5B,EAAEoB,EAAEnB,EAAEC,EAAEC,EAAEC,EAAEE,EAAEC,GAAG,OAAOC,EAAET,EAAE+H,SAAStH,EAAER,GAAG,IAAIA,EAAEiC,SAAI,EAAO5B,CAAC,CAAC,SAASyG,EAAEhH,GAAGA,GAAGA,EAAE+B,MAAM/B,EAAE+B,IAAID,KAAI,GAAI9B,GAAGA,EAAE2B,KAAK3B,EAAE2B,IAAIsG,QAAQjB,EAAE,CAAC,SAAStD,EAAE1D,EAAEE,EAAEoB,GAAG,IAAA,IAAQnB,EAAE,EAAEA,EAAEmB,EAAEqB,OAAOxC,IAAIgE,EAAE7C,EAAEnB,GAAGmB,IAAInB,GAAGmB,IAAInB,IAAIF,EAAE8B,KAAK9B,EAAE8B,IAAI7B,EAAEF,GAAGA,EAAEwG,KAAK,SAAStG,GAAG,IAAIF,EAAEE,EAAE8F,IAAI9F,EAAE8F,IAAI,GAAGhG,EAAEwG,KAAK,SAASxG,GAAGA,EAAEwH,KAAKtH,EAAE,EAAE,OAAOF,GAAGC,EAAE6B,IAAI9B,EAAEE,EAAE+B,IAAI,CAAC,EAAE,CAAC,SAAS4E,EAAE7G,GAAG,MAAM,iBAAiBA,GAAG,MAAMA,GAAGA,EAAE6B,KAAK7B,EAAE6B,IAAI,EAAE7B,EAAEc,EAAEd,GAAGA,EAAEkI,IAAIrB,GAAG5F,EAAE,CAAA,EAAGjB,EAAE,CAA+6C,SAASmE,EAAEnE,EAAEE,EAAEoB,GAAG,IAAI,GAAG,mBAAmBtB,EAAE,CAAC,IAAIG,EAAE,mBAAmBH,EAAEmC,IAAIhC,GAAGH,EAAEmC,MAAMhC,GAAG,MAAMD,IAAIF,EAAEmC,IAAInC,EAAEE,GAAG,MAAMF,EAAEmI,QAAQjI,CAAC,OAAOF,GAAGC,EAAE6B,IAAI9B,EAAEsB,EAAE,CAAC,CAAC,SAAS2C,EAAEjE,EAAEE,EAAEoB,GAAG,IAAInB,EAAEC,EAAE,GAAGH,EAAEmI,SAASnI,EAAEmI,QAAQpI,IAAIG,EAAEH,EAAE0B,OAAOvB,EAAEgI,SAAShI,EAAEgI,SAASnI,EAAE8B,KAAKqC,EAAEhE,EAAE,KAAKD,IAAI,OAAOC,EAAEH,EAAE+B,KAAK,CAAC,GAAG5B,EAAEkI,qBAAqB,IAAIlI,EAAEkI,sBAAsB,OAAOrI,GAAGC,EAAE6B,IAAI9B,EAAEE,EAAE,CAACC,EAAE0C,KAAK1C,EAAEmD,IAAI,IAAI,CAAC,GAAGnD,EAAEH,EAAE2B,IAAI,IAAIvB,EAAE,EAAEA,EAAED,EAAEwC,OAAOvC,IAAID,EAAEC,IAAI6D,EAAE9D,EAAEC,GAAGF,EAAEoB,GAAG,mBAAmBtB,EAAEuB,MAAMD,GAAGJ,EAAElB,EAAE8B,KAAK9B,EAAE+B,IAAI/B,EAAE4B,GAAG5B,EAAE8B,SAAI,CAAM,CAAC,SAAS+D,EAAE7F,EAAEC,EAAEC,GAAG,OAAOsC,KAAKR,YAAYhC,EAAEE,EAAE,CAAC,SAASoI,EAAEpI,EAAEoB,EAAEnB,GAAG,IAAME,EAAEC,EAAEC,EAAEe,GAAG4F,WAAW5F,EAAE4F,SAASqB,iBAAiBtI,EAAE2B,IAAI3B,EAAE2B,GAAG1B,EAAEoB,GAAGjB,GAAK,EAAsB,KAAeiB,EAAEK,IAAIrB,EAAE,GAAGC,EAAE,GAAGgD,EAAEjC,EAAEpB,EAAUoB,EAAGK,IAAjhS,SAAW1B,EAAEC,EAAEoB,GAAG,IAAInB,EAAEC,EAAEC,EAAEC,EAAE,GAAG,IAAID,KAAKH,EAAE,OAAOG,EAAEF,EAAED,EAAEG,GAAG,OAAOA,EAAED,EAAEF,EAAEG,GAAGC,EAAED,GAAGH,EAAEG,GAAG,GAAGmI,UAAU7F,OAAO,IAAIrC,EAAEgC,SAASkG,UAAU7F,OAAO,EAAE3C,EAAEwH,KAAKgB,UAAU,GAAGlH,GAAG,mBAAmBrB,GAAG,MAAMA,EAAEwI,aAAa,IAAIpI,KAAKJ,EAAEwI,kBAAa,IAASnI,EAAED,KAAKC,EAAED,GAAGJ,EAAEwI,aAAapI,IAAI,OAAOgB,EAAEpB,EAAEK,EAAEH,EAAEC,EAAE,KAAK,CAAivRyD,CAAExB,EAAE,KAAK,CAACnC,IAAIG,GAAGM,EAAEA,EAAEW,EAAEmC,aAAuBpD,EAAE,KAAKiB,EAAEoH,WAAW1I,EAAEwH,KAAKlG,EAAEmG,YAAY,KAAKnH,EAAUD,EAAEA,EAAEyB,IAAIR,EAAEoH,WAA1L,MAAuMnI,GAAGmD,EAAEpD,EAAEJ,EAAEK,EAAE,CAAy1BP,EAAEY,EAAEoE,MAAM/E,EAAE,CAAC6B,IAAI,SAAS9B,EAAEC,EAAEC,EAAEoB,GAAG,IAAA,IAAQnB,EAAEC,EAAEC,EAAEJ,EAAEA,EAAE2B,IAAI,IAAIzB,EAAEF,EAAE8B,OAAO5B,EAAEyB,GAAG,IAAI,IAAIxB,EAAED,EAAE6B,cAAc,MAAM5B,EAAEuI,2BAA2BxI,EAAEyI,SAASxI,EAAEuI,yBAAyB3I,IAAIK,EAAEF,EAAE4C,KAAK,MAAM5C,EAAE0I,oBAAoB1I,EAAE0I,kBAAkB7I,EAAEsB,GAAG,CAAA,GAAIjB,EAAEF,EAAE4C,KAAK1C,EAAE,OAAOF,EAAEyF,IAAIzF,CAAC,OAAOF,GAAGD,EAAEC,CAAC,CAAC,MAAMD,CAAC,GAAGE,EAAE,EAAwDqC,EAAEiD,UAAUoD,SAAS,SAAS5I,EAAEC,GAAG,IAAIC,EAAEA,EAAE,MAAMsC,KAAK0D,KAAK1D,KAAK0D,KAAK1D,KAAKuD,MAAMvD,KAAK0D,IAAI1D,KAAK0D,IAAIjF,EAAE,CAAA,EAAGuB,KAAKuD,OAAO,mBAAmB/F,IAAIA,EAAEA,EAAEiB,EAAE,CAAA,EAAGf,GAAGsC,KAAKhB,QAAQxB,GAAGiB,EAAEf,EAAEF,GAAG,MAAMA,GAAGwC,KAAKP,MAAMhC,GAAGuC,KAAKyD,IAAIjD,KAAK/C,GAAG6C,EAAEN,MAAM,EAAED,EAAEiD,UAAUsD,YAAY,SAAS9I,GAAGwC,KAAKP,MAAMO,KAAKV,KAAI,EAAG9B,GAAGwC,KAAKwD,IAAIhD,KAAKhD,GAAG8C,EAAEN,MAAM,EAAED,EAAEiD,UAAUC,OAAOpD,EAAElC,EAAE,GAAGE,EAAE,mBAAmB0I,QAAQA,QAAQvD,UAAUsB,KAAKkC,KAAKD,QAAQE,WAAWC,WAAW5I,EAAE,SAASN,EAAEC,GAAG,OAAOD,EAAEiC,IAAIJ,IAAI5B,EAAEgC,IAAIJ,GAAG,EAAEoB,EAAEC,IAAI,EAAE3C,EAAE,8BAA8BC,EAAE,EAAEC,EAAE4E,GAAE,GAAI3E,EAAE2E,GAAE,GCA1tV,IAAuE9E,EAAE,EAAkB,SAASL,EAAEI,EAAEgB,EAAEtB,EAAEI,EAAED,EAAED,GAAGoB,IAAIA,EAAE,IAAI,IAAIZ,EAAEF,EAAEG,EAAEW,EAAE,GAAG,QAAQX,EAAE,IAAIH,KAAKG,EAAE,CAAA,EAAGW,EAAE,OAAOd,EAAEE,EAAEY,EAAEd,GAAGG,EAAEH,GAAGc,EAAEd,GAAG,IAAIP,EAAE,CAACsB,KAAKjB,EAAEkB,MAAMb,EAAEc,IAAIzB,EAAE0B,IAAIhB,EAAEiB,IAAI,KAAKC,GAAG,KAAKC,IAAI,EAAEC,IAAI,KAAKC,IAAI,KAAKC,iBAAY,EAAOC,MAAM1B,EAAE2B,KAAI,EAAGC,IAAI,EAAEgH,SAAShJ,EAAEiJ,OAAOlJ,GAAG,GAAG,mBAAmBI,IAAII,EAAEJ,EAAEmI,cAAc,IAAIjI,KAAKE,OAAE,IAASC,EAAEH,KAAKG,EAAEH,GAAGE,EAAEF,IAAI,OAAOH,EAAE+B,OAAO/B,EAAE+B,MAAMnC,GAAGA,CAAC,CCA1wB,IAAIqB,EAAEjB,EAAEH,EAAEC,EAAEC,EAAE,EAAEG,EAAE,GAAGC,EAAER,EAAEM,EAAEE,EAAEqB,IAAInB,EAAEF,EAAE0C,IAAItC,EAAEJ,EAAEwH,OAAO/H,EAAEO,EAAEuB,IAAIV,EAAEb,EAAE4H,QAAQ3H,GAAED,EAAEoB,GAAG,SAASjB,GAAEX,EAAEsB,GAAGd,EAAEwF,KAAKxF,EAAEwF,IAAI3F,EAAEL,EAAEI,GAAGkB,GAAGlB,EAAE,EAAE,IAAIF,EAAEG,EAAEgJ,MAAMhJ,EAAEgJ,IAAI,CAACzH,GAAG,GAAGoE,IAAI,KAAK,OAAOhG,GAAGE,EAAE0B,GAAGe,QAAQzC,EAAE0B,GAAGoB,KAAK,CAAA,GAAI9C,EAAE0B,GAAG5B,EAAE,CAAC,SAASc,GAAEd,GAAG,OAAOI,EAAE,EAAS,SAAWJ,EAAEE,GAAK,IAAIE,EAAEO,GAAEW,IAAI,GAAG,GAAGlB,EAAEkB,EAAEtB,GAAGI,EAAE2B,MAAM3B,EAAEwB,GAAG,CAAQqC,QAAE,EAAO/D,GAAG,SAASF,GAAG,IAAIsB,EAAElB,EAAEkJ,IAAIlJ,EAAEkJ,IAAI,GAAGlJ,EAAEwB,GAAG,GAAGvB,EAAED,EAAEkB,EAAEA,EAAEtB,GAAGsB,IAAIjB,IAAID,EAAEkJ,IAAI,CAACjJ,EAAED,EAAEwB,GAAG,IAAIxB,EAAE2B,IAAI6G,SAAS,CAAA,GAAI,GAAGxI,EAAE2B,IAAI1B,GAAGA,EAAEkJ,KAAK,CAAC,IAAIhJ,EAAE,SAASP,EAAEsB,EAAEjB,GAAG,IAAID,EAAE2B,IAAIsH,IAAI,OAAM,EAAG,IAAInJ,EAAEE,EAAE2B,IAAIsH,IAAIzH,GAAG4H,OAAO,SAASxJ,GAAG,QAAQA,EAAE+B,GAAG,GAAG,GAAG7B,EAAEuJ,MAAM,SAASzJ,GAAG,OAAOA,EAAEsJ,GAAG,GAAG,OAAO9I,GAAGA,EAAEgH,KAAKhF,KAAKxC,EAAEsB,EAAEjB,GAAG,IAAIF,EAAEC,EAAE2B,IAAIP,QAAQxB,EAAE,OAAOE,EAAE+H,QAAQ,SAASjI,GAAG,GAAGA,EAAEsJ,IAAI,CAAC,IAAIhI,EAAEtB,EAAE4B,GAAG,GAAG5B,EAAE4B,GAAG5B,EAAEsJ,IAAItJ,EAAEsJ,SAAI,EAAOhI,IAAItB,EAAE4B,GAAG,KAAKzB,GAAE,EAAG,CAAC,GAAGK,GAAGA,EAAEgH,KAAKhF,KAAKxC,EAAEsB,EAAEjB,IAAIF,CAAC,EAAEE,EAAEkJ,KAAI,EAAG,IAAI/I,EAAEH,EAAEkG,sBAAsBjG,EAAED,EAAEoG,oBAAoBpG,EAAEoG,oBAAoB,SAASzG,EAAEsB,EAAEjB,GAAG,GAAGmC,KAAKV,IAAI,CAAC,IAAI5B,EAAEM,EAAEA,OAAE,EAAOD,EAAEP,EAAEsB,EAAEjB,GAAGG,EAAEN,CAAC,CAACI,GAAGA,EAAEkH,KAAKhF,KAAKxC,EAAEsB,EAAEjB,EAAE,EAAEA,EAAEkG,sBAAsBhG,CAAC,CAAC,OAAOH,EAAEkJ,KAAKlJ,EAAEwB,EAAE,CAArtBgC,CAAEK,GAAEjE,EAAE,CAAgtB,SAASa,GAAEb,EAAEE,GAAG,IAAIC,EAAEQ,GAAEW,IAAI,IAAId,EAAE0F,KAAKtD,GAAEzC,EAAEkJ,IAAInJ,KAAKC,EAAEyB,GAAG5B,EAAEG,EAAED,EAAEA,EAAEG,EAAEgJ,IAAIrD,IAAIhD,KAAK7C,GAAG,CAAiF,SAASiE,GAAEpE,GAAG,OAAOI,EAAE,EAAEoE,GAAE,WAAW,MAAM,CAAC2D,QAAQnI,EAAE,EAAE,GAAG,CAAsN,SAASwE,GAAExE,EAAEK,GAAG,IAAIH,EAAES,GAAEW,IAAI,GAAG,OAAOsB,GAAE1C,EAAEmJ,IAAIhJ,KAAKH,EAAE0B,GAAG5B,IAAIE,EAAEmJ,IAAIhJ,EAAEH,EAAE8F,IAAIhG,GAAGE,EAAE0B,EAAE,CAAqiB,SAAS+C,KAAI,IAAA,IAAQ3E,EAAEA,EAAEO,EAAE8C,YAAYrD,EAAEsD,KAAKtD,EAAEqJ,IAAI,IAAIrJ,EAAEqJ,IAAIrD,IAAIiC,QAAQjB,IAAGhH,EAAEqJ,IAAIrD,IAAIiC,QAAQ9D,IAAGnE,EAAEqJ,IAAIrD,IAAI,EAAE,OAAO1E,GAAGtB,EAAEqJ,IAAIrD,IAAI,GAAGxF,EAAEsB,IAAIR,EAAEtB,EAAEiC,IAAI,CAAC,CAACzB,EAAEqB,IAAI,SAAS7B,GAAGK,EAAE,KAAKC,GAAGA,EAAEN,EAAE,EAAEQ,EAAEoB,GAAG,SAAS5B,EAAEsB,GAAGtB,GAAGsB,EAAEK,KAAKL,EAAEK,IAAI2F,MAAMtH,EAAEsH,IAAIhG,EAAEK,IAAI2F,KAAK7G,IAAGA,GAAET,EAAEsB,EAAE,EAAEd,EAAE0C,IAAI,SAASlD,GAAGU,GAAGA,EAAEV,GAAGsB,EAAE,EAAE,IAAInB,GAAGE,EAAEL,EAAE+B,KAAKsH,IAAIlJ,IAAID,IAAIG,GAAGF,EAAE6F,IAAI,GAAG3F,EAAE2F,IAAI,GAAG7F,EAAEyB,GAAGqG,QAAQ,SAASjI,GAAGA,EAAEsJ,MAAMtJ,EAAE4B,GAAG5B,EAAEsJ,KAAKtJ,EAAEE,EAAEF,EAAEsJ,SAAI,CAAM,KAAKnJ,EAAE6F,IAAIiC,QAAQjB,IAAG7G,EAAE6F,IAAIiC,QAAQ9D,IAAGhE,EAAE6F,IAAI,GAAG1E,EAAE,IAAIpB,EAAEG,CAAC,EAAEG,EAAEwH,OAAO,SAAShI,GAAGY,GAAGA,EAAEZ,GAAG,IAAIsB,EAAEtB,EAAE+B,IAAIT,GAAGA,EAAE+H,MAAM/H,EAAE+H,IAAIrD,IAAIrD,SAAS,IAAIpC,EAAEyC,KAAK1B,IAAInB,IAAIK,EAAEkJ,yBAAyBvJ,EAAEK,EAAEkJ,wBAAwBzI,IAAG0D,KAAIrD,EAAE+H,IAAIzH,GAAGqG,QAAQ,SAASjI,GAAGA,EAAEE,IAAIF,EAAEqJ,IAAIrJ,EAAEE,GAAGF,EAAEE,OAAE,CAAM,IAAIA,EAAEG,EAAE,IAAI,EAAEG,EAAEuB,IAAI,SAAS/B,EAAEsB,GAAGA,EAAEkF,KAAK,SAASxG,GAAG,IAAIA,EAAEgG,IAAIiC,QAAQjB,IAAGhH,EAAEgG,IAAIhG,EAAEgG,IAAIwD,OAAO,SAASxJ,GAAG,OAAOA,EAAE4B,IAAIuC,GAAEnE,EAAE,EAAE,OAAOK,GAAGiB,EAAEkF,KAAK,SAASxG,GAAGA,EAAEgG,MAAMhG,EAAEgG,IAAI,GAAG,GAAG1E,EAAE,GAAGd,EAAEsB,IAAIzB,EAAEL,EAAEiC,IAAI,CAAC,GAAGhC,GAAGA,EAAED,EAAEsB,EAAE,EAAEd,EAAE4H,QAAQ,SAASpI,GAAGqB,GAAGA,EAAErB,GAAG,IAAIsB,EAAEjB,EAAEL,EAAE+B,IAAI1B,GAAGA,EAAEgJ,MAAMhJ,EAAEgJ,IAAIzH,GAAGqG,QAAQ,SAASjI,GAAG,IAAIgH,GAAEhH,EAAE,OAAOA,GAAGsB,EAAEtB,CAAC,CAAC,GAAGK,EAAEgJ,SAAI,EAAO/H,GAAGd,EAAEsB,IAAIR,EAAEjB,EAAE4B,KAAK,EAAE,IAAII,GAAE,mBAAmBqH,sBAAsB,SAASzI,GAAEjB,GAAG,IAAIsB,EAAEjB,EAAE,WAAWsJ,aAAazJ,GAAGmC,IAAGuH,qBAAqBtI,GAAG4H,WAAWlJ,EAAE,EAAEE,EAAEgJ,WAAW7I,EAAE,IAAIgC,KAAIf,EAAEoI,sBAAsBrJ,GAAG,CAAC,SAAS2G,GAAEhH,GAAG,IAAIsB,EAAEjB,EAAEH,EAAEF,EAAE+B,IAAI,mBAAmB7B,IAAIF,EAAE+B,SAAI,EAAO7B,KAAKG,EAAEiB,CAAC,CAAC,SAAS6C,GAAEnE,GAAG,IAAIsB,EAAEjB,EAAEL,EAAE+B,IAAI/B,EAAE4B,KAAKvB,EAAEiB,CAAC,CAAC,SAASsB,GAAE5C,EAAEsB,GAAG,OAAOtB,GAAGA,EAAE2C,SAASrB,EAAEqB,QAAQrB,EAAEkF,KAAK,SAASlF,EAAEjB,GAAG,OAAOiB,IAAItB,EAAEK,EAAE,EAAE,CAAC,SAAS4D,GAAEjE,EAAEsB,GAAG,MAAM,mBAAmBA,EAAEA,EAAEtB,GAAGsB,CAAC,CCCt6G,MAWMuI,GAAS,CACpBC,QAAS,UACTC,aAAc,UAEdC,KAAM,yBAINC,YAAa,UACbC,gBAAiB,WAiBNC,GAAyBC,IACpC,MAAMC,EAfkB,CAACA,IACzB,MAAMC,EAAUD,EAAIE,OACpB,IAAK,qCAAqC7F,KAAK4F,GAC7C,MAAO,yBAET,GAAuB,IAAnBA,EAAQ3H,OAAc,CACxB,MAAMtC,EAAIiK,EAAQ,GACZpJ,EAAIoJ,EAAQ,GACZxG,EAAIwG,EAAQ,GAClB,MAAO,IAAIjK,IAAIA,IAAIa,IAAIA,IAAI4C,IAAIA,GACjC,CACA,OAAOwG,GAIKE,CAAkBJ,GAAepF,MAAM,GAOnD,OADmB,KALTyF,SAASJ,EAAIrF,MAAM,EAAG,GAAI,IAKL,KAJrByF,SAASJ,EAAIrF,MAAM,EAAG,GAAI,IAIO,KAHjCyF,SAASJ,EAAIrF,MAAM,EAAG,GAAI,KAGoB,IACrC,IAAO,0BAA4B,2BAI3C0F,GACH,MADGA,GAEH,OAFGA,GAGF,OAIEC,GAAS,qCAGTC,GACL,oBADKA,GAEH,oBC9CGC,GChBE,0sBDoBFC,GEpBE,8PFsBFC,GGtBE,8NCsBR,SAASC,IAAQC,IACpBA,EAAAC,MACAA,EAAAC,OACAA,EAAAC,MACAA,EAAAC,YACAA,GAAc,EAAAC,UACdA,EAAA1G,MACAA,EAAA2G,KACAA,EAAAC,OACAA,EAAAC,YACAA,KACGjK,IAEH,MAAMkK,QAAEA,EAAA5D,QAASA,GAAY6D,GAAQ,KACjC,IAAKV,EAAK,MAAO,CAAES,QAAS,YAAa5D,QAAS,IAElD,MAAM8D,EAAaX,EAAIV,OAEjBsB,EAAeD,EAAWE,MAAM,qBAOtC,MAAO,CAAEJ,QANOG,EAAeA,EAAa,GAAK,YAM/B/D,QAFJ8D,EAAW9G,QAAQ,eAAgB,IAAIA,QAAQ,eAAgB,MAG9E,CAACmG,IA0BJ,OACIc,EAAC,MAAA,CACGL,UACAR,QACAC,SACAG,YACA1G,MAAO,CACHoH,QAAS,eACTC,cAAe,SACfC,WAAY,KACTtH,GAEPuH,MAAM,gCACF3K,EACJ4K,wBAAyB,CAAExE,OAtCd+D,GAAQ,KACzB,IAAK7D,EAAS,MAAO,GACrB,IAAIuE,EAAcvE,EASlB,GAPIuD,IAEAgB,EAAcA,EACTvH,QAAQ,iBAAkB,SAASyG,MACnCzG,QAAQ,mBAAoB,WAAW0G,YAG5B,IAAhBC,EAA2B,CAC3B,MAAMa,EAAmBvI,OAAO0H,GAChCY,EAAc,wBAAwB3H,KAAK2H,GACrCA,EAAYvH,QAAQ,yBAA0B,iBAAiBwH,MAC/DD,EAAYvH,QACV,wDACA,qBAAqBwH,KAEjC,CAEA,OAAOD,GACR,CAACvE,EAASuD,EAAaE,EAAMC,EAAQC,KAkB/BnJ,SAAA8I,GAASW,EAAC,QAAA,CAAOzJ,SAAA8I,KAG9B,CCnEO,MAAMmB,GAAa,EACxBC,aACAC,oBACAC,aACAC,cACAC,SACAC,aACAC,gBACAC,iBACAC,iBACAC,qBAEA,MAAMC,EAAUrD,GAAOC,QAEjBqD,EAA4C,CAChDC,SAAU,QACVC,MAAO,OACPC,OAAQ,OACRtB,QAAS,OACTuB,cAAe,SACfC,WAAY,WACZC,IAAK,MACLC,OAAQ,OACRC,WAAY,uBASRC,EAAyC,CAC7C1C,MAAO,OACPC,OAAQ,OACR0C,SAAU,OACVC,UAAW,OACXC,aAAcrD,GACdsD,gBAAiBd,EACjBe,MAAO,UACPC,OAAQ,OACRC,OAAQ,UACRnC,QAAS,OACTwB,WAAY,SACZY,eAAgB,SAChBC,WAAY,oBAAoBzD,iBAA+BA,KAC/DwC,SAAU,WACVlB,WAAY,KAGRoC,EAAuC,CAC3CpD,MAAO,OACPC,OAAQ,OACRa,QAAS,QACTxC,OAAQW,GAAsB+C,IAG1BqB,EAAiB3B,IAAWD,EAa5B6B,EAA2C,CAC/CpB,SAAU,WACVqB,IAAK,MACLpB,MAAO,MACPnC,MAAO,OACPC,OAAQ,OACR4C,aAAc,MACdG,OAAQ,OACRQ,WAAY,cACZP,OAAQ,UACRnC,QAAS,OACTwB,WAAY,SACZY,eAAgB,SAChBO,SAAU,OACVC,WAAY,IACZX,MAAOpE,GAAOG,KACd6E,QAAS,KAGLC,EAAc,CAClBhH,EACAiH,EACAC,EACAC,EACAC,IAEAC,EAAC,MAAA,CACC7D,UAAW,eAAe2D,IAC1BrK,MAAO,CAAEuJ,OAAQ,WACjBY,UAGCzM,SAAA,CAAA0M,GACCjD,EAAC,SAAA,CACCxK,KAAK,SACLqD,MAAO4J,EACPO,QAAUzO,IACRA,EAAE8O,kBACFJ,KAEF,aAAW,QAEX1M,SAAAyJ,EAACf,GAAA,CACCS,YAAa,EACbR,IAAKH,GACLU,OAAQ,eACRL,OAAQ,OAMdY,EAAC,MAAA,CACCnH,MAAO,CACLyK,aAAcL,EAAU,OAAS,IACjCM,UAAW,gBACPJ,EAAa,CAAEK,UAAW,OAAQC,UAAW,QAAW,CAAA,GAG7DlN,SAAAwF,OAKP,OACEqH,EAAAM,EAAA,CACEnN,SAAA,CAAAyJ,EAAC,QAAA,CAAOzJ,SAAA,mLAKKuH,GAAOG,qNAOFW,mLAMWC,usCAuC7BmB,EAAC,MAAA,CAAIT,UAAU,sBAAsB1G,MAAOuI,EAC1C7K,SAAA6M,EAAC,MAAA,CAAI7D,UAAU,qBAAqB1G,MAxKU,CAClDoH,QAAS,OACTwB,WAAY,SACZC,IAAK,QAuKEnL,SAAA,CAAAuK,IACEF,IACAI,GACD+B,EACE,iDACAhC,EACA,KACA,sBACA,GAIHC,GACC+B,EACE/B,EACAC,EACAC,EACA,uBACA,GAIJlB,EAAC,SAAA,CACCnH,MAAOgJ,EACPmB,QAjKU,KACdR,EACF7B,IACSC,EACTF,IAEAD,KA4JMkD,aAAepP,IACbqP,OAAOC,OAAOtP,EAAEuP,cAAcjL,MAAO,CACnCoJ,gBAAiBnE,GAAOE,aACxB+F,UAAW,iBAGfC,aAAezP,IACbqP,OAAOC,OAAOtP,EAAEuP,cAAcjL,MAAO,CACnCkL,UAAW,cAGf,aAAYvB,EAAiB,gBAAkB5B,EAAc,iBAAmB,kBAEhFrK,SAAAyJ,EAACf,GAAA,CACCC,IAAKsD,EAAiBxD,GAAkB4B,EAAc7B,GAAmBD,GACzE,cAAY,OACZ,eAAc,EACdW,OAAQ,eACR5G,MAAO0J,eC9MR0B,GAAyB,iCAEhCC,OAAuBC,IAAI,CAC/B,SACA,QACA,WACA,WACA,OACA,SAGIC,OAA8BD,IAAI,CACtC,IACA,SACA,QACA,WACA,SACA,UACA,UACA,WAGIE,OAAwBF,IAAI,CAChC,SACA,OACA,MACA,WACA,SACA,WACA,QACA,SACA,WACA,UACA,YACA,SACA,aACA,aAGIG,OAA6BH,IAAI,CACrC,QACA,SACA,eACA,OACA,cACA,OACA,gBAGII,OAA8BJ,IAAI,CACtC,WACA,WACA,QACA,WAGIK,GAAmB,CACvB,QACA,WACA,YACA,UACA,cACA,YACA,aACA,WACA,UACA,QACA,WACA,QACA,SACA,SACA,QACA,QAGIC,GAAyB,CAC7B,gBACA,gBACA,gBACA,eACA,iBAGIC,GACJ,uFAEIC,GACJ,iGAEIC,OAAuBC,IAC7B,IAAIC,IAAgB,EAEpB,MAAMC,GAAuBnL,GAC3BA,EAAMb,QAAQ,OAAQ,KAAKyF,OAUvBwG,GAAgBpL,IACpB,GAAqB,iBAAVA,GAAgC,OAAVA,EAC/B,OAAO,EAGT,MAAMqL,EAAMrL,EACZ,MACqB,iBAAZqL,EAAIC,KACY,iBAAhBD,EAAIE,SACXnQ,MAAMC,QAAQgQ,EAAIG,QAClBpQ,MAAMC,QAAQgQ,EAAII,gBACQ,iBAAnBJ,EAAIK,YACY,iBAAhBL,EAAIM,SAITC,GAAY,CAACrJ,EAA0BzG,KACtCA,GAGLyG,EAAIsJ,IAAI/P,GAAMyG,EAAIuJ,IAAIhQ,IAAQ,GAAK,IAG/BiQ,GAAkB,CAACxJ,EAA0ByJ,IAChC,IAAbzJ,EAAI0J,KACC,OAGF7Q,MAAM8Q,KAAK3J,EAAI4J,WACnB1O,KAAK,CAAC1C,EAAGoD,IAAMA,EAAE,GAAKpD,EAAE,IAAMA,EAAE,GAAGqR,cAAcjO,EAAE,KACnDkB,MAAM,EAAG2M,GACTzJ,IAAI,EAAEP,EAAMqK,KAAW,GAAGrK,KAAQqK,KAClCC,KAAK,MAGJC,GAAiBvM,IACrB,GAAc,OAAVA,EACF,OAAO,KAGT,MAAMwM,EAASC,OAAO3H,SAAS9E,EAAO,IACtC,OAAOyM,OAAOC,MAAMF,GAAU,KAAOA,GAGjCG,GAAgB3M,GACJA,EAAMb,QAAQ,OAAQ,KAAKA,QAAQ,kBAAmB,KACpD,GAGdyN,GAAmBC,IACvB,IAAIC,EAAQ,EACRtE,EAAyBqE,EAC7B,YAAOrE,WAAQuE,iBACbD,GAAS,EACTtE,EAASA,EAAOuE,cACZvE,IAAWjH,SAASyL,QAI1B,OAAOF,GAGHG,GAAkBJ,GACN1B,GAAoB0B,EAAQK,aAAa,SAAW,IACjE9N,cACA+N,MAAM,KAAK,IACI,GAuEdC,GACJ5K,IAEA,MAAM6K,EAAcjS,MAAM8Q,KAAKlB,GAAiBsC,UAC7CzJ,OAAQ0J,GAAUA,EAAMjC,MAAQ9I,EAAQ8I,KACxC7N,KAAK,CAAC1C,EAAGoD,IAAMA,EAAEuN,WAAa3Q,EAAE2Q,YAChCrM,MAAM,EAAG,GAEZ,GAA2B,IAAvBgO,EAAYrQ,OACd,OAAOwF,EAAQ+I,QAGjB,MAAMiC,EAAiB,CACrB,yBACGH,EAAY9K,IAAKgL,IAClB,MAAME,EAAiBtC,GAAoBoC,EAAMhC,SACjD,MAAO,KAAKgC,EAAMjC,UAAUmC,OAE9BnB,KAAK,MAEP,MAAO,GAAG9J,EAAQ+I,cAAciC,KAG5BE,GAAab,IACjB,GAA4C,SAAxCA,EAAQK,aAAa,eACvB,OAAO,EAGT,GAAIL,aAAmBc,aAAed,EAAQe,OAC5C,OAAO,EAGT,MAAM3O,EAAQ4O,OAAOC,iBAAiBjB,GACtC,GAAsB,SAAlB5N,EAAMoH,SAA2C,WAArBpH,EAAM8O,WACpC,OAAO,EAGT,MAAMC,EAAOnB,EAAQoB,wBACrB,OAAOD,EAAKzI,MAAQ,GAAKyI,EAAKxI,OAAS,GAGnC0I,GAAiBC,IACrB,IACE,OAAO,IAAIC,IAAID,EAAMN,OAAOQ,SAASF,MAAMA,IAC7C,CAAA,MACE,OAAOA,CACT,GAGIG,GAAkBtO,GACH,oBAARuO,KAA6C,mBAAfA,IAAIC,OACpCD,IAAIC,OAAOxO,GAGbA,EAAMb,QAAQ,mCAAoC,QAGrDsP,GAAwB5B,IAC5B,MAAM6B,EAAM7B,EAAQ8B,QAAQvP,cAE5B,GAAIyN,EAAQ+B,GACV,MAAO,IAAIN,GAAezB,EAAQ+B,MAGpC,MAAMC,EAA8D,CAClE,CAAC,OAAQhC,EAAQK,aAAa,SAC9B,CAAC,cAAeL,EAAQK,aAAa,gBACrC,CAAC,eAAgBL,EAAQK,aAAa,iBACtC,CAAC,aAAcL,EAAQK,aAAa,eACpC,CAAC,OAAQL,EAAQK,aAAa,SAC9B,CAAC,OAAQL,EAAQK,aAAa,UAGhC,IAAA,MAAY4B,EAAUC,KAAcF,EAClC,GAAIE,EACF,MAAO,GAAGL,KAAOI,MAAaR,GAAeS,OAIjD,MAAMC,EAAU5T,MAAM8Q,KAAKW,EAAQoC,WAChCpL,OAAOqL,SACP7P,MAAM,EAAG,GACTkD,IAAKoD,GAAc,IAAI2I,GAAe3I,MACtC2G,KAAK,IACR,GAAI0C,EACF,MAAO,GAAGN,IAAMM,IAGlB,MAAMG,EAAStC,EAAQE,cACvB,IAAKoC,EACH,OAAOT,EAOT,MAAO,GAAGA,iBAJYtT,MAAM8Q,KAAKiD,EAAOxS,UAAUkH,OAC/CuL,GAAYA,EAAQT,UAAY9B,EAAQ8B,SAEfvN,QAAQyL,GAAW,MAI3CwC,GAAiBxC,IACrB,MAAMyC,EAAqB,GAC3B,IAAI9G,EAAyBqE,EACzBC,EAAQ,EAEZ,KAAOtE,GAAUsE,EAAQ,GAAG,CAC1B,MAAMyC,EAAUd,GAAqBjG,GAErC,GADA8G,EAASE,QAAQD,GACbA,EAAQE,WAAW,KACrB,MAEFjH,EAASA,EAAOuE,cAChBD,GAAS,CACX,CAEA,OAAOwC,EAAShD,KAAK,QAGjBoD,GAAmB7C,IACvB,MAAMxI,EAAO8G,IACV0B,aAAmBc,YAAcd,EAAQ8C,UAAY9C,EAAQ+C,cAC5D,IAEEC,EAAY1E,GAAoB0B,EAAQK,aAAa,eAAiB,IACtEzH,EAAQ0F,GAAoB0B,EAAQK,aAAa,UAAY,IAC7D4C,EAAc3E,GAClB0B,EAAQK,aAAa,gBAAkB,IAEnClL,EAAOmJ,GAAoB0B,EAAQK,aAAa,SAAW,IAC3DlN,EACJ6M,aAAmBkD,kBACnBlD,aAAmBmD,qBACnBnD,aAAmBoD,kBACf9E,GAAoB0B,EAAQ7M,OAAS,IACrC,GAEAkQ,EAAY9U,MAAM8Q,KAAKW,EAAQoC,WAClC1M,IAAK4N,GAASxD,GAAawD,IAC3BC,KAAKlB,SACFmB,EACHxD,EAAQ+B,IAAM,IAAI/B,EAAQ+B,MAC1BsB,GAAa,IAAIA,KAClBb,GAAcxC,GAEVyD,EACJjM,GAAQwL,GAAapK,GAASqK,GAAe9P,GAASgC,GAAQqO,EAEhE,GAAsC,UAAlCxD,EAAQ8B,QAAQvP,cAA2B,CAE7C,MAAO,GADWyN,EAAQK,aAAa,SAAW,UAC3BoD,GAAS,SAClC,CAEA,OAAOA,GAAS,YAGZC,GAAiB1D,IACrB,MAAM2D,EAAS3D,EACT4D,EAAuB,GAE7B,IAAA,MAAWC,KAAa9F,GAAkB,CACxC,MAAM+F,EAAa,KAAKD,IAClBE,EAAmB1B,QAAQrC,EAAQK,aAAayD,IAChDE,EAAmD,mBAAvBL,EAAOG,GAEzC,IAAKC,GAAqBC,KAI1BJ,EAAWpT,KAAKqT,GACZD,EAAWzT,QCzbwB,GD0brC,KAEJ,CAEA,OAAOyT,GAGHK,GAA2BjE,GAC/BhC,GAAuBhH,OAAQiL,GAAajC,EAAQkE,aAAajC,IAAWvM,IACzEuM,GAAaA,EAAS3P,QAAQ,QAAS,KAGtC6R,GAA2BnE,GAC/BA,EACGoE,oBACApN,OACEiL,GACCA,EAASW,WAAW,UAAY3E,GAAyB/L,KAAK+P,IAEjEzP,MAAM,EAAG,GACTkD,IAAKuM,GAAaA,EAAS3P,QAAQ,QAAS,KAE3C+R,GAA2BjS,IAC/B,MAAMkS,EAAoB,GAwB1B,OAtBIlS,EAAMuJ,QAA2B,SAAjBvJ,EAAMuJ,QACxB2I,EAAQ9T,KAAK,UAAU4B,EAAMuJ,UAE3BvJ,EAAMoH,SACR8K,EAAQ9T,KAAK,WAAW4B,EAAMoH,WAE5BpH,EAAMwI,UACR0J,EAAQ9T,KAAK,YAAY4B,EAAMwI,YAE7BxI,EAAM8I,QAA2B,SAAjB9I,EAAM8I,QACxBoJ,EAAQ9T,KAAK,WAAW4B,EAAM8I,UAE5B9I,EAAMmS,eAAyC,SAAxBnS,EAAMmS,eAC/BD,EAAQ9T,KAAK,kBAAkB4B,EAAMmS,iBAEnCnS,EAAM8O,YAAmC,YAArB9O,EAAM8O,YAC5BoD,EAAQ9T,KAAK,cAAc4B,EAAM8O,cAE/B9O,EAAMoS,SAA6B,MAAlBpS,EAAMoS,SACzBF,EAAQ9T,KAAK,WAAW4B,EAAMoS,WAGzBjW,MAAM8Q,KAAK,IAAI3B,IAAI4G,KAatBG,GAAoB,CAACzE,EAAkBC,KAC3C,MAAMyE,EAXoB,CAAC1E,IAC3B,MAAM6B,EAAM7B,EAAQ8B,QAAQvP,cACtBoS,EAAU3E,EAAQ+B,GAAK,IAAIjC,GAAaE,EAAQ+B,MAAQ,GACxD6C,EAAarW,MAAM8Q,KAAKW,EAAQoC,WACnC1M,IAAK4N,GAASxD,GAAawD,IAC3BC,KAAKlB,SAER,MAAO,GAAGR,IAAM8C,IAAUC,EAAa,IAAIA,IAAe,MAI5CC,CAAoB7E,GAClC,GAAIC,GAAS,EACX,OAAOyE,EAGT,MAAM5U,EAAWvB,MAAM8Q,KAAKW,EAAQlQ,UACjCkH,OAAQ8N,IAAWrH,GAAiBsH,IAAID,EAAMhD,QAAQvP,gBACtDyE,OAAQ8N,GAAUjE,GAAUiE,IAC/B,GAAwB,IAApBhV,EAASK,OACX,OAAOuU,EAGT,MAAMM,EAAUlV,EACb0C,MAAM,EAAG,GACTkD,IAAKoP,GAAUL,GAAkBK,EAAO7E,EAAQ,IAC7CgF,EACJnV,EAASK,OAAS6U,EAAQ7U,OAAS,KAAIL,EAASK,OAAS6U,EAAQ7U,QAAW,GAE9E,MAAO,GAAGuU,KAASM,EAAQvF,KAAK,OAAOwF,KAenCC,GAAgB,CAACtM,EAAeuM,IACf,IAAjBA,EAAMhV,OACD,GAAGyI,aAGL,GAAGA,OAAWuM,EAAM1F,KAAK,QAsB5B2F,GAAsB,KAC1B,MAAMC,EACJ3Q,SAAS4Q,cAAc,iCAAmC5Q,SAASyL,KAC/DoF,EAAqB,GACrBC,MAAW9H,IAEX+H,EAAalX,MAAM8Q,KAAKgG,EAAKK,iBAAiB,sBACpD,IAAA,MAAWC,KAAQF,EAAY,CAC7B,IAAK5E,GAAU8E,GACb,SAGF,MAAMnO,EAAO8G,GAAoBqH,EAAK5C,aAAe,IACrD,GAAKvL,KAAQA,EAAKrH,OAAS,OAIvBqV,EAAKT,IAAIvN,KAIbgO,EAAKI,IAAIpO,GACT+N,EAAS/U,KAAK,KAAKgH,KACf+N,EAASpV,QCnlBgB,IDolB3B,KAEJ,CAEA,OAAOoV,GA8BHM,GAA+B,CACnCC,EACAC,EACAC,KAEA,IAAA,MAAWC,KAAQ1X,MAAM8Q,KAAKyG,GAAQ,CACpC,GACEE,EAAQxG,OCxmBsB,KDymB9BuG,EAAU3G,MC5mBwB,GD8mBlC,OAKF,GAFA4G,EAAQxG,OAAS,EAEbyG,aAAgBC,aAAc,CAChC,MAAMC,EAAQF,EAAKG,aAChB9F,MAAM,KACN5K,IAAK2Q,GAAa/H,GAAoB+H,IACtCrP,OAAOqL,SAEV,IAAA,MAAWgE,KAAYF,EACrB,GAAKjI,GAA4BhM,KAAKmU,KAGtCN,EAAUH,IAAIS,GACVN,EAAU3G,MC9nBkB,ID+nB9B,OAGJ,QACF,CAEA,GAAI,aAAc6G,EAChB,IACE,MAAMK,EAAeL,EAAsBM,SAC3CV,GAA6BS,EAAaP,EAAWC,EACvD,CAAA,MAEA,CAEJ,GAGIQ,GAA6B,KACjC,MAAMT,MAAgBrI,IAChBsI,EAAU,CAAExG,MAAO,GAEzB,IAAA,MAAWiH,KAAclY,MAAM8Q,KAAK3K,SAASgS,aAAc,CACzD,GACEV,EAAQxG,OCnpBsB,KDopB9BuG,EAAU3G,MCvpBwB,GDypBlC,MAGF,IACE,IAAKqH,EAAWF,SACd,SAEFV,GAA6BY,EAAWF,SAAUR,EAAWC,EAC/D,CAAA,MAEA,CACF,CAEA,OAAOzX,MAAM8Q,KAAK0G,GAAWrQ,IAAK2Q,GAAa,KAAKA,MAGhDM,GAA4B,KAChC,MAAMC,EAAcrY,MAAM8Q,KAAK3K,SAASgR,iBAAiB,MACnDmB,EAAkBD,EAAYpU,MAAM,ECvrBN,KDyrB9BmM,EAAkB,GAClBmI,MAAcpJ,IACdqJ,MAA6B3I,IAC7B4I,MAAgB5I,IAChB6I,MAAiB7I,IACjB8I,MAAkB9I,IAClB+I,MAAoB/I,IACpBgJ,MAAqBhJ,IACrBiJ,MAAwBjJ,IAE9B,IAAIkJ,EAAkB,EAClBC,EAAW,EACXC,EAAwB,EACxBC,EAA2B,EAE3BC,EAAkB,EAClBC,EAAwB,EACxBC,EAAmB,EACnBC,EAAmB,EACnBC,EAA0B,EAE9B,IAAA,IAASC,EAAQ,EAAGA,EAAQlB,EAAgB1W,OAAQ4X,GAAS,EAAG,CAC9D,MAAM/H,EAAU6G,EAAgBkB,GAC1BlG,EAAM7B,EAAQ8B,QAAQvP,cAE5B,GAAIkL,GAAiBsH,IAAIlD,GACvB,SAGF,IAAKhB,GAAUb,GACb,SAGFsH,GAAmB,EACnBvI,GAAUiI,EAAWnF,GAErB,MAAMmG,EAAO5H,GAAeJ,GACxBgI,GACFjJ,GAAUkI,EAAYe,GAGxB,MAAM/H,EAAQF,GAAgBC,GAC1BC,EAAQsH,IACVA,EAAWtH,GAGb,MAAM7N,EAAQ4O,OAAOC,iBAAiBjB,GAClCnC,GAAuBkH,IAAI3S,EAAMoH,UACnCuF,GAAUoI,EAAe/U,EAAMoH,SAE7BsE,GAAwBiH,IAAI3S,EAAMwI,WACpCmE,GAAUqI,EAAgBhV,EAAMwI,UAGlC,MAAMqN,EAAuB5D,GAAwBjS,GACrD,IAAA,MAAW8V,KAAeD,EACxBlJ,GAAUsI,EAAmBa,GAG/B,MAAMtE,EAAaF,GAAc1D,GACjC,GAAI4D,EAAWzT,OAAS,EAEtB,IAAA,MAAW0T,KAAaD,EACtB7E,GAAUmI,EAAarD,GAI3B,MAAMsE,EAAWzI,GAAcM,EAAQK,aAAa,aAC9C+H,EAA0B,OAAbD,GAAqBA,GAAY,EAChDC,IACFV,GAAmB,GAGrB,MAAMW,EAAoC,YAAjBjW,EAAMuJ,OAC3B0M,IACFV,GAAyB,GAG3B,MAAMW,EAAYnE,GAAwBnE,GACtCsI,EAAUnY,OAAS,IACrByX,GAAoB,GAGtB,MAAMW,EAAYtE,GAAwBjE,GACtCuI,EAAUpY,OAAS,IACrB0X,GAAoB,GAGtB,MAAMW,EAAgE,SAA5CxI,EAAQK,aAAa,mBAC3CmI,IACFV,GAA2B,GAG7B,MAAMxG,EAAOtB,EAAQK,aAAa,QAC5BoI,EAAsB9K,GAAwBoH,IAAIlD,KAAiB,MAARA,GAAeQ,QAAQf,IAClFoH,EAAoB9K,GAAkBmH,IAAIiD,GAC1CW,EACJ3I,EAAQkE,aAAa,aACqB,SAA1ClE,EAAQK,aAAa,iBAEvB,GACU,MAARwB,GACAP,IACCA,EAAKsB,WAAW,OAChBtB,EAAKsB,WAAW,eACjB,CACA,MAAMgG,EAAevH,GAAcC,GAE7BuH,EAAO,KADChG,GAAgB7C,IAAY4I,QACZA,IAEzB9B,EAAQ/B,IAAI8D,KACf/B,EAAQlB,IAAIiD,GACZlK,EAAMnO,KAAKqY,GAKf,CAYA,KATEJ,GACAC,GACAF,GACA5E,EAAWzT,OAAS,GACpBiY,GACAC,GACAC,EAAUnY,OAAS,GACnBoY,EAAUpY,OAAS,IAESwY,EAC5B,SAGEF,EACFjB,GAAyB,EAEzBC,GAA4B,EAG9B,MAAMpB,EAAW7D,GAAcxC,GACzByD,EAAQZ,GAAgB7C,GACxB8I,EAAeb,EACfc,EAAyB,GAE3BnF,EAAWzT,OAAS,GACtB4Y,EAAavY,KAAK,OAAOoT,EAAWnE,KAAK,QAEvCiJ,GACFK,EAAavY,KAAK,QAAQwX,KAExBI,GACFW,EAAavY,KAAK,OAAO2X,KAEvBG,EAAUnY,OAAS,GACrB4Y,EAAavY,KAAK,QAAQ8X,EAAU7I,KAAK,QAEvC8I,EAAUpY,OAAS,GACrB4Y,EAAavY,KAAK,QAAQ+X,EAAU9I,KAAK,QAEvCqJ,EAAa3Y,OAAS,EACxB4Y,EAAavY,KAAK,OAAOsY,EAAarJ,KAAK,QAClC4I,GACTU,EAAavY,KAAK,sBAGpB,MAEMqY,EAAO,KAAKhH,KAAOwE,IADvB0C,EAAa5Y,OAAS,EAAI,KAAK4Y,EAAatJ,KAAK,SAAW,OACVgE,KAE9CuF,EACgB,EAApBpF,EAAWzT,QACVsY,EAAsB,EAAI,IAC1BC,EAAoB,EAAI,IACxBN,EAAa,EAAI,IACjBC,EAAmB,EAAI,IACvBC,EAAUnY,OAAS,EAAI,EAAI,IAC3BoY,EAAUpY,OAAS,EAAI,EAAI,IAC3BqY,EAAoB,EAAI,GAErBS,EAAWlC,EAAuB9H,IAAI4J,KACvCI,GAAYD,EAAQC,EAASD,QAChCjC,EAAuB/H,IAAI6J,EAAM,CAAEA,OAAMG,QAAOjB,SAEpD,CAEA,MAAMnJ,EAAgBrQ,MAAM8Q,KAAK0H,EAAuBtG,UACrD7P,KAAK,CAAC1C,EAAGoD,IAAMA,EAAE0X,MAAQ9a,EAAE8a,OAAS9a,EAAE6Z,MAAQzW,EAAEyW,OAChDvV,MAAM,ECh4BsB,IDi4B5BkD,IAAKwT,GAAcA,EAAUL,MAE1BM,EAAwB,IAAI/K,IAChC7P,MAAM8Q,KAAK4H,EAAW3H,WAAWtI,OAAO,EAAEgR,KACxCpK,GAAkBmH,IAAIiD,KAIpBoB,EAAqB,CACzB,wBAAwB5B,mBAAuCC,sBAA6CK,IAC5G,qBAAqB5I,GAAgBgI,EAAa,KAClD,mCAAmCQ,qBAAmCC,iBAAqCC,iBAAgCC,IAC3I,iBAAiB3I,GAAgBiK,EAAuB,KACxD,oBAAoBjK,GAAgBmI,EAAmB,MACvD,iHAGIgC,EAvXuB,MAC7B,MAAMhE,EAAO3Q,SAASyL,MAAQzL,SAASqB,gBAMvC,OALsBxH,MAAM8Q,KAAKgG,EAAKvV,UACnCkH,OAAQ8N,IAAWrH,GAAiBsH,IAAID,EAAMhD,QAAQvP,gBACtDyE,OAAQ8N,GAAUjE,GAAUiE,IAC5BtS,MAAM,EC9gBuB,GDghBXkD,IAAKoP,GACxBL,GAAkBK,EC9gBU,KD63BTwE,GACfC,EAAgB,CACpB,kBAAkB3C,EAAYzW,mBAAmB0W,EAAgB1W,mBAAmBmX,gBAA8BC,IAAWX,EAAYzW,OAAS0W,EAAgB1W,OAAS,gBAAkB,KAC7L,kBAAkB+O,GAAgB8H,EAAW,MAC7C,mBAAmB9H,GAAgB+H,EAAY,KAC/C,6BAA6B/H,GAAgBiI,EAAe,iBAAiBjI,GAAgBkI,EAAgB,MAC7G,oBAAoBiC,EAAalZ,OAAS,EAAIkZ,EAAa5J,KAAK,QAAU,UAG5E,MAAO,CACLd,MAAOA,EAAMnM,MAAM,EC/5BE,IDg6BrBoM,gBACAwK,qBACAI,eAAgBhD,KAChB+C,kBA4CSE,GAAiB,KAC5B,GAAsB,oBAAXzI,QAA8C,oBAAbtM,SAC1C,MAAO,CACLiK,MAAO,GACPC,cAAe,GACfF,QAAS,IAtvBiB,MAC9B,IAAIL,IAA2C,oBAAnBqL,eAA5B,CAIArL,IAAgB,EAEhB,IACE,MAAMsL,EAAMD,eAAeE,QAAQpM,IACnC,IAAKmM,EACH,OAGF,MAAMhK,EAASkK,KAAKC,MAAMH,GAC1B,IAAKpb,MAAMC,QAAQmR,GACjB,OAGF,IAAA,MAAWxM,KAASwM,EACbpB,GAAapL,IAhMkB,IAmMhCA,EAAM2L,SAGVX,GAAiBa,IAAI7L,EAAMsL,IAAKtL,GAE9BgL,GAAiBiB,KAAO,GAC1B2K,QAAQC,KACN,0CAA0C7L,GAAiBiB,OAGjE,OAAS6K,GACPF,QAAQG,KAAK,uCAAwCD,EACvD,CA/BA,GAuvBAE,GACA,MAAM1L,EAx0Ba,CAAC2L,IACpB,IACE,OAAO,IAAI7I,IAAI6I,EAAQA,GAAQ9I,IACjC,CAAA,MACE,OAAO8I,CACT,GAm0BYC,CAAarJ,OAAOQ,SAASF,MACnCgJ,EAASnM,GAAiBc,IAAIR,GACpC,GAAI6L,EAEF,OADAP,QAAQC,KAAK,iCAAiCvL,KACvC,CACLE,MAAO2L,EAAO3L,MACdC,cAAe0L,EAAO1L,cACtBF,QAAS6B,GAAwB+J,IAIrCP,QAAQC,KAAK,kCAAkCvL,KAE/C,MAAM8L,EAAW5D,KACX6D,EAAWjc,MAAM8Q,KAAK3K,SAASgR,iBAAiB,eACnD1O,OAAQgJ,GAAYa,GAAUb,IAC9BtK,IAAKsK,GACJ,KAAK1B,GAAoB0B,EAAQ+C,aAAe,OAEjD/L,OAAQ6R,GAAkB,OAATA,GACjBrW,MAAM,ECv+BiB,IDi6BW,IACrCiY,IAsFA,MAAM/J,EAAgC,CACpCjC,MACAC,SAxFF+L,EAuEwC,CACtChM,MACA7F,MAAOlE,SAASkE,MAChB8R,KAAMhW,SAASqB,gBAAgB2U,KAC/BF,WACAG,UA/YyD,CACzD,CAAElH,MAAO,OAAQ4C,SAAU,uBAC3B,CAAE5C,MAAO,MAAO4C,SAAU,4BAC1B,CAAE5C,MAAO,UAAW4C,SAAU,WAC9B,CAAE5C,MAAO,UAAW4C,SAAU,WAC9B,CAAE5C,MAAO,OAAQ4C,SAAU,QAC3B,CAAE5C,MAAO,IAAK4C,SAAU,KACxB,CAAE5C,MAAO,SAAU4C,SAAU,UAC7B,CAAE5C,MAAO,QAAS4C,SAAU,SAC5B,CAAE5C,MAAO,mBAAoB4C,SAAU,kCACvC,CAAE5C,MAAO,gBAAiB4C,SAAU,aACpC,CACE5C,MAAO,oBACP4C,SACE,kFAEJ,CAAE5C,MAAO,WAAY4C,SAAU,cAC/B,CAAE5C,MAAO,kBAAmB4C,SAAU,4BACtC,CAAE5C,MAAO,uBAAwB4C,SAAU,sBAG/B3Q,IACZ,EAAG+N,QAAO4C,cAAe,KAAK5C,MAAU/O,SAASgR,iBAAiBW,GAAUlW,UA0X5EwO,MAAO4L,EAAS5L,MAChBC,cAAe2L,EAAS3L,cACxBwK,mBAAoBmB,EAASnB,mBAC7BI,eAAgBe,EAASf,eACzBD,cAAegB,EAAShB,cACxBqB,aAAcxF,KACdyF,kBAxcU,OAAAC,EAAApW,SAASyL,WAAT,EAAA2K,EAAeC,YAAarW,SAASqB,gBAAgBgV,WAG9DzY,QAAQ,8BAA+B,IACvCA,QAAQ,4BAA6B,IACrCA,QAAQ,kCAAmC,IAC3CA,QAAQ,mBAAoB,IAC5BA,QAAQ,OAAQ,KAChByF,OAGAzF,QAAQ,WAAY,MACpBA,QAAQ,OAAQ,KAChByF,QA0Wc,CACfmN,GAAc,OAAQ,CACpB,UAAUuF,EAAMhM,KAAO,YACvB,YAAYgM,EAAM7R,OAAS,YAC3B,WAAW6R,EAAMC,MAAQ,cAE3BxF,GAAc,WAAYuF,EAAMD,UAChCtF,GAAc,oBAAqBuF,EAAME,WACzCzF,GAAc,sBAAuBuF,EAAMrB,oBAC3ClE,GAAc,+BAAgCuF,EAAMjB,gBACpDtE,GAAc,4BAA6BuF,EAAMlB,eACjDrE,GAAc,YAAauF,EAAM9L,OACjCuG,GAAc,oBAAqBuF,EAAM7L,eACzCsG,GAAc,wBAAyBuF,EAAMG,cAC7C1F,GAAc,qBAAsB,CAClC,KAAKuF,EAAMI,iBAAmB,mBAIlBpL,KAAK,SAoEnBd,MAAO4L,EAAS5L,MAChBC,cAAe2L,EAAS3L,cACxBC,WAAYmM,KAAKC,MACjBnM,QAn9BsC,GA69BxC,OAPAX,GAAiBa,IAAIP,EAAKiC,GAnvBI,MAC9B,GAAIvC,GAAiBiB,MCzQS,GD0Q5B,OAGF,MAAM8L,EAAS3c,MAAM8Q,KAAKlB,GAAiBsC,UAAU7P,KACnD,CAAC1C,EAAGoD,IAAMpD,EAAE2Q,WAAavN,EAAEuN,YAEvBoG,EAAWiG,EAAO/a,OChRM,GDiR9B,IAAA,IAASxC,EAAI,EAAGA,EAAIsX,EAAUtX,GAAK,EACjCwQ,GAAiBgN,OAAOD,EAAOvd,GAAG8Q,MA0uBpC2M,GArwB4B,MAC5B,GAA8B,oBAAnB1B,eAIX,IACE,MAAM2B,EAAaxB,KAAKyB,UACtB/c,MAAM8Q,KAAKlB,GAAiBsC,UAAU7P,KACpC,CAAC1C,EAAGoD,IAAMpD,EAAE2Q,WAAavN,EAAEuN,aAG/B6K,eAAe6B,QAAQ/N,GAAwB6N,EACjD,OAASpB,GACPF,QAAQG,KAAK,uCAAwCD,EACvD,GAwvBAuB,GACAzB,QAAQC,KACN,oCAAoCvL,UAAYN,GAAiBiB,QAG5D,CACLT,MAAO+B,EAAM/B,MACbC,cAAe8B,EAAM9B,cACrBF,QAAS6B,GAAwBG,KEvhC/B+K,GAAkB,wBAClBC,GAAqB,8BACdC,GAA0B,IAEjCC,GAAgB,+BAKhBC,GAAqB,qBAkBdC,GACXvY,IAEA,GAA4B,oBAAjBwY,aACX,IACEA,aAAaR,QACXM,GACAhC,KAAKyB,UAAU,IAAK/X,EAAOyY,QAAShB,KAAKC,QAE7C,CAAA,MAEA,GAoBWgB,GAA0B,KACT,oBAAjBF,cACXA,aAAaG,WAAWL,KA2NbM,GAAQ,CAAChZ,EAAeiZ,EAAaC,IAChDC,KAAKF,IAAIC,EAAKC,KAAKD,IAAID,EAAKjZ,IA6BjBoZ,GAAwBC,MACnCC,EACAC,EApTgC,OAsThC,GAAsB,oBAAX1L,OACT,OAGF,MAAM2L,EAAS3L,OAAO4L,QAChBC,EAAQJ,EAAUE,EACpBL,KAAKQ,IAAID,GAAS,SAIhB,IAAItW,QAAeE,IACvB,MAAMsW,EACJ/L,OAAO9J,uBAAA,CACL8V,GAAmChM,OAAOtK,WAAW,IAAMsW,EAASC,YAAYhC,OAAQ,KAEtFiC,EAAYD,YAAYhC,MAExBkC,EAAQlC,IACZ,MACMmC,EAAWjB,IADDlB,EAAMiC,GACWR,EAAY,EAAG,GAC1CW,EA5CiB,CAACD,KAC1Bd,KAAKgB,IAAIhB,KAAKiB,GAAKH,GAAY,GAAK,EA2CpBI,CAAcJ,GAC5BpM,OAAOyM,SAAS,EAAGd,EAASE,EAAQQ,GAEhCD,EAAW,EACbL,EAAII,GAEJ1W,KAIJsW,EAAII,MAIFO,GAA0B,KAC9B,GAA4B,oBAAjB3B,aACT,OAAO,KAGT,IACE,MAAMpC,EAAMoC,aAAanC,QAAQ8B,IACjC,IAAK/B,EACH,OAAO,KAGT,MAAMhK,EAASkK,KAAKC,MAAMH,GAC1B,MACwB,iBAAfhK,EAAOlB,KACM,iBAAbkB,EAAO5P,GACb6P,OAAO+N,SAAShO,EAAO5P,IACJ,iBAAb4P,EAAOtR,GACbuR,OAAO+N,SAAShO,EAAOtR,GAKnB,CACLoQ,IAAKkB,EAAOlB,IACZ1O,EAAG4P,EAAO5P,EACV1B,EAAGsR,EAAOtR,EACVuf,SAA4B,IAAnBjO,EAAOiO,SAPT,IASX,CAAA,MACE,OAAO,IACT,GAGIC,GAAqB,CAAC9d,EAAW1B,EAAWuf,KAChD,GAA4B,oBAAjB7B,aAIX,IACE,MAAM+B,EAAgC,CACpCrP,IAAKuC,OAAOQ,SAASF,KACrBvR,EAAAA,EACA1B,EAAAA,EACAuf,WAEF7B,aAAaR,QAAQG,GAAoB7B,KAAKyB,UAAUwC,GAC1D,CAAA,MAEA,GAGIC,GAAoB,CAACpS,EAAqB5L,EAAW1B,KACzDsN,EAAOvJ,MAAM4b,KAAO,GAAGje,MACvB4L,EAAOvJ,MAAM6J,IAAM,GAAG5N,OAGlB4f,GAAqBtS,IAAA,CACzB5L,EAAG6P,OAAOsO,WAAWvS,EAAOvJ,MAAM4b,OAAS,EAC3C3f,EAAGuR,OAAOsO,WAAWvS,EAAOvJ,MAAM6J,MAAQ,IAGtCkS,GAAsB,CAACxS,EAAqBiS,KAChDjS,EAAOvJ,MAAMoS,QAAUoJ,EAAU,IAAM,KAG5BQ,GAAkB,KAC7B,GAAwB,oBAAb1Z,UAA8C,oBAAXsM,OAC5C,OAGF,MAAMrF,EAASjH,SAAS2Z,eAAe5C,IACvC,KAAM9P,aAAkBmF,aACtB,OAGF,MAAQ/Q,EAAAA,EAAG1B,EAAAA,GAAM4f,GAAkBtS,GACnCwS,GAAoBxS,GAAQ,GAC5BkS,GAAmB9d,EAAG1B,GAAG,IAG3B,IAAIigB,IAAiC,EACrC,MAAMC,GAAgC,KAChCD,KAGJA,IAAiC,EAEjC5Z,SAASjC,iBAAiB,YAAcK,IACtC,MAAM6I,EAASjH,SAAS2Z,eAAe5C,IACvC,KAAM9P,aAAkBmF,aACtB,OAGF,GAA6B,MAAzBnF,EAAOvJ,MAAMoS,QACf,OAGF,MAAQzU,EAAAA,EAAG1B,EAAAA,GAAM4f,GAAkBtS,GAC7B6S,EAAW1b,EAAM2b,MACjBC,EAAW5b,EAAM6b,MACNrC,KAAKsC,MAAMJ,EAAWze,EAAG2e,EAAWrgB,IA1b1B,KA6bzB8f,GAAoBxS,GAAQ,GAC5BkS,GAAmB9d,EAAG1B,GAAG,QAezBwgB,GAAe,KACnB,MAAM5F,EAAWvU,SAAS2Z,eAAe5C,IACzC,GAAIxC,EAIF,OAFAA,EAAS7W,MAAM8J,WAAa7E,GAAOC,QACnCiX,KACOtF,EAGT,MAAMtN,EAASjH,SAASoa,cAAc,OACtCnT,EAAOoG,GAAK0J,GACZ9P,EAAOvJ,MAAMwI,SAAW,WACxBe,EAAOvJ,MAAM4b,KAAO,MACpBrS,EAAOvJ,MAAM6J,IAAM,MACnBN,EAAOvJ,MAAMoS,QAAU,IAEvB7I,EAAOvJ,MAAMsG,MAAQ,OACrBiD,EAAOvJ,MAAMuG,OAAS,OACtBgD,EAAOvJ,MAAMmJ,aAAe,MAC5B,MAAMwT,EAAY1X,GAAOC,QACzBqE,EAAOvJ,MAAM8J,WAAa6S,EAa1B,OAXApT,EAAOvJ,MAAMsJ,OAAS,oBACtBC,EAAOvJ,MAAM4c,UAAY,oCACzBrT,EAAOvJ,MAAM6c,UAAY,aACzBtT,EAAOvJ,MAAM8I,OAAS,aACtBS,EAAOvJ,MAAMmS,cAAgB,OAC7B5I,EAAOvJ,MAAMkL,UAAY,wBACzB3B,EAAOvJ,MAAMyJ,WAAa,cAAqC+P,iBAAmDA,6BAClHlX,SAASyL,KAAK+O,YAAYvT,GAC1B4S,KAxC0C,CAAC5S,IAC3C,MAAMwT,EAASzB,KACVyB,GAAUA,EAAO1Q,MAAQuC,OAAOQ,SAASF,OAI9CyM,GAAkBpS,EAAQwT,EAAOpf,EAAGof,EAAO9gB,GAC3C8f,GAAoBxS,EAAQwT,EAAOvB,WAkCnCwB,CAAoCzT,GACpCoO,QAAQC,KAAK,gCAAgC+E,oBACtCpT,GAGH0T,GAAa7C,MAAOzc,EAAW1B,KACnC,MAAMsN,EAASkT,KACfd,GAAkBpS,EAAQ5L,EAAG1B,GAC7B8f,GAAoBxS,GAAQ,GAC5BkS,GAAmB9d,EAAG1B,GAAG,SACnB,IAAIkI,QAASE,GAAYC,WAAWD,EAASkV,MAG/C2D,GAAoBtP,IACxB,MAAMmB,EAAOnB,EAAQoB,wBACrB,MAAO,CACLrR,EAAGoR,EAAK6M,KAAOhN,OAAOuO,QAAUpO,EAAKzI,MAAQ,EAC7CrK,EAAG8S,EAAKlF,IAAM+E,OAAO4L,QAAUzL,EAAKxI,OAAS,IAI3C6W,GAA4B,uCAE5BC,GAAyBpJ,cAC7B,IACE,OAAO3R,SAAS4Q,cAAce,EAChC,OAAS4D,GACP,MAAMyF,EAAgBrJ,EAAS/M,MAAMkW,IACrC,IAAKE,EAEH,OADA3F,QAAQG,KAAK,8BAA8B7D,IAAY4D,GAChD,KAGT,MAAM0F,GAAe,OAAA7E,EAAA4E,EAAc,aAAI3X,SAAU,IAC3C6X,GAAe,OAAAC,EAAAH,EAAc,aAAI3X,SAAU,GACjD,IAAK6X,EAEH,OADA7F,QAAQG,KAAK,0CAA0C7D,KAChD,KAGT,IACE,MAAMZ,EAAa/Q,SAASgR,iBAAiBiK,GAC7C,IAAA,MAAWzG,KAAazD,EACtB,GAAI,OAAAqK,EAAA5G,EAAUnG,kBAAV,EAAA+M,EAAuBC,SAASH,GAClC,OAAO1G,EAGX,OAAO,IACT,OAAS8G,GAEP,OADAjG,QAAQG,KAAK,uCAAuC7D,IAAY2J,GACzD,IACT,CACF,GA6BIC,GAAqB,CACzBjQ,EACAjR,EACAgB,EACA1B,KAEA2R,EAAQkQ,cACN,IAAIC,WAAWphB,EAAM,CACnBqhB,SAAS,EACTC,YAAY,EACZC,KAAMtP,OACNuP,QAASxgB,EAAIiR,OAAOuO,QACpBiB,QAASniB,EAAI2S,OAAO4L,YA+CpB6D,GAA4BjE,MAAOxM,UACjC0Q,GAAkC1Q,GAAS,IAG7C0Q,GAAoClE,MACxCxM,EACA2Q,KAEA,MAAMxP,EAAOnB,EAAQoB,wBACfwP,EAAiB5P,OAAO6P,YAE9B,IAAKF,IApW8B,EACnCxP,EACAyP,IACYzP,EAAKlF,IAAM,GAAKkF,EAAKrG,OAAS8V,EAiWrBE,CAAsB3P,EAAMyP,GAC/C,OAGF,MAAMG,EAAezE,KAAKD,IACxB,EACAC,KAAKD,IAAI3X,SAASyL,KAAK6Q,aAActc,SAASqB,gBAAgBib,cAAgBJ,GAE1EnE,EAvWgC,EACtCwE,EACAC,EACAC,EACAP,EACAG,IAIO5E,GADL8E,EAAiBC,GAAWN,EAAiB,EAAIO,EAAa,GAC1C,EAAG7E,KAAKD,IAAI,EAAG0E,IA8VrBK,CACdpQ,OAAO4L,QACPzL,EAAKlF,IACLkF,EAAKxI,OACLiY,EACAG,SAGIxE,GAAsBE,EArpBI,MAoqB5B4E,GAAkB7E,MAAOxX,IAC7B,MAAMsc,EAhIc,CAACtc,IACrB,GAAIA,EAAKqR,SAAU,CACjB,MAAMkL,EAAW9B,GAAsBza,EAAKqR,UAE5C,GAAIkL,aAAoBzQ,YAAa,CACnC,MAAM0Q,EAASlC,GAAiBiC,GAChC,MAAO,CACLvR,QAASuR,EACTxhB,EAAGyhB,EAAOzhB,EACV1B,EAAGmjB,EAAOnjB,EAEd,CACA0b,QAAQG,KAAK,0CAA0ClV,EAAKqR,WAC9D,CAEA,MAAsB,iBAAXrR,EAAKjF,GAAoC,iBAAXiF,EAAK3G,EACrC,CACL0B,EAAGiF,EAAKjF,EACR1B,EAAG2G,EAAK3G,IAIZ0b,QAAQG,KAAK,6DAA8DlV,GACpE,OAyGQyc,CAAczc,GAC7B,GAAKsc,EAAL,CAIA,GAAoB,UAAhBtc,EAAK0c,QAAsBJ,EAAOtR,QAAS,OACvCyQ,GAA0Ba,EAAOtR,SACvC,MAAMwR,EAASlC,GAAiBgC,EAAOtR,SACvCsR,EAAOvhB,EAAIyhB,EAAOzhB,EAClBuhB,EAAOjjB,EAAImjB,EAAOnjB,CACpB,CAIA,SAFMghB,GAAWiC,EAAOvhB,EAAGuhB,EAAOjjB,GAEd,SAAhB2G,EAAK0c,OAAT,CAIA,GAAKJ,EAAOtR,QAKZ,MAAoB,UAAhBhL,EAAK0c,QACPzB,GAAmBqB,EAAOtR,QAAS,cAAesR,EAAOvhB,EAAGuhB,EAAOjjB,GACnE4hB,GAAmBqB,EAAOtR,QAAS,YAAasR,EAAOvhB,EAAGuhB,EAAOjjB,GACjE4hB,GAAmBqB,EAAOtR,QAAS,YAAasR,EAAOvhB,EAAGuhB,EAAOjjB,GACjE4hB,GAAmBqB,EAAOtR,QAAS,UAAWsR,EAAOvhB,EAAGuhB,EAAOjjB,QAC/DijB,EAAOtR,QAAQ2R,cAIG,SAAhB3c,EAAK0c,OA/FW,CAAC1R,UACrB,GAAwB,SAApBA,EAAQ8B,QAEV,YADC9B,EAA4B4R,gBAI/B,GAAwB,WAApB5R,EAAQ8B,SAAyB9B,EAA8B6R,KAEjE,YADC,OAAA/G,EAAA9K,EAA8B6R,OAA9B/G,EAAoC8G,iBAIvC,MAAME,EAAa9R,EAAQ+R,QAAQ,QAC/BD,EACFA,EAAWF,gBAIb7H,QAAQG,KAAK,6DAmFb8H,CAAcV,EAAOtR,SA1HC,EAACA,EAAsBxI,KAC7C,MAAMsK,EAAU9B,EAAQ8B,QAAQmQ,cAChB,UAAZnQ,GAAmC,aAAZA,GACxB9B,EAA6BkS,QAC7BlS,EAA6B7M,MAAQqE,EACtCwI,EAAQkQ,cAAc,IAAIiC,MAAM,QAAS,CAAE/B,SAAS,KACpDpQ,EAAQkQ,cAAc,IAAIiC,MAAM,SAAU,CAAE/B,SAAS,MAInDpQ,EAAQwI,mBACVxI,EAAQkS,QACRlS,EAAQ+C,YAAcvL,EACtBwI,EAAQkQ,cAAc,IAAIiC,MAAM,QAAS,CAAE/B,SAAS,MAItDrG,QAAQG,KACN,wFAoGAkI,CAAgBd,EAAOtR,QAAShL,EAAKwC,MAAQ,KAd7CuS,QAAQG,KAAK,8DAA+DlV,EAAK0c,OAHnF,CAbA,GAgKIW,GAAkB7F,MAAOxX,IAC7B,IACE,MAAMsd,EAAYtd,EAAKyJ,IACvB,IAAI8T,EACJ,IACEA,EAAc,IAAIhR,IAAI+Q,EAAWtR,OAAOQ,SAASF,MAAMA,IACzD,CAAA,MACEiR,EAAcD,CAChB,CAEA,MAAME,EAtHwB,CAACF,IACjC,IAAIG,EAA2B,KAC/B,IACEA,EAAe,IAAIlR,IAAI+Q,EAAWtR,OAAOQ,SAASF,KACpD,CAAA,MAEA,CAEA,MAAMoR,EAAWnkB,MAAM8Q,KACrB3K,SAASgR,iBAAiB,8CAI5B,IAAA,MAAWiN,KAAMD,EACf,GAAIC,aAAcC,mBAAqBD,EAAGrR,cAASmR,WAAcnR,MAC/D,OAAOqR,EAIX,GAAIF,EAAc,CAEhB,IAAA,MAAWE,KAAMD,EACf,GAAMC,aAAcC,kBACpB,IACE,MAAMC,EAAQ,IAAItR,IAAIoR,EAAGrR,KAAMN,OAAOQ,SAASF,MAC/C,GACEuR,EAAMC,WAAaL,EAAaK,UAChCD,EAAME,SAAWN,EAAaM,QAC9BF,EAAMG,OAASP,EAAaO,KAE5B,OAAOL,CAEX,CAAA,MACE,QACF,CAIF,IAAA,MAAWA,KAAMD,EACf,GAAMC,aAAcC,kBACpB,IAEE,GADc,IAAIrR,IAAIoR,EAAGrR,KAAMN,OAAOQ,SAASF,MACrCwR,WAAaL,EAAaK,SAClC,OAAOH,CAEX,CAAA,MACE,QACF,CAIF,MAAMvI,EAASkI,EAAUhgB,QAAQ,MAAO,IACxC,IAAA,MAAWqgB,KAAMD,EAAU,CACzB,MAAMpR,EAAOqR,EAAGtS,aAAa,SAAWsS,EAAGtS,aAAa,cAAgB,GACxE,GAAIiB,IAASA,IAASgR,GAAahR,IAAS8I,GAAU9I,IAAS,IAAI8I,KACjE,OAAOuI,CAEX,CACF,CAGA,MAAMM,EAAcX,EACjBhgB,QAAQ,oBAAqB,IAC7BA,QAAQ,UAAW,IACnBgO,MAAM,KACNtJ,OAAOqL,SACJ6Q,EAAcD,EAAYA,EAAY9iB,OAAS,IAAM,GAE3D,GAAI+iB,EAAa,CAEf,IAAIC,EAAc,CAACD,GACnB,GAAIT,EAAc,CAChB,IAAA,MAAW,CAAGtf,KAAUsf,EAAaW,aAAa9T,UAC5CnM,GAAOggB,EAAY3iB,KAAK2C,GAE1Bsf,EAAaO,MACfG,EAAY3iB,KAAKiiB,EAAaO,KAAK1gB,QAAQ,KAAM,IAErD,CACA6gB,EAAcA,EAAYzd,IAAK5G,GAAMA,EAAEyD,eAGvC,MAAM8gB,EAAa9kB,MAAM8Q,KACvB3K,SAASgR,iBACP,mFAIJ,IAAA,MAAWiN,KAAMU,EAAY,CAC3B,MAAM7b,GAAQmb,EAAG5P,aAAe,IAAIhL,OAAOxF,cACrCyQ,GAAa2P,EAAGtS,aAAa,eAAiB,IAAI9N,cAClD+gB,GAAWX,EAAGtS,aAAa,aAAe,IAAI9N,cACpD,IAAA,MAAWghB,KAAQJ,EACjB,GACE3b,IAAS+b,GACTvQ,IAAcuQ,GACdD,IAAYC,GACZ/b,EAAKuY,SAASwD,GAEd,OAAOZ,CAGb,CACF,CAEA,OAAO,MAamBa,CAA0BlB,GAElD,GAAIE,EAAiB,CACnBzI,QAAQ0J,IAAI,sCAAuClB,EAAaC,EAAgB1Q,eAC1E2O,GAA0B+B,GAEhC,MAAMhB,EAASlC,GAAiBkD,GAShC,aARMnD,GAAWmC,EAAOzhB,EAAGyhB,EAAOnjB,GAElCmkB,EAAgBtC,cAAc,IAAIC,WAAW,cAAe,CAAEC,SAAS,EAAME,KAAMtP,UACnFwR,EAAgBtC,cAAc,IAAIC,WAAW,YAAa,CAAEC,SAAS,EAAME,KAAMtP,UACjFwR,EAAgBtC,cAAc,IAAIC,WAAW,YAAa,CAAEC,SAAS,EAAME,KAAMtP,UACjFwR,EAAgBtC,cAAc,IAAIC,WAAW,UAAW,CAAEC,SAAS,EAAME,KAAMtP,UAC/EwR,EAAgBb,SAlJO,CAACW,IAC5B,IACE,MAAM3c,EAAU,IAAI4L,IAAIP,OAAOQ,SAASF,MAClCgQ,EAAS,IAAI/P,IAAI+Q,GACvB,OAAO3c,EAAQ+d,SAAWpC,EAAOoC,QAAU/d,EAAQmd,WAAaxB,EAAOwB,QACzE,CAAA,MACE,OAAO,CACT,GA6IYa,CAAqBpB,EAC/B,CAGAxI,QAAQ0J,IAAI,wEAAyElB,GAGrF,IACE,MAAM5S,EAAS,IAAI4B,IAAIgR,GACvB,GACE5S,EAAO+T,SAAW1S,OAAOQ,SAASkS,QAClC/T,EAAOmT,WAAa9R,OAAOQ,SAASsR,UACpCnT,EAAOqT,KAGP,OADAhS,OAAOQ,SAASwR,KAAOrT,EAAOqT,MACvB,CAEX,CAAA,MAAyB,CAGzB,IACE,MAAMrT,EAAS,IAAI4B,IAAIgR,GACvB,GAAI5S,EAAO+T,SAAW1S,OAAOQ,SAASkS,OAAQ,CAE5C,MAAME,EAAUjU,EAAOmT,SAAWnT,EAAOoT,OAASpT,EAAOqT,KAGzD,OAFAhS,OAAO6S,QAAQC,UAAU,CAAA,EAAI,GAAIF,GACjC5S,OAAOkP,cAAc,IAAI6D,cAAc,WAAY,CAAExgB,MAAO,CAAA,MACrD,CACT,CACF,CAAA,MAAyB,CAIzB,OADAyN,OAAOQ,SAASF,KAAOiR,GAChB,CACT,OAAStI,GAEP,OADAF,QAAQG,KAAK,2BAA4BlV,EAAKyJ,IAAKwL,IAC5C,CACT,GAmDW+J,GAAwBxH,MACnCxX,IAEA,MAAMif,EAASjf,EAAKkf,QACpB,IACE,GAAkB,aAAdlf,EAAKmf,KAEP,aADM9C,GAAgBrc,GACf,CACLkf,QAASD,EACTG,OAAQ,uBAAuBpf,EAAK0c,UAIxC,GAAkB,WAAd1c,EAAKmf,KAEP,YAhTgB3H,OAAOxX,IAC3B,MAAMuc,EAAW9B,GAAsBza,EAAKqR,UAC5C,KAAMkL,aAAoBzQ,aAExB,YADAiJ,QAAQG,KAAK,wCAAwClV,EAAKqR,kBAItDqK,GAAkCa,GAAU,GAClD,MAAMC,EAASlC,GAAiBiC,SAC1BlC,GAAWmC,EAAOzhB,EAAGyhB,EAAOnjB,IAsSxBgmB,CAAcrf,GACb,CACLkf,QAASD,EACTG,OAAQ,4BAIZ,GAAkB,mBAAdpf,EAAKmf,KAA2B,CAElC,MAAO,CACLD,QAASD,EACTG,OAHc3K,KAGE/K,QAEpB,CAEA,GAAkB,aAAd1J,EAAKmf,KAAqB,OACtB9B,GAAgBrd,SAEhB,IAAIuB,QAASE,GAAYC,WAAWD,EAAS,OACnD,MAAMxG,EAAUwZ,KAChB,MAAO,CACLyK,QAASD,EACTG,OAAQ,yCAAyCpT,OAAOQ,SAASF,wBAAwBrR,EAAQyO,UAErG,CAEA,MAAO,CAAEwV,QAASD,EAAQG,OAAQ,mBACpC,OAASnK,GACP,MAAMqK,EAAMrK,aAAiBsK,MAAQtK,EAAMuK,QAAUjjB,OAAO0Y,GAE5D,OADAF,QAAQG,KAAK,iCAAiClV,EAAKmf,OAAQlK,GACpD,CAAEiK,QAASD,EAAQG,OAAQ,SAASE,IAC7C,GAGIG,GAAwC,KAC5C,GAAwB,oBAAb/f,UAA8C,oBAAXsM,OAC5C,OAGF,MAAMmO,EAASzB,KACVyB,GAAUA,EAAO1Q,MAAQuC,OAAOQ,SAASF,MAI9CuN,MAGsB,oBAAbna,WACmB,YAAxBA,SAASggB,WACXhgB,SAASjC,iBAAiB,mBAAoBgiB,GAAuC,CACnFE,MAAM,IAGRF,MC18BG,MAAMG,GAAyB,CAAC,IAAK,IAAK,MAE3CC,GAAyB,mBACzBC,OAA0BpX,IAChC,IAAIqX,GAA0B,EAE9B,MAAMC,GAAoBC,IACxB,MAAMnd,EAAUmd,EAAQld,OAAOzF,QAAQ,OAAQ,IAC/C,MAAI,gBAAgBJ,KAAK4F,GAChBA,EAGF,WAAWA,KAEdod,GAAiB,CAACD,EAAiBE,KACvC,MAAMC,EAAaJ,GAAiBC,GAC9BxW,EAAM,IAAI8C,IAAI6T,GAKpB,OAJA3W,EAAI4W,SAA4B,WAAjB5W,EAAI4W,SAAwB,OAAS,MACpD5W,EAAIqU,SAAW,GAAGrU,EAAIqU,SAASxgB,QAAQ,MAAO,MAAM6iB,IACpD1W,EAAIsU,OAAS,GACbtU,EAAIuU,KAAO,GACJvU,EAAI6W,YAyCAC,GAAuBtL,GACb,iBAAVA,GAAgC,OAAVA,KAAkB,cAAeA,IACzD5H,QAAS4H,EAAkCuL,WAKhDC,GAAiBjJ,MAAOkJ,IAC5B,IACE,MAAM3gB,QAAc2gB,EAASC,OACvBC,EAAS7gB,EAAK6gB,OACpB,MAAsB,iBAAXA,EAA4BA,EACnCA,GAA4B,iBAAXA,EAA4B/L,KAAKyB,UAAUsK,GACzD7gB,EAAKkV,OAASlV,EAAKyf,SAAWkB,EAASG,UAChD,CAAA,MACE,OAAOH,EAASG,UAClB,GAGIC,GAASC,GACb,IAAIxf,QAASE,IACXC,WAAWD,EAASsf,KAWlBC,GAA2BC,GAC/BlB,KAA4BkB,EAEjBC,GAA6B,IAAcnB,GAE3CoB,GAA0B,KACrCpB,IAA2B,EAC3B,MAAMqB,EAAS7nB,MAAM8Q,KAAKyV,IAC1B,IAAA,MAAWuB,KAAgBD,EACzB,IACEC,EAAanG,cAAc,IAAIiC,MAAM0C,KACrCwB,EAAaC,QACbD,EAAa1jB,gBAAgB,OAC7B0jB,EAAaE,MACf,CAAA,MAEA,GAISC,GAAsBC,IAEjC,MAAMC,EAAcD,EAAOnkB,QAAQ,2BAA4B,IACzDqkB,EAAeC,KAAKF,GACpBG,EAAQ,IAAIC,WAAWH,EAAaxmB,QAC1C,IAAA,IAASxC,EAAI,EAAGA,EAAIgpB,EAAaxmB,OAAQxC,GAAK,EAC5CkpB,EAAMlpB,GAAKgpB,EAAaI,WAAWppB,GAErC,OAAOkpB,GAsFHG,GAAoBxK,MACxByK,EACAC,EACAC,EAAqB,KACrBC,KAEA,MAAMC,EAAqBnB,KAC3B,GAAsB,IAAlBe,EAAO9mB,OAET,YADA,MAAAinB,GAAAA,EAAqB,SAIvB,GAAIpB,GAAwBqB,GAE1B,YADA,MAAAD,GAAAA,EAAqB,SAKvB,MAAME,EAAaL,EAAOM,OAAO,CAACC,EAAKxpB,IAAMwpB,EAAMxpB,EAAEypB,WAAY,GACjE1N,QAAQ0J,IAAI,mCAAmCwD,EAAO9mB,kBAAkBmnB,iBAA0BJ,KAElG,MAAAE,GAAAA,EAAqB,YAErB,MAAMM,EAA2BT,EAAOvhB,IAAKiiB,IAC3C,MAAMC,EAAS,IAAId,WAAWa,EAAMF,YAEpC,OADAG,EAAO5Y,IAAI2Y,GACJC,EAAOC,SAIhB,IAAIC,EAAeZ,EACnB,GAAID,EAAO9mB,OAAS,GAAK8mB,EAAO,GAAG9mB,QAAU,EAAG,CAC9C,MAAM4nB,EAASxpB,MAAM8Q,KAAK4X,EAAO,GAAGzkB,MAAM,EAAG,IAC1CkD,OAASpE,EAAEgkB,SAAS,IAAI0C,SAAS,EAAG,KAAK/F,eACzCxS,KAAK,KACRsK,QAAQ0J,IAAI,+BAA+BsE,KAGvCA,EAAOnV,WAAW,aAEXmV,EAAOnV,WAAW,UAAYmV,EAAOnV,WAAW,SADzDkV,EAAe,aAGNC,EAAOnV,WAAW,eAC3BkV,EAAe,YACNC,EAAOnV,WAAW,iBAC3BkV,EAAe,aAEnB,CAIA,IAAIG,EAAeH,GAAgBA,EAAa/H,SAAS,KAAO+H,EAAe,aAC3EI,EAA6BR,EAEjC,GAAiB,cAAbR,EAA0B,CAE5B,MACMa,EAlIc,EACtB5nB,EACAgnB,EAAqB,QAErB,MAAMU,EAAS,IAAIM,YAAY,IACzB7H,EAAO,IAAI8H,SAASP,GAsB1B,OAlBAvH,EAAK+H,UAAU,EAAG,YAAY,GAC9B/H,EAAK+H,UAAU,EAAG,GAAKloB,GAAQ,GAC/BmgB,EAAK+H,UAAU,EAAG,YAAY,GAG9B/H,EAAK+H,UAAU,GAAI,YAAY,GAC/B/H,EAAK+H,UAAU,GAAI,IAAI,GACvB/H,EAAKgI,UAAU,GAAI,GAAG,GACtBhI,EAAKgI,UAAU,GAXE,GAWY,GAC7BhI,EAAK+H,UAAU,GAAIlB,GAAY,GAC/B7G,EAAK+H,UAAU,GAbE,EAaElB,EAAwB,GAAG,GAC9C7G,EAAKgI,UAAU,GAAIC,GAAc,GACjCjI,EAAKgI,UAAU,GAAI,IAAI,GAGvBhI,EAAK+H,UAAU,GAAI,YAAY,GAC/B/H,EAAK+H,UAAU,GAAIloB,GAAQ,GAEpB,IAAI2mB,WAAWe,IAuGLW,CADKvB,EAAOM,OAAO,CAACC,EAAKxpB,IAAMwpB,EAAMxpB,EAAEypB,WAAY,GACtBN,GAC5Ce,EAAiB,CAACH,EAAOF,UAAWH,GACpCO,EAAe,YACflO,QAAQ0J,IAAI,wCAAwC0D,KACtD,CAEApN,QAAQ0J,IAAI,oCAAoCwE,gBAA2Bf,MAC3E,MAAMuB,EAAO,IAAIC,KAAKR,EAAgB,CAAEnpB,KAAMkpB,IAExC5B,EAAe,IAAIsC,MACnBC,EAAYrX,IAAIsX,gBAAgBJ,GAEtC,IASE,GAxM+B,CAACpC,IAClCvB,GAAoBlP,IAAIyQ,IA+LtByC,CAA2BzC,GAE3BA,EAAa0C,QAAU,OACvB1C,EAAa2C,UAAW,EAExB3C,EAAazjB,aAAa,cAAe,QACzCyjB,EAAa5d,IAAMmgB,EAEf5C,GAAwBqB,GAE1B,YADA,MAAAD,GAAAA,EAAqB,eAIjBf,EAAa4C,OACnB,MAAA7B,GAAAA,EAAqB,gBAhIE5K,OACzB6J,IAEIA,EAAa6C,aAIX,IAAI3iB,QAAc,CAACE,EAAS0iB,KAChC,MAAMC,EAAWpY,OAAOqY,YAAY,KAC7BhD,EAAa6C,OAChBnP,QAAQC,KAAK,gDAEd,KAEGsP,EAAU,KACdC,IACA9iB,KAGI+iB,EAAU,KACdD,IACAJ,EAAO,IAAI5E,MAAM,gCAGbkF,EAAe,KACnBF,IACA9iB,KAGI8iB,EAAU,KACdvY,OAAO0Y,cAAcN,GACrB/C,EAAa3jB,oBAAoB,QAAS4mB,GAC1CjD,EAAa3jB,oBAAoB,QAAS8mB,GAC1CnD,EAAa3jB,oBAAoBmiB,GAAwB4E,IAG3DpD,EAAa5jB,iBAAiB,QAAS6mB,GACvCjD,EAAa5jB,iBAAiB,QAAS+mB,GACvCnD,EAAa5jB,iBAAiBoiB,GAAwB4E,MA2FhDE,CAAmBtD,GACzB,MAAAe,GAAAA,EAAqB,OACvB,OAASwC,GAGP,MAFA7P,QAAQE,MAAM,4BAA4B2P,IAAO,CAAE1C,SAAUe,EAAc7Y,KAAMqZ,EAAKrZ,OACtF,MAAAgY,GAAAA,EAAqB,QACfwC,CACR,CAAA,QAjNmC,CAACvD,IACpCvB,GAAoB3J,OAAOkL,IAiNzBwD,CAA6BxD,GAC7BA,EAAaC,QACbD,EAAa1jB,gBAAgB,OAC7B0jB,EAAaE,OACbhV,IAAIuY,gBAAgBlB,EACtB,GAQWmB,GAAwBC,IACnC,MAAMC,EAAYD,EACf1Z,MAAM,SACN5K,IAAKmT,GAASA,EAAK9Q,QACnBf,OAAQ6R,GAASA,EAAKjG,WAAW,UACjClN,IAAKmT,GAASA,EAAKrW,MAAM,GAAG0nB,aAE/B,GAAyB,IAArBD,EAAU9pB,OACZ,OAAO,KAGT,MAAMgqB,EAAUF,EAAUxa,KAAK,MAC/B,GAAgB,WAAZ0a,EACF,MAAO,CAAEprB,KAAM,QAGjB,IACE,OAAO8a,KAAKC,MAAMqQ,EACpB,OAASlQ,GAEP,OADAF,QAAQG,KAAK,2BAA4BD,GAClC,IACT,GAGWmQ,GACXtM,GAEyB,iBAAlBA,EAAQuM,aACG,IAAjBvM,EAAQ/e,MAAuC,UAAjB+e,EAAQ/e,MA6ClC,MAAMurB,GAA0B,CACrCrF,EACAsF,EAMAC,EAAsB,CAAA,KAEtB,MAAMC,EAAQvF,GAAeD,EAAS,gBACtClL,QAAQC,KAAK,+BAAgCyQ,GAC7C,MAAMC,EAAS,IAAIC,UAAUF,GAC7B,IAAIG,EAAM,EACNC,EAAY,GACZC,EAAiBP,EAAOQ,WAAa,GACrCC,GAAU,EACVC,GAAU,EAGVC,EAA2B3kB,QAAQE,UAEnC0kB,EAAoC,KACpCC,EAAyE,KAC7E,MAAMC,EAAe,IAAI9kB,QAAc,CAACE,EAAS0iB,KAC/CgC,EAAe1kB,EACf2kB,EAAcjC,IAGhB,IAAImC,EAAsD,KACtDC,EAAwE,KAC5E,MAAMC,EAAc,IAAIjlB,QAAqB,CAACE,EAAS0iB,KACrDmC,EAAc7kB,EACd8kB,EAAapC,IAGTsC,EAAaxR,IACbgR,IACJA,GAAU,EACVlR,QAAQG,KAAK,2BAA4BD,EAAMuK,SAC/C,MAAA4G,GAAAA,EAAcnR,GACd,MAAAsR,GAAAA,EAAatR,KAGTyR,EAAwB,KACxBT,GACCJ,EAAU9iB,QAAW+iB,IAC1BG,GAAU,EACV,MAAAE,GAAAA,IACA,MAAAG,GAAAA,EAAc,CACZ9jB,KAAMqjB,EAAU9iB,OAChB4jB,WAAYb,MA8EhB,OA1EAJ,EAAOkB,OAAS,WACd7R,QAAQC,KAAK,2CACb,OAAAc,EAAA0P,EAAOqB,gBAAP/Q,EAAA9V,KAAAwlB,GACAE,EAAOoB,KACLjS,KAAKyB,UAAU,CACbvc,KAAM,QACNgtB,WAAYxB,EAAOyB,UACnBL,WAAYpB,EAAOQ,gBAAa,EAChCkB,SAAU1B,EAAO0B,UAAY,KAC7BC,UAAW3B,EAAOrD,UAAY,iBAKpCwD,EAAOyB,UAAarpB,cAClB,MAAMgb,EA5Z4B,CACpC3a,IAEA,IACE,MAAqB,iBAAVA,EACF,KAEF0W,KAAKC,MAAM3W,EACpB,CAAA,MACE,OAAO,IACT,GAkZkBipB,CAAuB7qB,OAAOuB,EAAMiC,OACpD,GAAK+Y,EAAL,CAEA,GAAqB,cAAjBA,EAAQ/e,MAAsD,iBAAvB+e,EAAQ6N,WAKjD,OAJA5R,QAAQC,KAAK,8CAA+C8D,EAAQ6N,YACpEb,EAAiBhN,EAAQ6N,WACzB,OAAA7Q,EAAA0P,EAAO6B,uBAAcvO,EAAQ6N,iBAC7B,MAAAR,GAAAA,KAIF,GAAqB,YAAjBrN,EAAQ/e,MAA8C,iBAAjB+e,EAAQtW,KAAjD,CAQA,GAAqB,UAAjBsW,EAAQ/e,MAA4C,iBAAjB+e,EAAQtW,KAO7C,OANAuS,QAAQC,KAAK,sCAAuC8D,EAAQtW,KAAKhF,MAAM,EAAG,KAC1EqoB,EAAY/M,EAAQtW,UACc,iBAAvBsW,EAAQ6N,aACjBb,EAAiBhN,EAAQ6N,WACzB,OAAA7L,EAAA0K,EAAO6B,uBAAcvO,EAAQ6N,cAKjC,GAAqB,SAAjB7N,EAAQ/e,KAIV,OAHAgb,QAAQC,KAAK,uBACb0R,SACAhB,EAAO4B,QAIT,GAAqB,UAAjBxO,EAAQ/e,KAAkB,CAC5Bgb,QAAQE,MAAM,+BAAgC6D,EAAQ7D,OACtD,MAAM2P,EAAM2C,GAAWzO,EAAQ7D,OAAS,gBAAsC,IAAtB6D,EAAQ0H,WAChEiG,EAAU7B,GACVc,EAAO4B,OACT,CAxBA,MALE,OAAAzM,EAAA2K,EAAOgC,YAAP3M,EAAA7a,KAAAwlB,EAAmB,CACjBI,IAA4B,iBAAhB9M,EAAQ8M,IAAmB9M,EAAQ8M,IAAM,EACrDpjB,KAAMsW,EAAQtW,MAbJ,GA2ChBkjB,EAAO+B,QAAWC,IAChB3S,QAAQE,MAAM,iCAAkCyS,GAChDjB,EAAUc,GAAW,0BAA0B,KAGjD7B,EAAOiC,QAAWD,IAChB3S,QAAQC,KAAK,0CAA2C0S,EAAGE,KAAMF,EAAGG,QAChE5B,IACAJ,GAAaC,EACfY,IAGFD,EAAUc,GAAW,6BAA6B,MAG7C,CACLO,UAAYnF,GACNqD,GAA0B,IAAfrD,EAAMvY,KAAmB7I,QAAQE,WAIhDykB,EAAYA,EAAU5mB,KAAKkY,UACzB,GAAIwO,EAAS,OAEb,SADMK,EACFL,EAAS,OACb,MAAMX,OAhZO7N,OAAOiM,IAC1B,MAAM5B,EAAQ,IAAIC,iBAAiB2B,EAAKsE,eAExC,IAAIC,EAAS,GACb,IAAA,IAASrvB,EAAI,EAAGA,EAAIkpB,EAAM1mB,OAAQxC,GAFhB,MAGhBqvB,GAAUzrB,OAAO0rB,gBAAgBpG,EAAMqG,SAASvvB,EAAGA,EAHnC,QAKlB,OAAOwvB,KAAKH,IAyYcI,CAAazF,GACjCiD,GAAO,EACHI,GAAWN,EAAOhG,aAAeiG,UAAU0C,OAC/CtT,QAAQuT,MAAM,8CAA+C1C,EAAKjD,EAAMvY,MACxEsb,EAAOoB,KAAKjS,KAAKyB,UAAU,CAAEvc,KAAM,QAAS6rB,MAAKP,cAE5Ca,GAETqC,KAAM,KACJxT,QAAQC,KAAK,4DAA6D4Q,GAG1EM,EAAYA,EAAU5mB,KAAKkY,gBACnB6O,EACFL,GACAN,EAAOhG,aAAeiG,UAAU0C,OAClCtT,QAAQC,KAAK,2CAA4C4Q,GACzDF,EAAOoB,KAAKjS,KAAKyB,UAAU,CAAEvc,KAAM,aAGhCysB,GAETgC,OAAQ,KACNxC,GAAU,EACV,IACEN,EAAO4B,OACT,CAAA,MAEA,KAWAC,GAAa,CAAC/H,EAAiBgB,GAAqB,KACxD,MAAMvL,EAAQ,IAAIsK,MAAMC,GAExB,OADAvK,EAAMuL,UAAYA,EACXvL,GAGHwT,GAAmBjR,MACvByI,EACAyI,EACAC,EACAC,EACAC,EACAC,WAEA,MAAMC,EAAc,IAAIC,SACxBD,EAAYE,OAAO,OAAQP,GAC3BK,EAAYE,OAAO,QAASN,GAC5BI,EAAYE,OAAO,qBAAsB1sB,OAAOqsB,IAEhD,MAAMM,QAAoBC,MAAM,GAAGnJ,GAAiBC,cAAqB,CACvEmJ,OAAQ,OACRje,KAAM4d,IAGR,IAAKG,EAAYG,GACf,MAAM9B,SAAiB9G,GAAeyI,IAAc,GAGtD,MAAMI,EAAS,OAAAxT,EAAAoT,EAAY/d,WAAZ,EAAA2K,EAAkByT,YACjC,IAAKD,EACH,MAAM/B,GAAW,qCAAqC,GAGxDuB,EAAUQ,GAEV,MAAMrH,EAAoC,GAC1C,IAAIC,EAAW,aACXC,EAAa,KACjB,MAAMqH,EAAU,IAAIC,YACpB,IAAI5G,EAAS,GAEb,MACMgG,KADO,CAKX,MAAMa,KAAEA,EAAAvrB,MAAMA,SAAgBmrB,EAAOK,OACrC,GAAID,EACF,MAGF7G,GAAU2G,EAAQI,OAAOzrB,EAAO,CAAE0rB,QAAQ,IAC1C,MAAMC,EAASjH,EAAOvX,MAAM,cAC5BuX,EAASiH,EAAOC,OAAS,GAEzB,IAAA,MAAWC,KAASF,EAAQ,CAC1B,MAAMhR,EAAUiM,GAAqBiF,GACrC,GAAKlR,GAIDsM,GAAkBtM,GAAU,CAC9B,MAAMmR,EAASnR,EAAQmR,QAAU,MACjC/H,EAAWpJ,EAAQoO,YAAyB,SAAX+C,EAAoB,aAAe,cACpEhI,EAAOzmB,KAAKgmB,GAAmB1I,EAAQuM,QACnCvM,EAAQoR,cACV/H,EAAarJ,EAAQoR,YAEzB,CACF,CACF,CAKA,OAHAZ,EAAOa,cACPrB,OAAU,GAEH,CAAE7G,SAAQC,WAAUC,eAGvBiI,GAAyB5S,MAC7ByI,EACAyI,EACAC,EACAC,EACAC,EACAwB,KAEA,MAAM5E,EAAQvF,GAAeD,EAAS,gBAChCqK,EAlnBgB,oBAAXC,QAA0B,eAAgBA,OAC5CA,OAAOC,aAET,OAAOxU,KAAKC,SAASqB,KAAKmT,SAASnK,SAAS,IAAI9iB,MAAM,KAgnBvDykB,EAAoC,GAC1C,IAAIC,EAAW,aACXC,EAAa,KACbuI,EAAiB,EAErB,MAAMC,EAAc,IAClB,IAAIppB,QAAQ,CAACE,EAAS0iB,KACpB,GAAI0E,IAEF,YADA1E,EAAOoD,GAAW,kBAAkB,IAItC,IAAImC,GAAO,EACPkB,EAAuD,KAC3D,MAAMlF,EAAS,IAAIC,UAAUF,GAC7B4E,EAAU3E,GAEV,MAAMmF,EAAW,CACfC,EACA7V,KAEAyQ,EAAOkB,OAAS,KAChBlB,EAAOyB,UAAY,KACnBzB,EAAO+B,QAAU,KACjB/B,EAAOiC,QAAU,KACjB0C,EAAU,MACG,YAATS,EAIJ3G,EAAOlP,GAASsS,GAAW,iBAAiB,IAH1C9lB,KAMJikB,EAAOkB,OAAS,KACd7R,QAAQC,KACN,uCAAuCsV,gBAAwBI,KAEjEhF,EAAOoB,KACLjS,KAAKyB,UAAU,CACbvc,KAAM,QACNgxB,WAAYT,EACZ9nB,KAAMkmB,EACNC,QACAqC,mBAAoBpC,EACpBqC,SAAUP,MAKhBhF,EAAOyB,UAAarpB,IAClB,MAAMgb,EA/pBwB,CACpC3a,IAEA,IACE,MAAqB,iBAAVA,EACF,KAEF0W,KAAKC,MAAM3W,EACpB,CAAA,MACE,OAAO,IACT,GAqpBsB+sB,CAAuB3uB,OAAOuB,EAAMiC,OACpD,GAAK+Y,EAAL,CAKA,GAAqB,UAAjBA,EAAQ/e,MAA6C,iBAAlB+e,EAAQuM,MAAoB,CACjE,MAAMO,EAA6B,iBAAhB9M,EAAQ8M,IAAmB9M,EAAQ8M,IAAM,EAyB5D,MArqB0B,EAClCuF,EACAT,IACYS,EAAcT,EA0oBdU,CAAqBxF,EAAK8E,IAC5BzI,EAAOzmB,KAAKgmB,GAAmB1I,EAAQuM,QACvCqF,EAAiB9E,EACb9M,EAAQoO,YACVhF,EAAWpJ,EAAQoO,WAEc,iBAAxBpO,EAAQoR,cACjB/H,EAAarJ,EAAQoR,cAGvBnV,QAAQC,KACN,qDAAqDsV,SAAiB1E,UAAY8E,UAIlFhF,EAAOhG,aAAeiG,UAAU0C,MAClC3C,EAAOoB,KACLjS,KAAKyB,UAAU,CACbvc,KAAM,MACNgxB,WAAYT,EACZW,SAAUP,KAKlB,CAEA,GAAqB,SAAjB5R,EAAQ/e,KAAiB,CAG3B,OAD8B,iBAArB+e,EAAQmS,SAAwBnS,EAAQmS,SAAWP,GACxCA,GAClBE,EAAarD,GAAW,uBAAuB,GAC/CmC,GAAO,OACPhE,EAAO4B,UAGToC,GAAO,OACPhE,EAAO4B,QAET,CAEqB,UAAjBxO,EAAQ/e,OACV6wB,EAAarD,GAAWzO,EAAQ7D,OAAS,gBAAsC,IAAtB6D,EAAQ0H,WACjEkJ,GAAO,EACPhE,EAAO4B,QAhDT,MAFEvS,QAAQG,KAAK,wCAsDjBwQ,EAAO+B,QAAU,KACVmD,IACHA,EAAarD,GAAW,0BAA0B,KAItD7B,EAAOiC,QAAU,KACXkB,IACFgC,EAAS,SAAUtD,GAAW,kBAAkB,IAG9CmC,EACFmB,EAAS,WAGXA,EAAS,SAAUD,GAAcrD,GAAW,6BAA6B,OAI/E,IAAA,IAAS8D,EAAU,EAAGA,GAAWzL,GAAuBzkB,OAAQkwB,GAAW,EAAG,CAC5E,GAAIA,EAAU,EAAG,CACf,MAAMC,EAAQ1L,GAAuByL,EAAU,GAC/CtW,QAAQG,KACN,gCAAgCmW,cAAoBC,cAAkBZ,WAElE5J,GAAMwK,EACd,CAEA,IAEE,aADMX,IACC,CAAE1I,SAAQC,WAAUC,aAC7B,OAASlN,GACP,MAAMuL,EACJD,GAAoBtL,GAChBuK,EAAUvK,aAAiBsK,MAAQtK,EAAMuK,QAAUjjB,OAAO0Y,GAIhE,GAHAF,QAAQG,KACN,yCAAyCmW,eAAqB7K,WAAmBhB,MAE9EgB,GAAa6K,IAAYzL,GAAuBzkB,OACnD,MAAM8Z,CAEV,CACF,CAEA,MAAMsS,GAAW,oBAAoB,IAyC1BgE,GAAY/T,MACvByI,EACAzd,EACAmmB,EACAC,EACAxG,KAEA,MAAMtf,EAAUN,EAAKO,OACrB,IAAKD,EAAS,OACd,MAAMuf,EAAqBnB,KAI3B,IAAIsK,EAFJzW,QAAQC,KAAK,4BAA4BlS,EAAQ3H,iBACjD,MAAAinB,GAAAA,EAAqB,aAGrB,MAAMqJ,EAAe,KAAM,EAE3B,IACED,QAAkBpB,GAChBnK,EAASnd,EAAS6lB,EAAOC,EACzB6C,EACA,OAEJ,CAAA,MACED,QAAkB/C,GAChBxI,EAASnd,EAAS6lB,EAAOC,EACzB6C,EACA,OAEJ,CAEIzK,GAAwBqB,GAC1B,MAAAD,GAAAA,EAAqB,QAInBoJ,EAAUvJ,OAAO9mB,OAAS,QACtB6mB,GACJwJ,EAAUvJ,OAAQuJ,EAAUtJ,SAAUsJ,EAAUrJ,WAChDC,GAGF,MAAAA,GAAAA,EAAqB,SAMZsJ,GAAuB,CAClCzL,EACA0L,EACA3E,EACAjB,EACAR,EAMAC,EACAoG,KAEA,IAEIC,EAFAhD,GAAY,EACZiD,EAAiC,KAEjCC,GAAe,EAEnB,MAAMvF,EAAc,IAAIjlB,QAAciW,MAAO/V,EAAS0iB,iBACpD,IAEE,GAAI0E,SAAkBpnB,IACtB,MAAMuqB,QAzjBZxU,eACEyI,EACAgM,EACAjF,EACAjB,EACAkB,EACAJ,GAEA,MAAMpd,EAAM,GAAGuW,GAAiBC,cAC1BiM,EAAW,IAAIlD,SACrBkD,EAASjD,OAAO,OAAQgD,GACxBC,EAASjD,OAAO,aAAcjC,GAC1BjB,GAAWmG,EAASjD,OAAO,aAAclD,GAC7CmG,EAASjD,OAAO,WAAYhC,GAE5B,MAAMkF,EAAkBhD,MAAM1f,EAAK,CAAE2f,OAAQ,OAAQje,KAAM+gB,IAC3D,MAAArF,GAAAA,IACA,MAAMnG,QAAiByL,EACvB,IAAKzL,EAAS2I,GACZ,MAAM,IAAI9J,YAAYkB,GAAeC,IAEvC,OAAOA,EAASC,MAClB,CAmiB8ByL,CACtBnM,EACA0L,EACA3E,EACAjB,EACA,KACAP,EAAO6G,kBAGHC,EAAmBN,EAAUrF,WACnC,IAAI4F,EAAqBD,EACzB,MAAME,EAAWR,EAAUxpB,KAO3B,GALA,OAAAsT,EAAA0P,EAAOiH,kBAAP3W,EAAA9V,KAAAwlB,EAAyB,CACvBmB,WAAY2F,EACZI,UAAWF,IAGT3D,SAAkBpnB,IAGtB,MAAMinB,QAAsB,IAAInnB,QAAgB,CAACorB,EAAcC,KAC7D,GAAI/D,EAA+B,YAAlB8D,EAAa,IAE9B,MAAMlH,EAAQvF,GAAeD,EAAS,kBAChCyF,EAAS,IAAIC,UAAUF,GAC7BqG,EAAepG,EAEf,IAAImH,EAAa,GACbC,GAAW,EACXC,EAAmB,GAEvB,MAAMC,EAAUC,IACVH,IACJA,GAAW,EACXH,EAAaM,KAGTC,EAAQjY,IACR6X,IACJA,GAAW,EACXF,EAAY3X,KAGdyQ,EAAOkB,OAAS,KACd7R,QAAQC,KAAK,8BACb0Q,EAAOoB,KAAKjS,KAAKyB,UAAU,CACzBvc,KAAM,QACNgtB,WAAYC,EACZL,WAAY2F,EACZI,UAAWF,EACXW,MAAO5H,EAAO4H,MACdC,aAAc7H,EAAO8H,YACrBrC,mBAAoBzF,EAAOqD,sBAI/BlD,EAAOyB,UAAY3P,MAAO1Z,0BACxB,IAAIiC,EACJ,IACEA,EAAO8U,KAAKC,MAAMvY,OAAOuB,EAAMiC,MACjC,CAAA,MAEE,YADAgV,QAAQG,KAAK,gCAEf,CAEA,MAAMoY,EAAUvtB,EAAKhG,KAErB,GAAgB,YAAZuzB,GAAoD,iBAApBvtB,EAAK4mB,WAGvC,OAFA4F,EAAqBxsB,EAAK4mB,gBAC1B,OAAA7Q,EAAA0P,EAAO6B,cAAPvR,EAAA9V,KAAAwlB,EAAqB+G,IAIvB,GAAgB,cAAZe,EAAJ,CAQA,GAAgB,gBAAZA,GAAmD,iBAAfvtB,EAAK8X,MAG3C,OAFAkV,GAAoBhtB,EAAK8X,WACzB,OAAAiD,EAAA0K,EAAO+H,mBAAPzS,EAAA9a,OAA0BD,EAAK8X,QAIjC,GAAgB,eAAZyV,GAA4B/zB,MAAMC,QAAQuG,EAAKytB,OAAQ,CACzD,MAAMA,EAAQztB,EAAKytB,MAGfT,EAAiBhqB,SACnB,OAAA0qB,EAAAjI,EAAOkI,sBAAPD,EAAAztB,KAAAwlB,EAA6BuH,EAAiBhqB,SAEhDgqB,EAAmB,GAEnB,OAAAY,EAAAnI,EAAOoI,cAAPD,EAAA3tB,KAAAwlB,EAAqBgI,GAErB,MAAMK,EAAiD,GACvD,IAAA,MAAW7tB,KAAQwtB,EAAO,CAExB,MAAMM,EAA2B,aAAd9tB,EAAKmf,KACpB2O,GACFhX,GAAuB,CACrBiP,UAAWwG,EACXvF,YACAmG,MAAO5H,EAAO4H,MACdxE,MAAOpD,EAAOoD,MACdC,kBAAmBvb,QAAQkY,EAAOqD,mBAClCmF,iBAAkBP,EAAM9sB,IAAK1H,IAAAA,CAC3BkmB,QAASlmB,EAAEkmB,QACXC,KAAMnmB,EAAEmmB,KACR6O,KAAMh1B,EAAEg1B,QAEVC,iBAAkB,IAAIJ,KAI1B,MAAMzO,QAAewM,EAAY5rB,GAG7B8tB,GACF7W,KAGF,OAAAiX,EAAA1I,EAAO2I,eAAPD,EAAAluB,KAAAwlB,EAAsBxlB,EAAKkf,QAASlf,EAAKmf,KAAMC,EAAOA,QACtDyO,EAAQryB,KAAK4jB,EACf,CAQA,YANIsG,EAAOhG,aAAeiG,UAAU0C,MAClC3C,EAAOoB,KAAKjS,KAAKyB,UAAU,CACzBvc,KAAM,eACN8zB,aAIN,CAEA,GAAgB,eAAZP,EAOF,OANAT,EAAc9sB,EAAKquB,aAA0B,GAC7C,OAAAC,EAAA7I,EAAO8I,kBAAPD,EAAAruB,KAAAwlB,EAAyBqH,GACM,iBAApB9sB,EAAK4mB,aACd,OAAA4H,EAAA/I,EAAO6B,uBAActnB,EAAK4mB,kBAE5BqG,EAAOH,GAIT,GAAgB,UAAZS,EAAqB,CACvB,MAAMkB,EAAUzuB,EAAKkV,OAAoB,cAIzC,OAHA8W,GAAe,EACf,OAAA0C,EAAAjJ,EAAOhB,UAAPiK,EAAAzuB,KAAAwlB,EAAiBgJ,QACjBtB,EAAK,IAAI3N,MAAMiP,GAEjB,CA3EA,MALE,OAAA3T,EAAA2K,EAAOkJ,cAAP7T,EAAA7a,KAAAwlB,EACEzlB,EAAK4uB,UACL5uB,EAAK6uB,iBAiFXlJ,EAAO+B,QAAU,WACf1S,QAAQE,MAAM,0BACd8W,GAAe,EACf,OAAAjW,EAAA0P,EAAOhB,UAAP1O,EAAA9V,KAAAwlB,EAAiB,oCACjB0H,EAAK,IAAI3N,MAAM,sCAGjBmG,EAAOiC,QAAU,KACf5S,QAAQC,KAAK,2BACbgY,EAAOH,MAOX,GAHAf,EAAe,KAGXjD,IAAcH,EAIhB,OAHKG,GACHzP,KAEK3X,IAQT,IAAI+pB,EALJzW,QAAQC,KACN,sCAAsCuQ,EAAOoD,SAG/C,OAAA9N,EAAA2K,EAAOpD,qBAAPvH,EAAA7a,KAAAwlB,EAA4B,aAG5B,IACEgG,QAAkBpB,GAChBnK,EACAyI,EACAnD,EAAOoD,MACPtb,QAAQkY,EAAOqD,mBACf,IAAMC,EACLnD,IAAaoG,EAAepG,GAEjC,OAASmJ,GACP,GAAIhG,SAAkBpnB,IACtBsT,QAAQG,KACN,+CAA+C2Z,aAAmBtP,MAAQsP,EAAQrP,QAAUjjB,OAAOsyB,MAErGrD,QAAkB/C,GAChBxI,EACAyI,EACAnD,EAAOoD,MACPtb,QAAQkY,EAAOqD,mBACf,IAAMC,EACLS,IAAauC,EAAevC,GAEjC,EAEKT,GAAa2C,EAAUvJ,OAAO9mB,OAAS,QACpC6mB,GACJwJ,EAAUvJ,OACVuJ,EAAUtJ,SACVsJ,EAAUrJ,WACVqD,EAAOpD,oBAGT,OAAAtH,EAAA0K,EAAOpD,qBAAPtH,EAAA9a,KAAAwlB,EAA4B,QAGzBqD,GACHzP,KAEF3X,GACF,OAASmjB,GAEP,IAAKmH,EAAc,CACjB,MAAMzM,EAAMsF,aAAerF,MAAQqF,EAAIpF,QAAUjjB,OAAOqoB,GACxD,OAAA6I,EAAAjI,EAAOhB,UAAPiJ,EAAAztB,KAAAwlB,EAAiBlG,EACnB,CACA6E,EAAOS,EACT,CAAA,QACE,MAAAiH,GAAAA,EAAcrD,SAASsG,MAAM,QACzBhD,GAAgBA,EAAapM,YAAciG,UAAU0C,MACvDyD,EAAaxE,QAEfwE,EAAe,IACjB,IAGF,MAAO,CACLvD,KAAM,KACJM,GAAY,EACZ1H,KACI0K,GACFA,EAAarD,SAASsG,MAAM,QAE1BhD,GAAgBA,EAAapM,YAAciG,UAAU0C,MACvDyD,EAAaxE,SAGjBoC,KAAMlD,IC/rCJuI,GAAuC,CAC3CC,KCVa,806DDWbC,SEXa,0imEFYbC,SGZa,8j0DHabC,UIba,uwxEJoEf,MAAMC,GAAa,IApDnB,MAAA,WAAA50B,GACU60B,EAAAr0B,KAAA,QAAmB,IACnBq0B,EAAAr0B,KAAA,UAAS,EAAA,CAET,OAAAs0B,CAAQnvB,GACd,OAAO,IAAIoB,QAASE,IAClB,GAAsB,oBAAXuK,OAET,YADAvK,IAIF,MAAM4jB,EAAQ,IAAI1B,MAAMoL,GAAY5uB,IACpCklB,EAAMtB,QAAU,OAEhB,IAAIkC,GAAU,EACd,MAAM4E,EAAW,KACX5E,IACJA,GAAU,EACVZ,EAAMkK,QAAU,KAChBlK,EAAMoC,QAAU,KAChBhmB,MAGF4jB,EAAMkK,QAAU1E,EAChBxF,EAAMoC,QAAUoD,EACXxF,EAAMpB,OAAO6K,MAAM,IAAMjE,MAElC,CAEA,WAAc2E,GACZ,IAAIx0B,KAAKomB,OAAT,CACApmB,KAAKomB,QAAS,EACd,IACE,KAAOpmB,KAAKy0B,MAAMt0B,OAAS,GAAG,CAC5B,MAAMu0B,EAAO10B,KAAKy0B,MAAM5zB,QACnB6zB,SACC10B,KAAKs0B,QAAQI,EACrB,CACF,CAAA,QACE10B,KAAKomB,QAAS,CAChB,CAViB,CAWnB,CAEA,OAAAuO,CAAQxvB,GACgB,oBAAX6L,SACXhR,KAAKy0B,MAAMj0B,KAAK2E,GACXnF,KAAKomB,QACHpmB,KAAKw0B,QAEd,GKYII,GAAc,qBACdC,GAAgB,uBAChBC,GAAiB,mBACjBC,GAAS,IAKTC,GACG,QADHA,GAEK,aAFLA,GAGO,WAHPA,GAIU,uBAJVA,GAKM,YALNA,GAMU,kBANVA,GAOU,sBAGHC,GAAmBC,GAC9B,gBAAgBA,sCAYLC,GAAqBC,GAC5BA,EAAMjrB,YAAoB6qB,GAC1BI,EAAMC,eAAuBL,GAC7BI,EAAME,eAAuBN,GAC7BI,EAAMG,WAAmBP,GACzBI,EAAMI,eAAuBR,GAC7BI,EAAMhrB,OAAe4qB,GAClBA,GAkBIS,GAAoB/Y,IAC/B,MAAMgZ,EAAepZ,KAAKD,IAAI,EAAGC,KAAKqZ,MAAMjZ,EAAa,MAKzD,MAAO,GAJSJ,KAAKqZ,MAAMD,EAAe,IACvCpQ,WACA0C,SAAS,EAAG,SACE0N,EAAe,IAAIpQ,WAAW0C,SAAS,EAAG,QAShD4N,GAAyBV,GAAiC,CACrE,CACEnjB,GAAI,EACJvK,KAAMytB,GAAgBC,GACtBW,QAAQ,IAICC,GAA2BC,IACjCA,IAILA,EAAQ7Z,WAAW0Y,IACnBmB,EAAQ7Z,WAAW2Y,IACnBkB,EAAQ7Z,WAAW4Y,MAoBfkB,GAAoBC,GACVA,EAAS1O,OAAO,CAACC,EAAKhD,IAAYlI,KAAKD,IAAImL,EAAKhD,EAAQzS,IAAK,GAC5D,EAkBJmkB,GAA6B,CACxCtI,EACAzjB,EACAC,IACYwjB,IAAsBzjB,IAAgBC,EAEvC+rB,GAAa,EACxB3pB,UACA+d,SACAqD,qBAAoB,EACpBwI,wBACArlB,UAAS,EACTslB,aACAC,oBACAC,eACAC,sBAEA,MAAOP,EAAUQ,GAAeC,GAAoB,KAClD,GAA4B,oBAAjB3a,aAA8B,CACvC,MAAM4a,EAAQ5a,aAAanC,QAAQgb,IAC7BgC,EAAY7a,aAAanC,QAAQib,IAEvC,GAAI8B,GAASC,EAAW,CAEtB,GADmB5b,KAAKC,MAAQhT,SAAS2uB,EAAW,IACnC7B,GACf,IACE,OAAOlb,KAAKC,MAAM6c,EACpB,CAAA,MAEA,MAEAb,GAAwB/Z,aAE5B,CACF,CAEA,OAAO6Z,GAAsBrL,EAAO2K,cAG/B9qB,EAAQysB,GAAaH,IAAS,IAC9BvsB,EAAa2sB,GAAkBJ,IAAS,IACxClB,EAAgBuB,GAAqBL,IAAS,IAC9CnB,EAAYyB,GAAiBN,IAAS,IACtCO,EAAkBC,GAAuBR,IAAS,IAClDpB,EAAgB6B,GAAqBT,IAAS,IAC9CrB,EAAgB+B,GAAqBV,IAAS,IAC9CW,EAAqBC,GAA0BZ,GAAS,IACxDa,EAAgBC,GAAqBd,GAAwB,MAC9De,EAA2B,CAC/BrtB,SACAD,cACAqrB,iBACAD,aACA0B,mBACA3B,iBACAD,kBAEIqC,EAAqBvC,GAAkBsC,GACvCE,EA9IuB,EAC7BvC,EACAmC,IAEAllB,QACEklB,GACGnC,EAAMhrB,QACNgrB,EAAMjrB,aACNirB,EAAMI,gBACNJ,EAAMG,YACNH,EAAM6B,kBACN7B,EAAME,gBACNF,EAAMC,gBAkIQuC,CAAgBH,EAAaF,GAC1C1R,EAAa8R,EAAcJ,GAAkBG,EAAsB1C,GAEnE6C,EAAYC,GAAO1tB,GACnB2tB,EAAiBD,GAAO3tB,GAExB6tB,EAAmBF,GAAO9B,GAAiBC,IAC3CgC,EAAcH,GAA6B,MAC3CI,EAAYJ,GAA2B,MACvCK,EAAiBL,GAAmB,IACpCM,EAA4BN,GAAgC,MAC5DO,EAAeP,GACK,oBAAjB/b,aAAiB,MAElB,MAAMuc,EAAKvc,aAAanC,QAAQib,IAChC,OAAIyD,GAAMtd,KAAKC,MAAQhT,SAASqwB,EAAI,IAAMvD,GACjChZ,aAAanC,QAAQkb,IAEvB,MANW,GAQpB,MAGAyD,EAAkBT,GAAsB,MACxCU,EAAiBV,GAAsB,MACvCW,EAAkBX,GAA4B,MAC9CY,EAAYZ,GAA0C,MAEtDa,EAA0Bb,IAAO,GAEjCc,EAAmBd,GAAsB,MACzCe,EAAoBf,GAAsB,MAC1CgB,EAAsBhB,IAAO,GAC7BiB,EAAmBjB,GAA6B,MAChDkB,GAA2BlB,IAAO,GAClCmB,GAA2BnB,IAAO,GAElCoB,GAAwBpB,GAAsB,MAC9CqB,GAAyBrB,GAAO,IAChCsB,GAA2BtB,IAAO,GAClCuB,GAA2BvB,IAAO,GAElCwB,GAAwBxB,GAAsB,MAC9CyB,GAA4BzB,GAAsB,MAElD0B,GAAuB1B,GAA8B,MACrD2B,GAAqB3B,GAA8B,MAEnD4B,GAAqB5B,GAAsB,MAC3C6B,GAA0B7B,GAAe,IACzC8B,GAAyB9B,GAAmC,MAC5D+B,GAA+B/B,IAAO,GACtCgC,GAAiBhC,GAA+B,MAChDiC,GAAgCjC,GAAsB,MACtDkC,GAA2BlC,GAAO,IAClCmC,GAA0BnC,IAAO,GACjCoC,GAAkBpC,GAAO,GACzBqC,GAAsBrC,IAAO,GAEnCsC,GAAU,KACRvC,EAAUlyB,QAAUyE,GACnB,CAACA,IAEJgwB,GAAU,KACRrC,EAAepyB,QAAUwE,GACxB,CAACA,IAGJiwB,GAAU,KAAQ,MAAA9D,GAAAA,EAAoBnsB,IAAiB,CAACA,IACxDiwB,GAAU,KAAQ,MAAA7D,GAAAA,EAAensB,IAAY,CAACA,IAG9CgwB,GAAU,KACR,IAAK5D,EAAiB,OACtB,GAAIrsB,EAEF,YADAqsB,EAAgBxB,IAIlB,GAAIiC,GAAoB3B,EAAgB,CACtC,MAAM+E,EAAgB,IAAIpE,GAAUqE,UAAU/mB,KAAK1U,IAAMA,EAAEg3B,QAAqB,SAAXh3B,EAAEE,MAEvE,YADAy3B,GAAgB6D,MAAAA,OAAAA,EAAAA,EAAe7yB,OAAQytB,GAAgB1K,EAAO2K,WAEhE,CACA,GAAIyC,EAAY,CACd,MAAM4C,EAAKhD,GAAkBpC,GAAkB,CAC7C/qB,SACAD,cACAqrB,iBACAD,aAEAD,iBACAD,mBAGF,YADAmB,EAAgB+D,EAElB,CAEA,MAAMF,EAAgB,IAAIpE,GAAUqE,UAAU/mB,KAAK1U,IAAMA,EAAEg3B,QAAqB,SAAXh3B,EAAEE,MACvEy3B,GAAgB,MAAA6D,OAAA,EAAAA,EAAe7yB,OAAQytB,GAAgB1K,EAAO2K,aAC7D,CACD/qB,EACAC,EACAorB,EACAD,EACAF,EACAC,EACA2B,EACAM,EACAI,EACA1B,IAGF,MAAMuE,GAAWr1B,IL/SI,CAACA,IACtBivB,GAAWO,QAAQxvB,IK+SjBwvB,CAAQxvB,IAGJs1B,GAAoB,KACxBP,GAAgBv0B,SAAW,EACpBu0B,GAAgBv0B,SAGnB+0B,GAAyB,KAC7BR,GAAgBv0B,SAAW,GAGvBg1B,GAAyBC,GAC7BV,GAAgBv0B,UAAYi1B,EAExBC,GAAqB,KACrBV,GAAoBx0B,UAGxBw0B,GAAoBx0B,SAAU,EAC9B60B,GAAQ,UAGVJ,GAAU,KACoB,oBAAjBre,eACTA,aAAaR,QAAQqZ,GAAa/a,KAAKyB,UAAU2a,IACjDla,aAAaR,QAAQsZ,GAAe7Z,KAAKC,MAAMqK,cAEhD,CAAC2Q,IAEJ,MAAM6E,GAAyB,KA/OI,IACnC9qB,KA+OwBwpB,GAAqB7zB,WAzO7CqK,EAAQ+qB,UAAY/qB,EAAQgR,ejB5KihC,IAAWxjB,GAAEE,GAAOC,GAATH,GiBwZxiC,KACds9B,MjBzZwjCp9B,GiB0ZvjC,CAACu4B,EAAUpQ,EAAYzb,EAAQD,GjB1Z+hCxM,GAAEQ,GAAEW,IAAI,IAAId,EAAE0F,KAAKtD,GAAEzC,GAAEkJ,IAAInJ,MAAKC,GAAEyB,GAAG5B,GAAEG,GAAED,EAAEA,GAAEG,EAAE2F,IAAIhD,KAAK7C,KiB4ZznCy8B,GAAU,KACR,MAAM90B,EAAUm0B,GAAmB9zB,QACnC,IAAKL,GAAqC,oBAAnB01B,eACrB,OAGF,MAAMC,EAAW,IAAID,eAAe,KAClCF,OAIF,OADAG,EAASC,QAAQ51B,GACV,IAAM21B,EAASE,cACrB,IAEH,MAAMC,GAAqB,KACiB,OAAtC7B,GAA0B5zB,UAC5BqL,OAAO0Y,cAAc6P,GAA0B5zB,SAC/C4zB,GAA0B5zB,QAAU,MAEtC2zB,GAAsB3zB,QAAU,MAkB5B01B,GAAuB,KAC3BtE,GAAkB,GAClBC,GAAc,GACdE,GAAoB,GACpBC,GAAkB,GAClBC,GAAkB,GAClBI,EAAkB,MAClB0B,GAAsBvzB,QAAU,KAChCwzB,GAAuBxzB,QAAU,GACjCyzB,GAAyBzzB,SAAU,EACnC0zB,GAAyB1zB,SAAU,EACnCk0B,GAA6Bl0B,SAAU,EACvC+zB,GAAmB/zB,QAAU,KAC7Bg0B,GAAwBh0B,QAAU,IAG9B21B,GAAsB,KACQ,OAA9BzC,EAAkBlzB,UACpBqL,OAAO7J,aAAa0xB,EAAkBlzB,SACtCkzB,EAAkBlzB,QAAU,OAI1B41B,GAAa,KACc,OAA3B/C,EAAe7yB,UACjB+jB,cAAc8O,EAAe7yB,SAC7B6yB,EAAe7yB,QAAU,MAGvB+yB,EAAU/yB,UACZ+yB,EAAU/yB,QAAQw1B,aAClBzC,EAAU/yB,QAAU,MAGlB8yB,EAAgB9yB,UAClB8yB,EAAgB9yB,QAAQ2mB,QAAQwH,MAAM,QACtC2E,EAAgB9yB,QAAU,MAG5B4yB,EAAgB5yB,QAAU,MAGtB61B,GAAmB,KAClBtD,EAAUvyB,UAIfuyB,EAAUvyB,QAAQ81B,YAAYh2B,QAASi2B,GAAUA,EAAMnO,QACvD2K,EAAUvyB,QAAU,OAGhBg2B,GAAmB,KAClBvD,EAA0BzyB,UAI/ByyB,EAA0BzyB,QAAQ4nB,OAClC6K,EAA0BzyB,QAAU,OAGhCi2B,GAAoB,KACxB,MAAMC,EAAc/B,GAAen0B,QACnCm0B,GAAen0B,QAAU,KACzB,MAAAk2B,GAAAA,EAAarO,SACbuM,GAA8Bp0B,QAAU,KACxCq0B,GAAyBr0B,QAAU,IAGrCy0B,GACE,IAAM,KACJM,KACAY,KACAtC,GAAyBrzB,SAAU,EAEnCg2B,KACAxV,KACAyV,KACAL,KACAC,KACAJ,KAEA,MAAMU,EAAW7D,EAAYtyB,QACzBm2B,IACFA,EAASC,gBAAkB,KAC3BD,EAASE,OAAS,KAClBF,EAASrP,QAAU,KACI,aAAnBqP,EAASv4B,OACXu4B,EAASvO,OAEX0K,EAAYtyB,QAAU,MAGxBi2B,MAEF,IAIFxB,GAAU,KACR,MAAM6B,EPxf2B,MACnC,GAA4B,oBAAjBlgB,aAA8B,OAAO,KAChD,MAAMpC,EAAMoC,aAAanC,QAAQiC,IACjC,IAAKlC,EAAK,OAAO,KACjB,IACE,MAAMhK,EAASkK,KAAKC,MAAMH,GAC1B,OAAIqB,KAAKC,MAAQtL,EAAOqM,QArCN,KAsChBC,KACO,MAEFtM,CACT,CAAA,MAEE,OADAsM,KACO,IACT,GO0esBigB,GACpB,IAAKD,EAAa,OAElBhgB,KACAlC,QAAQC,KAAK,2CAGTiiB,EAAYlR,YACdsN,EAAa1yB,QAAUs2B,EAAYlR,UACP,oBAAjBhP,cACTA,aAAaR,QAAQuZ,GAAgBmH,EAAYlR,YAIrD,MAAMoR,EAAe1B,KACrB5D,GAAU,GACVO,GAAkB,GAClBI,EAAkBxC,IAElB,MAAMoH,EAAmB3iB,KAAiB/K,QAapC2tB,EN03BuB,EAC/BpX,EACAgX,EACA5J,EACA7H,EACAoG,KAEA,IAEIC,EAFAhD,GAAY,EACZiD,EAAiC,KAEjCC,GAAe,EAKnB,MAAMuL,EAAa,IAAIL,EAAYhJ,kBACnC,IAAA,MAAWsJ,KAAMN,EAAYlJ,iBACvBuJ,EAAWt4B,KAAMnG,GAAMA,EAAEqmB,UAAYqY,EAAGrY,WAC5B,aAAZqY,EAAGpY,KACLmY,EAAW97B,KAAK,CACd0jB,QAASqY,EAAGrY,QACZE,OAAQ,yCAA2D,oBAAXpT,OAAyBA,OAAOQ,SAASF,KAAO,sBAAsB+gB,MAGhIiK,EAAW97B,KAAK,CACd0jB,QAASqY,EAAGrY,QACZE,OAAQ,sDAkNd,MAAO,CACLmJ,KAAM,KACJM,GAAY,EACZ1H,KACI0K,GAAcA,EAAarD,SAASsG,MAAM,QAC1ChD,GAAgBA,EAAapM,YAAciG,UAAU0C,MACvDyD,EAAaxE,SAGjBoC,KAtNkB,IAAInoB,QAAciW,MAAO/V,EAAS0iB,eACpD,IACE,GAAI0E,SAAkBpnB,IAEtB,IAAI8qB,EAAqB0K,EAAYlR,UAErC,MAAM2C,QAAsB,IAAInnB,QAAgB,CAACorB,EAAcC,KAC7D,GAAI/D,EAA+B,YAAlB8D,EAAa,IAE9B,MAAMlH,EAAQvF,GAAeD,EAAS,kBAChCyF,EAAS,IAAIC,UAAUF,GAC7BqG,EAAepG,EAEf,IAAImH,EAAa,GACbC,GAAW,EACXC,EAAmB,GAEvB,MAAMC,EAAUC,IACVH,IACJA,GAAW,EACXH,EAAaM,KAGTC,EAAQjY,IACR6X,IACJA,GAAW,EACXF,EAAY3X,KAGdyQ,EAAOkB,OAAS,KACd7R,QAAQC,KAAK,qCACb0Q,EAAOoB,KAAKjS,KAAKyB,UAAU,CACzBvc,KAAM,SACNgtB,WAAYkQ,EAAYjQ,UACxBL,WAAYsQ,EAAYlR,UACxBoH,MAAO8J,EAAY9J,MACnBC,aAAcC,EACdrC,mBAAoBiM,EAAYrO,kBAChC4O,mBAAoBP,EAAYlJ,iBAChC0J,aAAcH,MAIlB5R,EAAOyB,UAAY3P,MAAO1Z,0BACxB,IAAIiC,EACJ,IACEA,EAAO8U,KAAKC,MAAMvY,OAAOuB,EAAMiC,MACjC,CAAA,MAAU,MAAQ,CAElB,MAAMutB,EAAUvtB,EAAKhG,KAErB,GAAgB,YAAZuzB,GAAoD,iBAApBvtB,EAAK4mB,WAGvC,OAFA4F,EAAqBxsB,EAAK4mB,gBAC1B,OAAA7Q,EAAA0P,EAAO6B,cAAPvR,EAAA9V,KAAAwlB,EAAqB+G,IAIvB,GAAgB,cAAZe,EAAJ,CAQA,GAAgB,gBAAZA,GAAmD,iBAAfvtB,EAAK8X,MAG3C,OAFAkV,GAAoBhtB,EAAK8X,WACzB,OAAAiD,EAAA0K,EAAO+H,mBAAPzS,EAAA9a,OAA0BD,EAAK8X,QAIjC,GAAgB,eAAZyV,GAA4B/zB,MAAMC,QAAQuG,EAAKytB,OAAQ,CACzD,MAAMA,EAAQztB,EAAKytB,MAGfT,EAAiBhqB,SACnB,OAAA0qB,EAAAjI,EAAOkI,sBAAPD,EAAAztB,KAAAwlB,EAA6BuH,EAAiBhqB,SAEhDgqB,EAAmB,GAEnB,OAAAY,EAAAnI,EAAOoI,cAAPD,EAAA3tB,KAAAwlB,EAAqBgI,GAErB,MAAMK,EAAiD,GACvD,IAAA,MAAW7tB,KAAQwtB,EAAO,CACxB,MAAMM,EAA2B,aAAd9tB,EAAKmf,KACpB2O,GACFhX,GAAuB,CACrBiP,UAAWwG,EACXvF,UAAWiQ,EAAYjQ,UACvBmG,MAAO8J,EAAY9J,MACnBxE,MAAOsO,EAAYtO,MACnBC,kBAAmBqO,EAAYrO,kBAC/BmF,iBAAkBP,EAAM9sB,IAAK1H,IAAAA,CAC3BkmB,QAASlmB,EAAEkmB,QACXC,KAAMnmB,EAAEmmB,KACR6O,KAAMh1B,EAAEg1B,QAEVC,iBAAkB,IAAIJ,KAI1B,MAAMzO,QAAewM,EAAY5rB,GAE7B8tB,GACF7W,KAGF,OAAAiX,EAAA1I,EAAO2I,eAAPD,EAAAluB,KAAAwlB,EAAsBxlB,EAAKkf,QAASlf,EAAKmf,KAAMC,EAAOA,QACtDyO,EAAQryB,KAAK4jB,EACf,CAKA,YAHIsG,EAAOhG,aAAeiG,UAAU0C,MAClC3C,EAAOoB,KAAKjS,KAAKyB,UAAU,CAAEvc,KAAM,eAAgB8zB,aAGvD,CAEA,GAAgB,eAAZP,EAOF,OANAT,EAAc9sB,EAAKquB,aAA0B,GAC7C,OAAAC,EAAA7I,EAAO8I,kBAAPD,EAAAruB,KAAAwlB,EAAyBqH,GACM,iBAApB9sB,EAAK4mB,aACd,OAAA4H,EAAA/I,EAAO6B,uBAActnB,EAAK4mB,kBAE5BqG,EAAOH,GAIT,GAAgB,UAAZS,EAAqB,CACvB,MAAMkB,EAAUzuB,EAAKkV,OAAoB,cAIzC,OAHA8W,GAAe,EACf,OAAA0C,EAAAjJ,EAAOhB,UAAPiK,EAAAzuB,KAAAwlB,EAAiBgJ,QACjBtB,EAAK,IAAI3N,MAAMiP,GAEjB,CAtEA,MALE,OAAA3T,EAAA2K,EAAOkJ,cAAP7T,EAAA7a,KAAAwlB,EACEzlB,EAAK4uB,UACL5uB,EAAK6uB,iBA4EXlJ,EAAO+B,QAAU,WACfsE,GAAe,EACf,OAAAjW,EAAA0P,EAAOhB,UAAP1O,EAAA9V,KAAAwlB,EAAiB,yBACjB0H,EAAK,IAAI3N,MAAM,2BAGjBmG,EAAOiC,QAAU,IAAMqF,EAAOH,KAMhC,GAHAf,EAAe,KAGXjD,IAAcH,EAIhB,OAHKG,GACHzP,KAEK3X,IAKT,IAAI+pB,EAFJzW,QAAQC,KAAK,uCAAuCiiB,EAAYtO,SAChE,OAAA7S,EAAA0P,EAAOpD,qBAAPtM,EAAA9V,KAAAwlB,EAA4B,aAG5B,IACEgG,QAAkBpB,GAChBnK,EAASyI,EAAeuO,EAAYtO,MAAOtb,QAAQ4pB,EAAYrO,mBAC/D,IAAMC,EACLnD,IAAaoG,EAAepG,GAEjC,OAASmJ,GACP,GAAIhG,SAAkBpnB,IACtBsT,QAAQG,KACN,+CAA+C2Z,aAAmBtP,MAAQsP,EAAQrP,QAAUjjB,OAAOsyB,MAErGrD,QAAkB/C,GAChBxI,EAASyI,EAAeuO,EAAYtO,MAAOtb,QAAQ4pB,EAAYrO,mBAC/D,IAAMC,EACLS,IAAauC,EAAevC,GAEjC,EAEKT,GAAa2C,EAAUvJ,OAAO9mB,OAAS,QACpC6mB,GACJwJ,EAAUvJ,OAAQuJ,EAAUtJ,SAAUsJ,EAAUrJ,WAChDqD,EAAOpD,oBAGT,OAAAvH,EAAA2K,EAAOpD,qBAAPvH,EAAA7a,KAAAwlB,EAA4B,QAGzBqD,GACHzP,KAEF3X,GACF,OAASmjB,GACP,IAAKmH,EAAc,CACjB,MAAMzM,EAAMsF,aAAerF,MAAQqF,EAAIpF,QAAUjjB,OAAOqoB,GACxD,OAAA9J,EAAA0K,EAAOhB,UAAP1J,EAAA9a,KAAAwlB,EAAiBlG,EACnB,CACA6E,EAAOS,EACT,CAAA,QACE,MAAAiH,GAAAA,EAAcrD,SAASsG,MAAM,QACzBhD,GAAgBA,EAAapM,YAAciG,UAAU0C,MACvDyD,EAAaxE,QAEfwE,EAAe,IACjB,MMnmCmB4L,CACjBnS,EAAOoS,eACPV,EACAG,EACA,CACE/P,YAAcuQ,IACPjC,GAAsBwB,IACvBS,GAAOA,IAAQvE,EAAa1yB,UAC9B0yB,EAAa1yB,QAAUi3B,EACK,oBAAjB7gB,cACTA,aAAaR,QAAQuZ,GAAgB8H,KAI3CrK,iBAAmB1V,IACZ8d,GAAsBwB,KAC3B/E,GAAkB,GAClBJ,GAAc,GACdQ,EAAkB,MAElBmC,GAAwBh0B,SAAWkX,EAEG,OAAlCqc,GAAsBvzB,QACxBuzB,GAAsBvzB,QAAUk3B,GAC9BlD,GAAwBh0B,SACxB,GAGFm3B,GACE5D,GAAsBvzB,QACtBg0B,GAAwBh0B,WAI9B2tB,gBAAkB5F,IAChB,IAAKiN,GAAsBwB,GAAe,OAC1C3B,GAAQ,aACRhD,EAAkB,MAClBR,GAAc,GACdE,GAAoB,GAEpB,MAAM6F,EACJrP,GAAiBiM,GAAwBh0B,QAC3Cg0B,GAAwBh0B,QAAUo3B,EAEI,OAAlC7D,GAAsBvzB,QACxBm3B,GACE5D,GAAsBvzB,QACtBo3B,GAGF7D,GAAsBvzB,QAAUk3B,GAC9BE,GACA,IAINrK,oBAAsBlrB,IACfmzB,GAAsBwB,IACtB5L,GACHhG,EAAOoS,eAAgBn1B,EAAM+iB,EAAOoD,MACpCC,EAAoBrqB,GAAUy5B,GAAuBz5B,EAAO44B,IAC5DrI,MAAOlK,GAAQ7P,QAAQG,KAAK,kCAAmC0P,KAEnEgJ,YAAcJ,IACZ,GAAKmI,GAAsBwB,GAA3B,CACI3J,EAAMryB,OAAS,GACjBq6B,GAAQ,YAEVpD,GAAkB,GAClBI,EAAkBxC,IAElB,IAAA,MAAWhwB,KAAQwtB,EAAO,CACxB,MAAMyK,EACU,aAAdj4B,EAAKmf,KACD,sBAAsBnf,EAAKguB,KAAKvkB,KAAO,KACzB,mBAAdzJ,EAAKmf,KACH,0BACc,aAAdnf,EAAKmf,KACH,cAAcnf,EAAKguB,KAAKtR,QAAU,KACpB,WAAd1c,EAAKmf,KACH,gBACAnf,EAAKmf,KAEjB0Y,GAAc,GAAGI,KAAa,GAC9BxG,EAAayG,IACX,MAAMC,EAAOD,EAAKA,EAAK/8B,OAAS,GAChC,OAAIg9B,IAASA,EAAKtH,OACT,IACFqH,EAAK16B,MAAM,GAAG,GACjB,IAAK26B,EAAMp+B,KAAM,SAGdm+B,GAEX,CAEAhE,GAAsBvzB,QAAU,KAChCg0B,GAAwBh0B,QAAU,EAjCQ,GAmC5CwtB,aAAc,OACdO,YAAa,KACNiH,GAAsBwB,KAC3B3B,GAAQ,YACRxD,GAAc,GACdQ,EAAkBxC,MAEpB5N,mBAAqB7jB,IACnBy5B,GAAuBz5B,EAAO44B,IAEhC3S,QAAUI,IACH+Q,GAAsBwB,KAC3B3E,EAAkB,MAClBqF,GAAc,SAASjT,KAAO,MA5HbpN,MACrBxX,IAEA,MAAMkvB,EAA2B,CAC/B/P,KAAMnf,EAAKmf,KACXD,QAASlf,EAAKkf,WACXlf,EAAKguB,MAEV,OAAOhP,GAAsBkQ,KA0H/BkE,EAA0BzyB,QAAU02B,EAEpCA,EAAW3N,KACRoF,MAAM,QACNsJ,QAAQ,KACFzC,GAAsBwB,KAC3BtF,GAAU,GACVO,GAAkB,GAClBJ,GAAc,GACdE,GAAoB,GACpBC,GAAkB,GAClBK,EAAkB,MAClBmC,GAAwBh0B,QAAU,GAClCuzB,GAAsBvzB,QAAU,KAChCyyB,EAA0BzyB,QAAU,MAGjCs0B,GAAwBt0B,SACzBuwB,GACEtI,EACAmK,EAAepyB,QACfkyB,EAAUlyB,UAGP03B,GAAe,WAGzB,IAEH,MAAMR,GAAgB,CAACr1B,EAAcquB,KACnC,MAAM9jB,EAAKimB,EAAiBryB,UAS5B,OARA8wB,EAAa6G,GAAa,IACrBA,EACH,CACEvrB,KACAvK,OACAquB,YAGG9jB,GAGH+qB,GAAoB,CAAC/qB,EAAYvK,KACrCivB,EAAa6G,GACXA,EAAS53B,IAAK8e,GACZA,EAAQzS,KAAOA,EAAK,IAAKyS,EAAShd,QAASgd,KAK3C+Y,GAA+B/1B,IACnC,MAAM4d,EAAa5d,EAAKO,OACnBqd,IAGL4U,GAAyBr0B,QAAUyf,EACW,OAA1C2U,GAA8Bp0B,QAIlCm3B,GAAkB/C,GAA8Bp0B,QAASyf,GAHvD2U,GAA8Bp0B,QAAUk3B,GAAczX,GAAY,KAMhEoY,GAAkC,KACtCzD,GAA8Bp0B,QAAU,KACxCq0B,GAAyBr0B,QAAU,IAG/Bq3B,GAAyB,CAACz5B,EAAyB44B,KACvD,GAA4B,iBAAjBA,GAA8BxB,GAAsBwB,GAA/D,CAIA,GAAc,cAAV54B,EAGF,OAFA2zB,GAAoB,QACpBC,GAAkB,GAIpB,GAAc,YAAV5zB,EAGF,OAFA2zB,GAAoB,QACpBC,GAAkB,GAIpB,GAAc,aAAV5zB,EAGF,OAFA2zB,GAAoB,QACpBC,GAAkB,GAIpB,GAAc,SAAV5zB,EAGF,OAFA2zB,GAAoB,QACpBC,GAAkB,GAIpBD,GAAoB,GACpBC,GAAkB,EA3BlB,GA8BIsG,GAAuBtB,KACC,iBAAjBA,GAA8BxB,GAAsBwB,MAI/DtC,GAA6Bl0B,SAAU,EACvC6xB,EAAkB,MAClBX,GAAU,GACVE,GAAkB,GAClBC,GAAc,GACdE,GAAoB,GACpBC,GAAkB,GAClBC,GAAkB,GAClBsC,GAAmB/zB,QAAU,KAC7Bg0B,GAAwBh0B,QAAU,GAClCuzB,GAAsBvzB,QAAU,KAC5ByyB,EAA0BzyB,UAC5ByyB,EAA0BzyB,QAAU,OAGnCs0B,GAAwBt0B,SACzBuwB,GACEtI,EACAmK,EAAepyB,QACfkyB,EAAUlyB,WAGZoU,QAAQC,KAAK,mEACRqjB,GAAe,UAIlBK,GAAsBlhB,MAAOgV,IACjC,IAAKjH,EAAOyB,UAEV,YADA6Q,GAAc,uCAAuC,GAIvD,MAAMc,EAAqBnM,EAASzpB,OACpC,IAAK41B,EAEH,YADAd,GAAc,2DAA2D,GAI3E,MAAMV,EAAe1B,KACrB5D,GAAU,GACVE,GAAkB,GAClBC,GAAc,GACdE,GAAoB,GACpBC,GAAkB,GAClBC,GAAkB,GAClBI,EAAkBxC,IAClB6E,GAA6Bl0B,SAAU,EAEvC,IACE+zB,GAAmB/zB,QAAUg4B,EAC7BJ,GAA4BI,GAC5BH,KAEA7B,KACA,MAAMtJ,EAAc5Y,KAAiB/K,QAE/BkvB,EAAsBphB,MAC1BxX,IAEA,MAAMkvB,EAA2B,CAC/B/P,KAAMnf,EAAKmf,KAKXD,QAASlf,EAAKkf,WACXlf,EAAKguB,MAEV,OAAOhP,GAAsBkQ,IAGzBmI,ENiWuB,EACjCpX,EACAuM,EACAxF,EACAjB,EACAR,EAMAC,EACAoG,KAEA,IAEIC,EAFAhD,GAAY,EACZiD,EAAiC,KAEjCC,GAAe,EA2MnB,MAAO,CACLxD,KAAM,KACJM,GAAY,EACZ1H,KACI0K,GAAcA,EAAarD,SAASsG,MAAM,QAC1ChD,GAAgBA,EAAapM,YAAciG,UAAU0C,MACvDyD,EAAaxE,SAGjBoC,KAlNkB,IAAInoB,QAAciW,MAAO/V,EAAS0iB,eACpD,IACE,GAAI0E,SAAkBpnB,IAGtB,MAAMinB,QAAsB,IAAInnB,QAAgB,CAACorB,EAAcC,KAC7D,GAAI/D,EAA+B,YAAlB8D,EAAa,IAE9B,MAAMlH,EAAQvF,GAAeD,EAAS,kBAChCyF,EAAS,IAAIC,UAAUF,GAC7BqG,EAAepG,EAEf,IAAImH,EAAa,GACbC,GAAW,EACXP,EAAqBxG,GAAa,GAClCgH,EAAmB,GAEvB,MAAMC,EAAUC,IACVH,IACJA,GAAW,EACXH,EAAaM,KAGTC,EAAQjY,IACR6X,IACJA,GAAW,EACXF,EAAY3X,KAGdyQ,EAAOkB,OAAS,KACdlB,EAAOoB,KAAKjS,KAAKyB,UAAU,CACzBvc,KAAM,QACNgtB,WAAYC,EACZL,WAAYZ,EACZ2G,UAAWF,EACXW,MAAO5H,EAAO4H,MACdC,aAAc7H,EAAO8H,YACrBrC,mBAAoBzF,EAAOqD,sBAI/BlD,EAAOyB,UAAY3P,MAAO1Z,0BACxB,IAAIiC,EACJ,IACEA,EAAO8U,KAAKC,MAAMvY,OAAOuB,EAAMiC,MACjC,CAAA,MAAU,MAAQ,CAElB,MAAMutB,EAAUvtB,EAAKhG,KAErB,GAAgB,YAAZuzB,GAAoD,iBAApBvtB,EAAK4mB,WAGvC,OAFA4F,EAAqBxsB,EAAK4mB,gBAC1B,OAAA7Q,EAAA0P,EAAO6B,cAAPvR,EAAA9V,KAAAwlB,EAAqB+G,IAIvB,GAAgB,cAAZe,EAAJ,CAQA,GAAgB,gBAAZA,GAAmD,iBAAfvtB,EAAK8X,MAG3C,OAFAkV,GAAoBhtB,EAAK8X,WACzB,OAAAiD,EAAA0K,EAAO+H,mBAAPzS,EAAA9a,OAA0BD,EAAK8X,QAIjC,GAAgB,eAAZyV,GAA4B/zB,MAAMC,QAAQuG,EAAKytB,OAAQ,CACzD,MAAMA,EAAQztB,EAAKytB,MAGfT,EAAiBhqB,SACnB,OAAA0qB,EAAAjI,EAAOkI,sBAAPD,EAAAztB,KAAAwlB,EAA6BuH,EAAiBhqB,SAEhDgqB,EAAmB,GAEnB,OAAAY,EAAAnI,EAAOoI,cAAPD,EAAA3tB,KAAAwlB,EAAqBgI,GAErB,MAAMK,EAAiD,GACvD,IAAA,MAAW7tB,KAAQwtB,EAAO,CACxB,MAAMM,EAA2B,aAAd9tB,EAAKmf,KACpB2O,GACFhX,GAAuB,CACrBiP,UAAWwG,EACXvF,YACAmG,MAAO5H,EAAO4H,MACdxE,MAAOpD,EAAOoD,MACdC,kBAAmBvb,QAAQkY,EAAOqD,mBAClCmF,iBAAkBP,EAAM9sB,IAAK1H,IAAAA,CAC3BkmB,QAASlmB,EAAEkmB,QACXC,KAAMnmB,EAAEmmB,KACR6O,KAAMh1B,EAAEg1B,QAEVC,iBAAkB,IAAIJ,KAI1B,MAAMzO,QAAewM,EAAY5rB,GAE7B8tB,GACF7W,KAGF,OAAAiX,EAAA1I,EAAO2I,eAAPD,EAAAluB,KAAAwlB,EAAsBxlB,EAAKkf,QAASlf,EAAKmf,KAAMC,EAAOA,QACtDyO,EAAQryB,KAAK4jB,EACf,CAQA,YANIsG,EAAOhG,aAAeiG,UAAU0C,MAClC3C,EAAOoB,KAAKjS,KAAKyB,UAAU,CACzBvc,KAAM,eACN8zB,aAIN,CAEA,GAAgB,eAAZP,EAOF,OANAT,EAAc9sB,EAAKquB,aAA0B,GAC7C,OAAAC,EAAA7I,EAAO8I,kBAAPD,EAAAruB,KAAAwlB,EAAyBqH,GACM,iBAApB9sB,EAAK4mB,aACd,OAAA4H,EAAA/I,EAAO6B,uBAActnB,EAAK4mB,kBAE5BqG,EAAOH,GAIT,GAAgB,UAAZS,EAAqB,CACvB,MAAMkB,EAAUzuB,EAAKkV,OAAoB,cAIzC,OAHA8W,GAAe,EACf,OAAA0C,EAAAjJ,EAAOhB,UAAPiK,EAAAzuB,KAAAwlB,EAAiBgJ,QACjBtB,EAAK,IAAI3N,MAAMiP,GAEjB,CAzEA,MALE,OAAA3T,EAAA2K,EAAOkJ,cAAP7T,EAAA7a,KAAAwlB,EACEzlB,EAAK4uB,UACL5uB,EAAK6uB,iBA+EXlJ,EAAO+B,QAAU,WACfsE,GAAe,EACf,OAAAjW,EAAA0P,EAAOhB,UAAP1O,EAAA9V,KAAAwlB,EAAiB,yBACjB0H,EAAK,IAAI3N,MAAM,2BAEjBmG,EAAOiC,QAAU,IAAMqF,EAAOH,KAMhC,GAHAf,EAAe,KAGXjD,IAAcH,EAIhB,OAHKG,GACHzP,KAEK3X,IAIT,IAAI+pB,EADJ,OAAA1V,EAAA0P,EAAOpD,qBAAPtM,EAAA9V,KAAAwlB,EAA4B,aAG5B,IACEgG,QAAkBpB,GAChBnK,EAASyI,EAAenD,EAAOoD,MAAOtb,QAAQkY,EAAOqD,mBACrD,IAAMC,EACLnD,IAAaoG,EAAepG,GAEjC,OAASmJ,GACP,GAAIhG,SAAkBpnB,IACtB+pB,QAAkB/C,GAChBxI,EAASyI,EAAenD,EAAOoD,MAAOtb,QAAQkY,EAAOqD,mBACrD,IAAMC,EACLS,IAAauC,EAAevC,GAEjC,EAEKT,GAAa2C,EAAUvJ,OAAO9mB,OAAS,QACpC6mB,GACJwJ,EAAUvJ,OAAQuJ,EAAUtJ,SAAUsJ,EAAUrJ,WAChDqD,EAAOpD,oBAGT,OAAAvH,EAAA2K,EAAOpD,qBAAPvH,EAAA7a,KAAAwlB,EAA4B,QAGzBqD,GACHzP,KAEF3X,GACF,OAASmjB,GACP,IAAKmH,EAAc,CACjB,MAAMzM,EAAMsF,aAAerF,MAAQqF,EAAIpF,QAAUjjB,OAAOqoB,GACxD,OAAA9J,EAAA0K,EAAOhB,UAAP1J,EAAA9a,KAAAwlB,EAAiBlG,EACnB,CACA6E,EAAOS,EACT,CAAA,QACE,MAAAiH,GAAAA,EAAcrD,SAASsG,MAAM,QACzBhD,GAAgBA,EAAapM,YAAciG,UAAU0C,MACvDyD,EAAaxE,QAEfwE,EAAe,IACjB,MM1jBqB+M,CACjBtT,EAAOoS,eACPgB,EACApT,EAAOyB,UACPqM,EAAa1yB,QACb,CACEwsB,MAAO5H,EAAO4H,MACdxE,MAAOpD,EAAOoD,MACd0E,cACAzE,qBAEF,CACEvB,YAAcuQ,IACPjC,GAAsBwB,IACvBS,GAAOA,IAAQvE,EAAa1yB,UAC9B0yB,EAAa1yB,QAAUi3B,EACK,oBAAjB7gB,cACTA,aAAaR,QAAQuZ,GAAgB8H,KAI3CrK,iBAAmB1V,IACZ8d,GAAsBwB,KAC3BpF,GAAkB,GAClBC,GAAc,GACdI,GAAkB,GACdyC,GAA6Bl0B,UAC/Bk0B,GAA6Bl0B,SAAU,EACvC6xB,EAAkB,OAGpBmC,GAAwBh0B,SAAWkX,EAEG,OAAlCqc,GAAsBvzB,QACxBuzB,GAAsBvzB,QAAUk3B,GAC9BlD,GAAwBh0B,SACxB,GAGFm3B,GACE5D,GAAsBvzB,QACtBg0B,GAAwBh0B,WAI9B2tB,gBAAkB5F,IAChB,IAAKiN,GAAsBwB,GAAe,OAC1C3B,GAAQ,aACRX,GAA6Bl0B,SAAU,EACvC6xB,EAAkB,MAClBR,GAAc,GACdE,GAAoB,GAEpB,MAAM6F,EAAmBrP,GAAiBiM,GAAwBh0B,QAClEg0B,GAAwBh0B,QAAUo3B,EAEI,OAAlC7D,GAAsBvzB,QACxBm3B,GACE5D,GAAsBvzB,QACtBo3B,GAGF7D,GAAsBvzB,QAAUk3B,GAC9BE,GACA,IAINrK,oBAAsBlrB,IACfmzB,GAAsBwB,IACtB5L,GACHhG,EAAOoS,eAAgBn1B,EAAM+iB,EAAOoD,MACpCC,EAAoBrqB,GAAUy5B,GAAuBz5B,EAAO44B,IAC5DrI,MAAOlK,GAAQ7P,QAAQG,KAAK,kCAAmC0P,KAEnEgJ,YAAcJ,IACZ,GAAKmI,GAAsBwB,GAA3B,CACI3J,EAAMryB,OAAS,GACjBq6B,GAAQ,YAEVpD,GAAkB,GAClBI,EAAkBxC,IAElB,IAAA,MAAWhwB,KAAQwtB,EAAO,CACxB,MAAMyK,EACU,aAAdj4B,EAAKmf,KACD,sBAAsBnf,EAAKguB,KAAKvkB,KAAO,KACzB,mBAAdzJ,EAAKmf,KACH,0BACc,aAAdnf,EAAKmf,KACH,cAAcnf,EAAKguB,KAAKtR,QAAU,KACpB,WAAd1c,EAAKmf,KACH,gBACAnf,EAAKmf,KAEjB0Y,GAAc,GAAGI,KAAa,GAC9BxG,EAAayG,IACX,MAAMC,EAAOD,EAAKA,EAAK/8B,OAAS,GAChC,OAAIg9B,IAASA,EAAKtH,OACT,IACFqH,EAAK16B,MAAM,GAAG,GACjB,IAAK26B,EAAMp+B,KAAM,SAGdm+B,GAEX,CAEAhE,GAAsBvzB,QAAU,KAChCg0B,GAAwBh0B,QAAU,EAjCQ,GAmC5CwtB,aAAc,OACdO,YAAa,KACNiH,GAAsBwB,KAC3B3B,GAAQ,YACRxD,GAAc,GACdQ,EAAkBxC,MAEpB5N,mBAAqB7jB,IACnBy5B,GAAuBz5B,EAAO44B,IAEhC3S,QAAUI,IACH+Q,GAAsBwB,KAC3BtC,GAA6Bl0B,SAAU,EACvC6xB,EAAkB,MAClBqF,GAAc,SAASjT,KAAO,MAGlCgU,GAGFxF,EAA0BzyB,QAAU02B,QAC9BA,EAAW3N,IACnB,OAASzU,GACP,IAAK0gB,GAAsBwB,GAAe,OAC1CtC,GAA6Bl0B,SAAU,EACvC6xB,EAAkB,MACdvd,aAAiBsK,OACnBsY,GAAc,SAAS5iB,EAAMuK,WAAW,EAE5C,CAAA,QACEiZ,GAAoBtB,EACtB,GAkPI2B,GAAiBC,IACrB,MAAMjC,EAAW7D,EAAYtyB,QACxBm2B,GAA+B,aAAnBA,EAASv4B,eAItBw6B,WAASC,WACXrF,EAAwBhzB,SAAU,GAGpC41B,KACAO,EAASvO,SA4DL8P,GAAiB7gB,MAAOsT,UAC5B,KACE+H,EAAUlyB,SACVoyB,EAAepyB,SACfszB,GAAyBtzB,SAH3B,CAUA,GAFA6xB,EAAkBxC,MAEb,OAAAla,EAAAmjB,UAAUC,mBAAV,EAAApjB,EAAwBqjB,cAG3B,OAFA3G,EAAkB,WAClBqF,GAAc,0CAA0C,GAI1D,GAA6B,oBAAlBuB,cAGT,OAFA5G,EAAkB,WAClBqF,GAAc,+CAA+C,GAI/D5D,GAAyBtzB,SAAU,EAEnC,IACE,MAAMkpB,QAAeoP,UAAUC,aAAaC,aAAa,CAAE9T,OAAO,IAClE6N,EAAUvyB,QAAUkpB,EAIpB,MAAMwP,EAAwC,CAC5CC,mBAAoB,MAIhBC,EAAqB,CACzB,wBACA,yBACA,cAEF,IAAA,MAAWC,KAAQD,EACjB,GAAIH,cAAcK,gBAAgBD,GAAO,CACvCH,EAAgBnX,SAAWsX,EAC3B,KACF,CAGF,MAAM1C,EAAW,IAAIsC,cAAcvP,EAAQwP,GAC3CpG,EAAYtyB,QAAUm2B,EACtB3D,EAAexyB,QAAU,GACzB63B,KACArD,GAAoBx0B,SAAU,EAE9B,MAAM+4B,GAAe5C,EAAS5U,UAAYmX,EAAgBnX,UAAY,cACnE5W,MAAM,KAAK,GACXvI,QAAU,aAEP42B,EAAkBrU,GACtBC,EAAOoS,eACP,CACE3Q,UAAWzB,EAAOyB,UAClBjB,UAAWsN,EAAa1yB,QACxBsmB,SAAU,KACV/E,SAAUwX,GAEZ,CACErS,YAAcuQ,IACPA,GAAOA,IAAQvE,EAAa1yB,UAGjC0yB,EAAa1yB,QAAUi3B,EACK,oBAAjB7gB,cACTA,aAAaR,QAAQuZ,GAAgB8H,KAGzCpQ,UAAW,EAAGhlB,WACPA,EAAKO,QAGVw1B,GAA4B/1B,MAIlCsyB,GAAen0B,QAAUg5B,EAEzB7C,EAASC,gBAAmBj5B,IACtBA,EAAMiC,KAAKqK,KAAO,IACpB+oB,EAAexyB,QAAQnF,KAAKsC,EAAMiC,MAC9B+0B,GAAen0B,SACZm0B,GAAen0B,QAAQmnB,UAAUhqB,EAAMiC,MAAM+uB,MAAO7Z,IACvDF,QAAQG,KACN,qCAAqCD,aAAiBsK,MAAQtK,EAAMuK,QAAUjjB,OAAO0Y,UAO/F6hB,EAASrP,QAAU,KACjBoQ,GAAc,6CAA6C,IAG7Df,EAASE,OAASxf,UAChBsa,GAAe,GACfiB,EAAepyB,SAAU,EACzBozB,EAAiBpzB,QAAU,KAC3By1B,KAEAG,KACAC,KAEA,MAAMoD,EAAgBjG,EAAwBhzB,QAC9CgzB,EAAwBhzB,SAAU,EAElC,MAAM8iB,EAAO,IAAIC,KAAKyP,EAAexyB,QAAS,CAC5C5G,KAAM+8B,EAAS5U,UAAY,eAE7BiR,EAAexyB,QAAU,GAEzB,MAAMk5B,EAAe/E,GAAen0B,QAGpC,GAFAm0B,GAAen0B,QAAU,KAErBi5B,EAIF,OAHA,MAAAC,GAAAA,EAAcrR,SACdgQ,UACAhG,EAAkB,MAIpB,GAAkB,IAAd/O,EAAKrZ,KAKP,OAJA,MAAAyvB,GAAAA,EAAcrR,SACdgQ,KACAhG,EAAkB,WAClBqF,GAAc,+CAA+C,GAI/D9F,GAAkB,GAClBS,EAAkBxC,IAElB,IACE,GAAI6J,EAAc,CAChBhE,KACA,MAAM7J,QAAkB6N,EAAatR,OAOrC,GANIyD,EAAUrF,YAAcqF,EAAUrF,aAAe0M,EAAa1yB,UAChE0yB,EAAa1yB,QAAUqrB,EAAUrF,WACL,oBAAjB5P,cACTA,aAAaR,QAAQuZ,GAAgB9D,EAAUrF,aAG/CqF,EAAUxpB,KAAKO,OAIjB,OAHAw1B,GAA4BvM,EAAUxpB,MACtCgwB,EAAkBxC,eACZ0I,GAAoB1M,EAAUxpB,MAGxC,CACF,OAASyS,GACPF,QAAQG,KACN,4EAA4ED,aAAiBsK,MAAQtK,EAAMuK,QAAUjjB,OAAO0Y,KAEhI,CAAA,QACEujB,IACF,CAEAzjB,QAAQC,KAAK,2EACbwd,EAAkBxC,SA7dAxY,OAAOiM,IAC7B,IAAK8B,EAAOyB,UAEV,YADA6Q,GAAc,uCAAuC,GAIvD,MAAMV,EAAe1B,KACrB5D,GAAU,GACVE,GAAkB,GAClBC,GAAc,GACdE,GAAoB,GACpBC,GAAkB,GAClBC,GAAkB,GAClBiE,KACA7D,EAAkBxC,IAClB6E,GAA6Bl0B,SAAU,EAEvC,IACE,MAAMm5B,EAAWrW,EAAK1pB,MAAQ,aACxBggC,EAAYD,EAAS/e,SAAS,OAChC,MACA+e,EAAS/e,SAAS,OAChB,MACA+e,EAAS/e,SAAS,SAAW+e,EAAS/e,SAAS,OAC7C,MACA,OACFkR,EAAO,IAAI+N,KAAK,CAACvW,GAAO,eAAesW,IAAa,CACxDhgC,KAAM+/B,IAGRnD,KAEA,MAAMtJ,EAAc5Y,KAAiB/K,QAG/BkvB,EAAsBphB,MAC1BxX,IAEA,MAAMkvB,EAA2B,CAC/B/P,KAAMnf,EAAKmf,KAKXD,QAASlf,EAAKkf,WACXlf,EAAKguB,MAEV,OAAOhP,GAAsBkQ,IAGzBmI,EAAa3L,GACjBnG,EAAOoS,eACP1L,EACA1G,EAAOyB,UACPqM,EAAa1yB,QACb,CACEwsB,MAAO5H,EAAO4H,MACdxE,MAAOpD,EAAOoD,MACd0E,cACAzE,qBAEF,CACEyD,iBAAkB,KACXsJ,GAAsBwB,IAC3BtB,MAEFpJ,gBAAkB1sB,IAChB,IAAK41B,GAAsBwB,GAAe,OACtCp3B,EAAK4mB,YAAc5mB,EAAK4mB,aAAe0M,EAAa1yB,UACtD0yB,EAAa1yB,QAAUZ,EAAK4mB,WACA,oBAAjB5P,cACTA,aAAaR,QAAQuZ,GAAgB/vB,EAAK4mB,aAI9C,MAAMvG,EAAargB,EAAK2sB,UAAU3pB,OAClC,GAAIqd,EAAY,CACd,MAAM6Z,EAAmBvF,GAAmB/zB,QAC5C+zB,GAAmB/zB,QAAUyf,EACiB,OAA1C2U,GAA8Bp0B,SAChCm3B,GAAkB/C,GAA8Bp0B,QAASyf,GACzDoY,MACSyB,IAAqB7Z,GAC9ByX,GAAczX,GAAY,EAE9B,CAEA2R,GAAkB,GAClBC,GAAc,GACdQ,EAAkBxC,KAEpB3I,YAAcuQ,IACPjC,GAAsBwB,IACvBS,GAAOA,IAAQvE,EAAa1yB,UAC9B0yB,EAAa1yB,QAAUi3B,EACK,oBAAjB7gB,cACTA,aAAaR,QAAQuZ,GAAgB8H,KAI3CrK,iBAAmB1V,IACZ8d,GAAsBwB,KAC3BpF,GAAkB,GAClBC,GAAc,GACdI,GAAkB,GACdyC,GAA6Bl0B,UAC/Bk0B,GAA6Bl0B,SAAU,EACvC6xB,EAAkB,OAIpBmC,GAAwBh0B,SAAWkX,EAEG,OAAlCqc,GAAsBvzB,QACxBuzB,GAAsBvzB,QAAUk3B,GAC9BlD,GAAwBh0B,SACxB,GAGFm3B,GACE5D,GAAsBvzB,QACtBg0B,GAAwBh0B,WAI9B2tB,gBAAkB5F,IAChB,IAAKiN,GAAsBwB,GAAe,OAC1C3B,GAAQ,aACRX,GAA6Bl0B,SAAU,EACvC6xB,EAAkB,MAClBR,GAAc,GACdE,GAAoB,GAEpB,MAAM6F,EACJrP,GAAiBiM,GAAwBh0B,QAE3Ci0B,GAAuBj0B,QAAU,KACjCg0B,GAAwBh0B,QAAUo3B,EAEI,OAAlC7D,GAAsBvzB,QACxBm3B,GACE5D,GAAsBvzB,QACtBo3B,GAGF7D,GAAsBvzB,QAAUk3B,GAC9BE,GACA,IAINrK,oBAAsBlrB,IACfmzB,GAAsBwB,IACtB5L,GACHhG,EAAOoS,eAAgBn1B,EAAM+iB,EAAOoD,MACpCC,EAAoBrqB,GAAUy5B,GAAuBz5B,EAAO44B,IAC5DrI,MAAOlK,GAAQ7P,QAAQG,KAAK,kCAAmC0P,KAEnEgJ,YAAcJ,IACZ,GAAKmI,GAAsBwB,GAA3B,CACI3J,EAAMryB,OAAS,GACjBq6B,GAAQ,YAEVpD,GAAkB,GAClBI,EAAkBxC,IAGlB,IAAA,MAAWhwB,KAAQwtB,EAAO,CACxB,MAAMyK,EACU,aAAdj4B,EAAKmf,KACD,sBAAsBnf,EAAKguB,KAAKvkB,KAAO,KACzB,mBAAdzJ,EAAKmf,KACH,0BACc,aAAdnf,EAAKmf,KACH,cAAcnf,EAAKguB,KAAKtR,QAAU,KACpB,WAAd1c,EAAKmf,KACH,gBACAnf,EAAKmf,KAEjB0Y,GAAc,GAAGI,KAAa,GAE9BxG,EAAayG,IACX,MAAMC,EAAOD,EAAKA,EAAK/8B,OAAS,GAChC,OAAIg9B,IAASA,EAAKtH,OACT,IACFqH,EAAK16B,MAAM,GAAG,GACjB,IAAK26B,EAAMp+B,KAAM,SAGdm+B,GAEX,CAGAhE,GAAsBvzB,QAAU,KAChCg0B,GAAwBh0B,QAAU,EApCQ,GAsC5CwtB,aAAc,CAAC+L,EAASC,EAAWC,OAInC1L,YAAa,CAAC2L,EAAYC,KACnB3E,GAAsBwB,KAE3B3B,GAAQ,YACRxD,GAAc,GACdQ,EAAkBxC,MAEpB5N,mBAAqB7jB,IACnBy5B,GAAuBz5B,EAAO44B,IAEhC3S,QAAUI,IACH+Q,GAAsBwB,KAC3BtC,GAA6Bl0B,SAAU,EACvC6xB,EAAkB,MAClBqF,GAAc,SAASjT,KAAO,MAGlCgU,GAGFxF,EAA0BzyB,QAAU02B,QAC9BA,EAAW3N,IAOnB,OAASzU,GACP,IAAK0gB,GAAsBwB,GAAe,OAE1CtC,GAA6Bl0B,SAAU,EACvC6xB,EAAkB,KACpB,CAAA,QACEiG,GAAoBtB,EACtB,GAkPUoD,CAAgB9W,IAGX,QAATqH,GApOS,EAACjB,EAAqBiN,KACrC,MAAM0D,EACJxuB,OAAOyuB,cACNzuB,OACE0uB,mBAEL,IAAKF,EACH,OAGF,MAAMv/B,EAAU,IAAIu/B,EACpB/G,EAAgB9yB,QAAU1F,EAE1B,MAAM0/B,EAAW1/B,EAAQ2/B,iBACzBD,EAASE,QAAU,IAEnB,MAAMC,EAAS7/B,EAAQ8/B,wBAAwBlR,GAC/C6J,EAAU/yB,QAAUm6B,EACpBA,EAAOE,QAAQL,GAEf,MAAMM,EAAY,IAAInZ,WAAW6Y,EAASO,mBAC1C3H,EAAgB5yB,QAAU,KAC1B,IAAIw6B,GAAiB,EAErB3H,EAAe7yB,QAAUqL,OAAOqY,YAAY,KAC1C,IAAK0O,EAAepyB,SAA8B,aAAnBm2B,EAASv4B,MAEtC,YADAg4B,KAIFoE,EAASS,qBAAqBH,GAE9B,IAAII,EAAM,EACV,IAAA,MAAWl9B,KAAS88B,EAClBI,GAAOl9B,EAKT,GAHgBk9B,EAAMJ,EAAU9/B,OACP,IA/sCT,IAitCY,CAC1B,GAAgC,OAA5Bo4B,EAAgB5yB,QAElB,YADA4yB,EAAgB5yB,QAAUqV,KAAKC,OAIjC,MAAMqlB,EAAkBtlB,KAAKC,MAAQsd,EAAgB5yB,QAIrD,YAHIw6B,GAAkBG,EAvtCF,KAwtClBxC,KAGJ,CAEAqC,GAAiB,EACjB5H,EAAgB5yB,QAAU,MACzB,KA+KC46B,CAAS1R,EAAQiN,GAGnBA,EAAS0E,MAAM,KACfzH,EAAiBpzB,QAAUmqB,EAC3BgH,GAAe,GACfiB,EAAepyB,SAAU,EAnjC3By1B,KACA9B,GAAsB3zB,QAAUqV,KAAKC,MACrCqc,EAAuB,GAEvBiC,GAA0B5zB,QAAUqL,OAAOqY,YAAY,KACrD,MAAMoX,EAAYnH,GAAsB3zB,QAKxC2xB,EAJkB,OAAdmJ,EAImBzlB,KAAKC,MAAQwlB,EAHX,IAIxB,KA2iCGzH,GAAyBrzB,UAC3BqzB,GAAyBrzB,SAAU,EACnCm4B,KAEJ,OAAS7jB,GACP,MAAMuZ,EA/zCW,CAACvZ,GAClBA,aAAiBsK,MACZtK,EAAMuK,QAER,kBA2zCYkc,CAAezmB,IAC1BuZ,EAAOjxB,cAAcwd,SAAS,eAAiByT,EAAOjxB,cAAcwd,SAAS,aAC/Eka,GAAwBt0B,SAAU,GAEpCi2B,KACApE,EAAkB,MAClBqF,GAAc,oBAAoBrJ,KAAU,GAC5C+H,KACAC,KACAxC,GAAyBrzB,SAAU,EACnCmxB,GAAe,GACfiB,EAAepyB,SAAU,EACzBy1B,IACF,CAAA,QACOrD,EAAepyB,SAAYkyB,EAAUlyB,SACxC6xB,EAAkB,MAEpByB,GAAyBtzB,SAAU,CACrC,CArMA,GAwMIg7B,GAAkB,KACtB/H,EAAiBjzB,QAAU,KAC3BmzB,EAAoBnzB,SAAU,EAC9B21B,MAgDIsF,GACJ99B,IAIA,GAFAA,EAAM+9B,iBAEF/9B,EAAMuK,cAAcyzB,sBACtB,IACEh+B,EAAMuK,cAAcyzB,sBAAsBh+B,EAAMi+B,UAClD,CAAA,MAEA,CAGF,MAAMN,EAAY7H,EAAiBjzB,QAC7Bq7B,EAAUlI,EAAoBnzB,QAGpC,GAFAg7B,KAEkB,OAAdF,EACF,OAGF,GAAIO,EAMF,YALIjJ,EAAepyB,QACjBm4B,KACS7E,GAAyBtzB,UAClCqzB,GAAyBrzB,SAAU,IAMF,QAv8CP,EAChC+W,EACAukB,EA7D+B,MA8DXvkB,GAAcukB,EAAc,OAAS,MAo8CnDC,CADalmB,KAAKC,MAAQwlB,IAEvBpD,GAAe,QAgDxBjD,GAAU,KACR,IAAKxM,GAAqBqM,GAAwBt0B,QAAS,OAC3D,MAAMw7B,EAAQnwB,OAAOtK,WAAW,KACzBqxB,EAAepyB,SAAYkyB,EAAUlyB,SAAYszB,GAAyBtzB,SAAYs0B,GAAwBt0B,SAC5G03B,GAAe,QAErB,KACH,MAAO,IAAMrsB,OAAO7J,aAAag6B,IAChC,CAACvT,IAEJ,MAAMwT,GAAW,KACf1G,KACAP,GAAoBx0B,SAAU,EAC9Bg2B,KACAxV,KACAyV,KACAkC,GAAc,CAAEE,SAAS,IACzBzC,KACAC,KACAH,KACAxE,GAAU,IAIRR,IACFA,EAAW1wB,QAAU,CACnB03B,eAAgB,KACdpD,GAAwBt0B,SAAU,EAC7B03B,GAAe,QAEtBgE,gBAAiB,KACflb,KACAyV,KACA,MAAME,EAAW7D,EAAYtyB,QACzBm2B,GAA+B,aAAnBA,EAASv4B,MACvBu6B,GAAc,CAAEE,SAAS,KAEzBzC,KACAC,OAGJ4F,cAIJ,MAAME,GAAyC,CAC7C12B,SAAU,QACVE,OAAQ,OACRD,MAAO,OACPnC,MAAO,QACPqE,UAAW,QACXvB,gBAAiB,uBACjBD,aAAcrD,GACdsB,QAASuH,EAAS,OAAS,OAC3BhG,cAAe,SACfkK,SAAU,SACV/J,OAAQ,QACRq2B,UAAWxwB,EAAS,OAAS,WAAW3I,KACxC4W,UAAW7W,GACXgD,WAAY,uBAgBRq2B,GAA+C,CACnDt1B,WAAY,OACZR,OAAQ,OACRC,OAAQ,UACRU,QAAS,MACTd,aAAc,MACdE,MAAOpE,GAAOG,KACdgC,QAAS,OACTwB,WAAY,SACZY,eAAgB,SAChBC,WAAY,SAASzD,wBAAsCA,MAqCvDq5B,GAA8C,CAClDC,KAAM,IACNp2B,UAAW,OACXC,aAAc,OACdE,MAAOpE,GAAOG,KACd2E,SAAU,OACV3C,QAAS,OACTwB,WAAY,SACZqB,QAAS,SACTs1B,WAAY,SACZ1sB,SAAU,SACV2sB,aAAc,WACdptB,QAAS,OAULqtB,GAAiD,CACrDx2B,SAAU,OACVc,SAAU,OACV21B,WAAY,MACZr2B,MAAOpE,GAAOG,KACdu6B,UAAW,SAGPC,GAAkD,CACtDt5B,MAAO,OACPC,OAAQ,OACR4C,aAAc,QACdW,WAAY,cACZ1C,QAAS,OACTwB,WAAY,SACZY,eAAgB,SAChBD,OAAQ,UACRF,MAAO,UACPC,OAAQ,qCACRG,WAAY,aAAazD,MAGrB65B,GAAiB93B,GAA4C,QAA7B4uB,EAAiBpzB,QACjDoG,GAAiB3B,IAAWD,EAC5B+3B,GAAoB93B,EAE1B,SACG,MAAA,CAAItB,UAAU,oBAAoB1G,MAAOk/B,GACxCxhC,SAAA,CAAAyJ,EAAC,QAAA,CAAOzJ,SAAA,kTAaKuH,GAAOG,22CAoDpBmF,EAAC,MAAA,CAAIvK,MA/KsC,CAC7CiK,QAAS,YACT7C,QAAS,OACToC,eAAgB,gBAChBZ,WAAY,UA4KRlL,SAAA,CAAAyJ,EAACf,GAAA,CACCC,ICr3DK,yhIDs3DLG,MAAM,aACNxG,MAAO,CAAE+/B,SAAU,OAAQx5B,OAAQ,QACnCE,aAAa,IAEf8D,EAAC,MAAA,CAAIvK,MA/K2C,CACpDoH,QAAS,OACTwB,WAAY,SACZC,IAAK,OA6KCnL,SAAA,CAAAyJ,EAAC,SAAA,CACCxK,KAAK,SACL+J,UAAU,mBACV1G,MAAOo/B,GACPj1B,QA/RY,KACpBmuB,KACAP,GAAoBx0B,SAAU,EAC9Bg7B,KACA3H,GAAyBrzB,SAAU,EAEnCg2B,KACAxV,KACAyV,KAEI3D,EAAYtyB,SAAyC,aAA9BsyB,EAAYtyB,QAAQpC,MAC7Cu6B,GAAc,CAAEE,SAAS,KAEzBrF,EAAwBhzB,SAAU,EAClC41B,KACAC,MAGFJ,KACA9D,EAAuB,GAEvBxB,GAC0B,oBAAjB/Z,aAA+BA,aAAe,MAGvDsc,EAAa1yB,QAAU,KACvB,MAAMy8B,EAAkBxM,GAAsBrL,EAAO2K,WACrD8C,EAAiBryB,QAAUqwB,GAAiBoM,GAC5C3L,EAAY2L,GAEZvL,GAAU,GACVgB,EAAUlyB,SAAU,EACpBmxB,GAAe,GACfiB,EAAepyB,SAAU,EACzB01B,MA8PQ,aAAW,yBACXzyB,MAAM,yBAEN9I,WAAC0I,GAAA,CAAQC,IEn4DN,y5GFm4D+BC,MAAO,OAG3Ca,EAAC,SAAA,CACCxK,KAAK,SACL+J,UAAU,mCACV1G,MAAO,IACFo/B,GACHh4B,QAAS,OACTwB,WAAY,SACZY,eAAgB,UAElBW,QAASC,EACT,aAAW,gBACX5D,MAAM,gBAEN9I,SAAAyJ,EAACf,GAAA,CACC,eAAc,IACdQ,OAAQ,eACRP,IAAKH,GACLI,MAAO,eAMd,MAAA,CAAItG,MA/LiD,CACxDiK,QAAS,WACTW,UAAW,OACX00B,KAAM,IACNp2B,UAAW,KA2L2BpM,IAAKs6B,GACvC15B,SAAAyJ,EAAC,MAAA,CAAInH,MAzL0C,CACnDoH,QAAS,OACTuB,cAAe,SACfE,IAAK,QAsL8B/L,IAAKu6B,GACjC35B,SAAAm2B,EAASvwB,IAAK8e,IACbjb,SAAC,MAAA,CAECnH,MACmB,SAAjBoiB,EAAQzlB,KACJ,CACEsN,QAAS,WACTF,SAAU,OACVC,WAAY,MACZX,MAAO,yBACPq2B,WAAY,IACZt2B,gBAAiB,4BACjBD,aAAc,OACd82B,UAAW,aACXF,SAAU,QAlMRtM,EAoMSrR,EAAQqR,OApMjB,CACpBsM,SAAU,MACV91B,QAASwpB,EAAS,WAAa,UAC/BtqB,aAAcrD,GACdiE,SAAU,OACVC,WAAY,OACZk2B,SAAU,aACVX,WAAY,WACZU,UAAWxM,EAAS,WAAa,aACjCrqB,gBAAiBqqB,EAASxuB,GAAOI,YAAc,GAC/CgE,MAAOoqB,EAASxuB,GAAOK,gBAAkB,2BA6L9B5H,SAAA0kB,EAAQhd,MAjBJgd,EAAQzS,IAtLJ,IAAC8jB,QA6MlBlpB,EAAC,MAAA,CAAIvK,MAhMsC,CAC7CiK,QAAS,YACT7C,QAAS,OACTwB,WAAY,SACZY,eAAgB,gBAChBX,IAAK,OA4LDnL,SAAA,CAAAyJ,EAAC,OAAInH,MAAO,IAAKq/B,GAAkB51B,WAAY,yBAC5C/L,SAAA63B,EACCpuB,EAAC,QAAKT,UAAU,oBAAoBF,MAAOid,EACxC/lB,SAAA+lB,IAEDuQ,EACFzpB,EAAC,MAAA,CACCvK,MAAO,CACLoH,QAAS,OACTwB,WAAY,SACZC,IAAK,OAGPnL,SAAA,CAAAyJ,EAAC,OAAA,CACCnH,MAAO,CACL+J,SAAU,OACVqI,QAAS,MACTmtB,WAAY,UAEf7hC,SAAA,oBAGDyJ,EAAC,SAAA,CACCxK,KAAK,SACLwN,QAAS6pB,EACT,aACExI,EACI,+BACA,4BAENxrB,MAAO,CACLsG,MAAO,OACPC,OAAQ,OACR4C,aAAc,OACdG,OAAQ,OACRC,OAAQ,UACRU,QAAS,MACT7C,QAAS,OACTwB,WAAY,SACZQ,gBAAiBoiB,EACbvmB,GAAOC,QACP,yBACJuE,WAAY,oBAAoBzD,KAChCsB,WAAY,KAGd5J,SAAAyJ,EAAC,OAAA,CACCnH,MAAO,CACLsG,MAAO,OACPC,OAAQ,OACR4C,aAAc,MACdC,gBAAiB,UACjBhC,QAAS,QACTqC,WAAY,aAAazD,KACzBkF,UAAWsgB,EACP,mBACA,gBACJ5O,UAAW,oCAKjB,OAGNrS,EAAC,MAAA,CAAIvK,MA3O2C,CACpDoH,QAAS,OACTwB,WAAY,SACZC,IAAK,MACLvB,WAAY,KAwOL5J,SAAA,CAAAqK,IACE,OAAA,CAAK/H,MAAOy/B,GACV/hC,SAAA21B,GAAiB4B,KAElB,KAEF9tB,EAAC,SADFwC,GACE,CACChN,KAAK,SACL+J,UAAU,mBACV1G,MAAO4/B,GACPz1B,QAAS60B,GACT,aAAW,gBACXx4B,MAAM,gBAEN9I,SAAAyJ,EAACf,GAAA,CACC,eAAc,IACdQ,OAAQ,yBACRP,IAAKF,GACLG,MAAO,MAIV,CACC3J,KAAK,SACL+J,UAAU,mBACV1G,MAAO4/B,GACPO,cA3gBVz/B,IAIA,GAFAA,EAAM+9B,kBAEFhJ,EAAUlyB,QAId,GAAIoyB,EAAepyB,QAEgB,QAA7BozB,EAAiBpzB,QACnBm4B,GAAc,CAAEE,SAAS,IAEzBF,SALJ,CAcA,GAJAlF,EAAiBjzB,QAAUqV,KAAKC,MAChC6d,EAAoBnzB,SAAU,EAC9B21B,KAEIx4B,EAAMuK,cAAcm1B,kBACtB,IACE1/B,EAAMuK,cAAcm1B,kBAAkB1/B,EAAMi+B,UAC9C,CAAA,MAEA,CAGFlI,EAAkBlzB,QAAUqL,OAAOtK,WAAW,KAEb,OAA7BkyB,EAAiBjzB,SACjBkyB,EAAUlyB,SACVoyB,EAAepyB,UAKjBmzB,EAAoBnzB,SAAU,EACzB03B,GAAe,WA/9CO,IAu8C7B,GA4fUoF,YAAa7B,GACb8B,gBA5bV5/B,IAEA89B,GAAmB99B,IA2bT6/B,SAAUT,GACV,aAAYD,GAAiB,iBAAmB93B,EAAc,eAAiB,eAC/EvB,MACEq5B,GACI,iBACA93B,EACE,eACA,2CAGRrK,SAAAyJ,EAACf,GAAA,CACC,eAAc,IACdQ,OAAQ,yBACRP,IAAKw5B,GAAiB35B,GAAmBD,GACzCK,MAAO,iBGtgEjBk6B,GAAqC,CACzCjG,eAAgB,uBAChB3Q,UAAW,GACXmG,MAPwB,qBAQxBxE,MAAO,QACP5O,UAAW1X,GAAOC,QAClB4tB,UARyB,SAcrBltB,GAAqB7E,IACzB,MAAM2E,EAAU3E,EAAM4E,OACtB,IALsB,CAAC5E,GACvB,qCAAqCjB,KAAKiB,GAIrC0/B,CAAgB/6B,GACnB,OAAO86B,GAAe7jB,UAExB,GAAuB,IAAnBjX,EAAQ3H,OAAc,CACxB,MAAMtC,EAAIiK,EAAQ,GACZpJ,EAAIoJ,EAAQ,GACZxG,EAAIwG,EAAQ,GAClB,MAAO,IAAIjK,IAAIA,IAAIa,IAAIA,IAAI4C,IAAIA,IAAIiB,aACrC,CACA,OAAOuF,EAAQvF,eAGXugC,GAAgB,CAACC,EAAkBC,KACvC,MACMrpB,EADa3R,GAAkB+6B,GACdvgC,MAAM,GACvBygC,EAAazC,GAA0Bv4B,SAAS0R,EAAInX,MAAMg+B,EAAOA,EAAQ,GAAI,IAE7E0C,EAAUC,GACDA,GAAW,EAAIH,GACxBI,EAASD,IAA4BhnB,OAH5BhZ,EAGkCggC,EAHR7mB,KAAKD,IAAI,EAAGC,KAAKF,IAAI,IAAKE,KAAK+mB,MAAMlgC,MAGpBmiB,SAAS,IAAI0C,SAAS,EAAG,KAHrE,IAAC7kB,GAKTtF,EAAIqlC,EAAOD,EAAU,IACrBvkC,EAAIwkC,EAAOD,EAAU,IACrB3hC,EAAI4hC,EAAOD,EAAU,IAE3B,MAAO,IAAIG,EAAMvlC,KAAKulC,EAAM1kC,KAAK0kC,EAAM9hC,MAGnCgiC,GAAcvkB,IAClB,MAAMqG,EAAapd,GAAkB+W,GACrC1X,GAAOC,QAAU8d,EACjB/d,GAAOE,aAAeu7B,GAAc1d,GAAY,KAChD/d,GAAOI,YAAc2d,GAuCjBme,GAAyB,mCACzBC,GAAoB,QACpBC,GAAsB,8BAkBtBC,GAAc,EAAGnZ,aAErB,MAAOoZ,EAAYC,GAAiBlN,GAA6BnM,IAC1DsZ,EAAaC,GAAkBpN,IAAS,GAG/C0D,GAAU,KACR,IAAK7P,EAAOyB,UAEV,YADA8X,GAAe,GAGjB,IAAIC,GAAY,EAsBhB,MAlFsBvnB,OACxByI,EACA+G,KAEA,IACE,MAAMvd,EAAMwW,EAAQ3iB,QAAQ,OAAQ,IAC9B0hC,QAAY7V,MAAM,GAAG1f,cAAgBud,YAC3C,OAAKgY,EAAI3V,SACK2V,EAAIre,OADE,IAEtB,CAAA,MACE,OAAO,IACT,GAmDEse,CAAkB1Z,EAAOoS,eAAgBpS,EAAOyB,WAAW1nB,KAAM4/B,IAC/D,IAAIH,EAAJ,CACA,GAAIG,EAAQ,CACV,MAAMC,EAA6B,IAC9B5Z,EACHxL,UAAW/W,GAAkBk8B,EAAOE,YAAc7Z,EAAOxL,WACzDoT,MAAO+R,EAAO/R,OAAS5H,EAAO4H,MAC9B+C,UAAWgP,EAAOG,YAAc9Z,EAAO2K,UACvCvH,MACmB,UAAjBuW,EAAOvW,OAAsC,WAAjBuW,EAAOvW,OAAuC,QAAjBuW,EAAOvW,MAC5DuW,EAAOvW,MACPpD,EAAOoD,OAGf2V,GAAWa,EAAOplB,WAClB6kB,EAAcO,EAChB,CACAL,GAAe,EAhBA,IAmBV,KAAQC,GAAY,IAC1B,CAACxZ,IAGJ,MAAO+Z,EAAQC,GAAa7N,GAAS,IACP,oBAAjB3a,cAC2C,SAA7CA,aAAanC,QAAQ,sBAKzBvP,EAAYm6B,GAAiB9N,IAAS,IACtC+N,EAAwBC,GAA6BhO,GAAS,IACvC,oBAAjB3a,cAG6C,SAAjDA,aAAanC,QAAQ2pB,MAIvBp5B,EAAa2sB,GAAkBJ,IAAS,IACxCtsB,EAAQysB,GAAaH,IAAS,IAC9BnsB,EAAgBo6B,GAAqBjO,GAAwB,OAC7DkO,EAAkBC,GAAuBnO,IAAS,GAGnDoO,EAAiBhN,GAAgC,MAEjDiN,GpBtMs+CvnC,EoBsMn8CgK,IACvCm9B,EAAkBn9B,GACL,OAATA,GAAeq9B,GAAoB,IpBxM+8CjnC,EAAE,EAAEoE,GAAE,WAAW,OAAOxE,CAAC,EoByM9gD,KpBzM89C,IAAWA,EoB4M5+C48B,GAAU,KACR,GAAIqK,EAEF,YADAD,GAAc,GAGhB,GAAIF,EAAQ,OACZ,GAA4B,oBAAjBvoB,cAC0C,SAA/CA,aAAanC,QAAQ,sBAAkC,OAG7D4qB,GAAc,GACd,MAAMrD,EAAQz6B,WAAW,KACvB89B,GAAc,GACc,oBAAjBzoB,cACTA,aAAaR,QAAQ,qBAAsB,SAE5C,KACH,MAAO,IAAMpU,aAAag6B,IACzB,CAACmD,EAAQG,IAEZ,MAAMO,EAAe,KACnB,MAAMC,GAAYX,EAClBC,EAAUU,GACVT,GAAc,GACc,oBAAjBzoB,cACTA,aAAaR,QAAQ,mBAAoBha,OAAO0jC,KAoCpD,OAdA7K,GAAU,KACR,MAAM8K,EAAgBpnC,IACN,WAAVA,EAAEmB,KAAoBqlC,IACxBC,GAAU,GACkB,oBAAjBxoB,cACTA,aAAaR,QAAQ,mBAAoB,WAM/C,OADA7W,SAASjC,iBAAiB,UAAWyiC,GAC9B,IAAMxgC,SAAShC,oBAAoB,UAAWwiC,IACpD,CAACZ,IAECT,EAGHl3B,EAAAM,EAAA,CACGnN,SAAA,EAACwkC,GACA/6B,EAACQ,GAAA,CACCC,WAAY,WAAM,OAAA,OAAA8Q,EAAAgqB,EAAen/B,cAAf,EAAAmV,EAAwBuiB,kBAC1CpzB,kBAAmB,WAAM,OAAA,OAAA6Q,EAAAgqB,EAAen/B,cAAf,EAAAmV,EAAwBumB,mBACjDn3B,WAAY,WAAM,OAAA,OAAA4Q,EAAAgqB,EAAen/B,cAAf,EAAAmV,EAAwBsmB,YAC1Cj3B,cACAC,SACAC,aACAC,cAAe,KACbk6B,GAAc,GACdQ,KAEFz6B,eAAgBq6B,EAAmB,KAAOr6B,EAC1CC,eAAgB,IAAMw6B,IACtBv6B,eAAgB,IAAMo6B,GAAoB,KAG9Ct7B,EAAC4sB,GAAA,CACC3pB,QA7Cc,KAClB+3B,GAAU,GACkB,oBAAjBxoB,cACTA,aAAaR,QAAQ,mBAAoB,SAE3CxB,QAAQC,KAAK,8BAyCTuQ,OAAQoZ,EACR/V,kBAAmB6W,EACnBrO,sBAzD0B,KAC9B,MAAM1B,GAAQ+P,EACdC,EAA0BhQ,GACE,oBAAjB3Y,cACTA,aAAaR,QAAQgoB,GAAwBhiC,OAAOmzB,IAEtD3a,QAAQC,KAAK,8CAA8C0a,MAoDvD3jB,QAASuzB,EACTjO,WAAYyO,EACZxO,kBAAmBQ,EACnBP,aAAcM,EACdL,gBAAiBuO,OA9BE,MAoCrBI,GAAe,uFAID3B,mRAWAA,6HAMAA,sLAUpB,IAAI4B,GAAsC,KACtCC,GAAsC,KACtCC,IAAmB,EACnBC,IAAgB,EAMb,MAAMC,GAAO,CAACzH,EAAwB,MAC3C,GAAIwH,GAEF,YADAxrB,QAAQG,KAAK,gCA5Na,MAC5B,GAAwB,oBAAbxV,SACT,OAEF,GAAIA,SAAS2Z,eAAeolB,IAC1B,OAEF,MAAMgC,EAAO/gC,SAASoa,cAAc,QACpC2mB,EAAK1zB,GAAK0xB,GACVgC,EAAKC,IAAM,aACXD,EAAKn0B,KAZL,4EAaA5M,SAASihC,KAAKzmB,YAAYumB,IAqN1BG,GAEA,MAAMC,EAvPqB,CAC3B9H,IAAA,CAEApB,eAAgBoB,EAAQpB,gBAAkBiG,GAAejG,eACzD3Q,UAAW+R,EAAQ/R,WAAa4W,GAAe5W,UAC/CmG,MAAOyQ,GAAezQ,MACtBxE,MAAOiV,GAAejV,MACtB5O,UAAW6jB,GAAe7jB,UAC1BmW,UAAW0N,GAAe1N,YA+OJ4Q,CAAqB/H,GAc3C,GAbAuF,GAAWuC,EAAc9mB,WAGrBgf,EAAQgI,aACVX,GAAkB1gC,SAAS2Z,eAAe0f,EAAQgI,aAClDT,IAAmB,IAEnBF,GAAkB1gC,SAASoa,cAAc,OACzCsmB,GAAgBrzB,GAAK,kBACrBrN,SAASyL,KAAK+O,YAAYkmB,IAC1BE,IAAmB,IAGhBF,GAEH,YADArrB,QAAQE,MAAM,8BAIhB,MAAM+rB,EAAaZ,GAAgBY,YAAcZ,GAAgBa,aAAa,CAAEnW,KAAM,SACtFkW,EAAWE,kBAEX,MAAM9jC,EAAQsC,SAASoa,cAAc,SACrC1c,EAAM2Q,YAAcoyB,GAEpB,MAAMgB,EAAYzhC,SAASoa,cAAc,OACzCqnB,EAAUp0B,GAAK,qBAEfi0B,EAAW/X,OAAO7rB,EAAO+jC,GACzBd,GAAkBc,EAGlBljC,IAAQygC,GAAA,CAAYnZ,OAAQsb,IAAmBM,GAC/CZ,IAAgB,EAEhBxrB,QAAQ0J,IAAI,mCAMD2iB,GAAU,KAChBb,KAIDF,KACFpiC,EAAO,KAAMoiC,IACbA,GAAkB,MAGhBD,IAAmBE,IACrB5gC,SAASyL,KAAKvR,YAAYwmC,IAG5BA,GAAkB,KAClBE,IAAmB,EACnBC,IAAgB,EAChBxrB,QAAQ0J,IAAI,qBAMD4iB,GAAU,IAAMd,GAEvBe,GAAQ,CACZd,QACAY,WACAC,YAGoB,oBAAXr1B,SACRA,OAA6Cs1B,MAAQA","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","../node_modules/@heroicons/react/24/outline/esm/ArrowPathIcon.js","../node_modules/@heroicons/react/24/outline/esm/CommandLineIcon.js","../node_modules/@heroicons/react/24/outline/esm/CursorArrowRaysIcon.js","../node_modules/@heroicons/react/24/outline/esm/FaceSmileIcon.js","../node_modules/@heroicons/react/24/outline/esm/HandRaisedIcon.js","../node_modules/@heroicons/react/24/outline/esm/MapIcon.js","../node_modules/@heroicons/react/24/outline/esm/MicrophoneIcon.js","../node_modules/@heroicons/react/24/outline/esm/QueueListIcon.js","../node_modules/@heroicons/react/24/outline/esm/StopIcon.js","../node_modules/@heroicons/react/24/outline/esm/XMarkIcon.js","../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/SvgIcon.tsx","../src/components/ChatWindow.tsx","../src/assets/icons/bulut_logo.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 * as React from \"react\";\nfunction ArrowPathIcon({\n title,\n titleId,\n ...props\n}, svgRef) {\n return /*#__PURE__*/React.createElement(\"svg\", Object.assign({\n xmlns: \"http://www.w3.org/2000/svg\",\n fill: \"none\",\n viewBox: \"0 0 24 24\",\n strokeWidth: 1.5,\n stroke: \"currentColor\",\n \"aria-hidden\": \"true\",\n \"data-slot\": \"icon\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, /*#__PURE__*/React.createElement(\"path\", {\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\",\n d: \"M16.023 9.348h4.992v-.001M2.985 19.644v-4.992m0 0h4.992m-4.993 0 3.181 3.183a8.25 8.25 0 0 0 13.803-3.7M4.031 9.865a8.25 8.25 0 0 1 13.803-3.7l3.181 3.182m0-4.991v4.99\"\n }));\n}\nconst ForwardRef = /*#__PURE__*/ React.forwardRef(ArrowPathIcon);\nexport default ForwardRef;","import * as React from \"react\";\nfunction CommandLineIcon({\n title,\n titleId,\n ...props\n}, svgRef) {\n return /*#__PURE__*/React.createElement(\"svg\", Object.assign({\n xmlns: \"http://www.w3.org/2000/svg\",\n fill: \"none\",\n viewBox: \"0 0 24 24\",\n strokeWidth: 1.5,\n stroke: \"currentColor\",\n \"aria-hidden\": \"true\",\n \"data-slot\": \"icon\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, /*#__PURE__*/React.createElement(\"path\", {\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\",\n d: \"m6.75 7.5 3 2.25-3 2.25m4.5 0h3m-9 8.25h13.5A2.25 2.25 0 0 0 21 18V6a2.25 2.25 0 0 0-2.25-2.25H5.25A2.25 2.25 0 0 0 3 6v12a2.25 2.25 0 0 0 2.25 2.25Z\"\n }));\n}\nconst ForwardRef = /*#__PURE__*/ React.forwardRef(CommandLineIcon);\nexport default ForwardRef;","import * as React from \"react\";\nfunction CursorArrowRaysIcon({\n title,\n titleId,\n ...props\n}, svgRef) {\n return /*#__PURE__*/React.createElement(\"svg\", Object.assign({\n xmlns: \"http://www.w3.org/2000/svg\",\n fill: \"none\",\n viewBox: \"0 0 24 24\",\n strokeWidth: 1.5,\n stroke: \"currentColor\",\n \"aria-hidden\": \"true\",\n \"data-slot\": \"icon\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, /*#__PURE__*/React.createElement(\"path\", {\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\",\n d: \"M15.042 21.672 13.684 16.6m0 0-2.51 2.225.569-9.47 5.227 7.917-3.286-.672ZM12 2.25V4.5m5.834.166-1.591 1.591M20.25 10.5H18M7.757 14.743l-1.59 1.59M6 10.5H3.75m4.007-4.243-1.59-1.59\"\n }));\n}\nconst ForwardRef = /*#__PURE__*/ React.forwardRef(CursorArrowRaysIcon);\nexport default ForwardRef;","import * as React from \"react\";\nfunction FaceSmileIcon({\n title,\n titleId,\n ...props\n}, svgRef) {\n return /*#__PURE__*/React.createElement(\"svg\", Object.assign({\n xmlns: \"http://www.w3.org/2000/svg\",\n fill: \"none\",\n viewBox: \"0 0 24 24\",\n strokeWidth: 1.5,\n stroke: \"currentColor\",\n \"aria-hidden\": \"true\",\n \"data-slot\": \"icon\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, /*#__PURE__*/React.createElement(\"path\", {\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\",\n d: \"M15.182 15.182a4.5 4.5 0 0 1-6.364 0M21 12a9 9 0 1 1-18 0 9 9 0 0 1 18 0ZM9.75 9.75c0 .414-.168.75-.375.75S9 10.164 9 9.75 9.168 9 9.375 9s.375.336.375.75Zm-.375 0h.008v.015h-.008V9.75Zm5.625 0c0 .414-.168.75-.375.75s-.375-.336-.375-.75.168-.75.375-.75.375.336.375.75Zm-.375 0h.008v.015h-.008V9.75Z\"\n }));\n}\nconst ForwardRef = /*#__PURE__*/ React.forwardRef(FaceSmileIcon);\nexport default ForwardRef;","import * as React from \"react\";\nfunction HandRaisedIcon({\n title,\n titleId,\n ...props\n}, svgRef) {\n return /*#__PURE__*/React.createElement(\"svg\", Object.assign({\n xmlns: \"http://www.w3.org/2000/svg\",\n fill: \"none\",\n viewBox: \"0 0 24 24\",\n strokeWidth: 1.5,\n stroke: \"currentColor\",\n \"aria-hidden\": \"true\",\n \"data-slot\": \"icon\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, /*#__PURE__*/React.createElement(\"path\", {\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\",\n d: \"M10.05 4.575a1.575 1.575 0 1 0-3.15 0v3m3.15-3v-1.5a1.575 1.575 0 0 1 3.15 0v1.5m-3.15 0 .075 5.925m3.075.75V4.575m0 0a1.575 1.575 0 0 1 3.15 0V15M6.9 7.575a1.575 1.575 0 1 0-3.15 0v8.175a6.75 6.75 0 0 0 6.75 6.75h2.018a5.25 5.25 0 0 0 3.712-1.538l1.732-1.732a5.25 5.25 0 0 0 1.538-3.712l.003-2.024a.668.668 0 0 1 .198-.471 1.575 1.575 0 1 0-2.228-2.228 3.818 3.818 0 0 0-1.12 2.687M6.9 7.575V12m6.27 4.318A4.49 4.49 0 0 1 16.35 15m.002 0h-.002\"\n }));\n}\nconst ForwardRef = /*#__PURE__*/ React.forwardRef(HandRaisedIcon);\nexport default ForwardRef;","import * as React from \"react\";\nfunction MapIcon({\n title,\n titleId,\n ...props\n}, svgRef) {\n return /*#__PURE__*/React.createElement(\"svg\", Object.assign({\n xmlns: \"http://www.w3.org/2000/svg\",\n fill: \"none\",\n viewBox: \"0 0 24 24\",\n strokeWidth: 1.5,\n stroke: \"currentColor\",\n \"aria-hidden\": \"true\",\n \"data-slot\": \"icon\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, /*#__PURE__*/React.createElement(\"path\", {\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\",\n d: \"M9 6.75V15m6-6v8.25m.503 3.498 4.875-2.437c.381-.19.622-.58.622-1.006V4.82c0-.836-.88-1.38-1.628-1.006l-3.869 1.934c-.317.159-.69.159-1.006 0L9.503 3.252a1.125 1.125 0 0 0-1.006 0L3.622 5.689C3.24 5.88 3 6.27 3 6.695V19.18c0 .836.88 1.38 1.628 1.006l3.869-1.934c.317-.159.69-.159 1.006 0l4.994 2.497c.317.158.69.158 1.006 0Z\"\n }));\n}\nconst ForwardRef = /*#__PURE__*/ React.forwardRef(MapIcon);\nexport default ForwardRef;","import * as React from \"react\";\nfunction MicrophoneIcon({\n title,\n titleId,\n ...props\n}, svgRef) {\n return /*#__PURE__*/React.createElement(\"svg\", Object.assign({\n xmlns: \"http://www.w3.org/2000/svg\",\n fill: \"none\",\n viewBox: \"0 0 24 24\",\n strokeWidth: 1.5,\n stroke: \"currentColor\",\n \"aria-hidden\": \"true\",\n \"data-slot\": \"icon\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, /*#__PURE__*/React.createElement(\"path\", {\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\",\n d: \"M12 18.75a6 6 0 0 0 6-6v-1.5m-6 7.5a6 6 0 0 1-6-6v-1.5m6 7.5v3.75m-3.75 0h7.5M12 15.75a3 3 0 0 1-3-3V4.5a3 3 0 1 1 6 0v8.25a3 3 0 0 1-3 3Z\"\n }));\n}\nconst ForwardRef = /*#__PURE__*/ React.forwardRef(MicrophoneIcon);\nexport default ForwardRef;","import * as React from \"react\";\nfunction QueueListIcon({\n title,\n titleId,\n ...props\n}, svgRef) {\n return /*#__PURE__*/React.createElement(\"svg\", Object.assign({\n xmlns: \"http://www.w3.org/2000/svg\",\n fill: \"none\",\n viewBox: \"0 0 24 24\",\n strokeWidth: 1.5,\n stroke: \"currentColor\",\n \"aria-hidden\": \"true\",\n \"data-slot\": \"icon\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, /*#__PURE__*/React.createElement(\"path\", {\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\",\n d: \"M3.75 12h16.5m-16.5 3.75h16.5M3.75 19.5h16.5M5.625 4.5h12.75a1.875 1.875 0 0 1 0 3.75H5.625a1.875 1.875 0 0 1 0-3.75Z\"\n }));\n}\nconst ForwardRef = /*#__PURE__*/ React.forwardRef(QueueListIcon);\nexport default ForwardRef;","import * as React from \"react\";\nfunction StopIcon({\n title,\n titleId,\n ...props\n}, svgRef) {\n return /*#__PURE__*/React.createElement(\"svg\", Object.assign({\n xmlns: \"http://www.w3.org/2000/svg\",\n fill: \"none\",\n viewBox: \"0 0 24 24\",\n strokeWidth: 1.5,\n stroke: \"currentColor\",\n \"aria-hidden\": \"true\",\n \"data-slot\": \"icon\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, /*#__PURE__*/React.createElement(\"path\", {\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\",\n d: \"M5.25 7.5A2.25 2.25 0 0 1 7.5 5.25h9a2.25 2.25 0 0 1 2.25 2.25v9a2.25 2.25 0 0 1-2.25 2.25h-9a2.25 2.25 0 0 1-2.25-2.25v-9Z\"\n }));\n}\nconst ForwardRef = /*#__PURE__*/ React.forwardRef(StopIcon);\nexport default ForwardRef;","import * as React from \"react\";\nfunction XMarkIcon({\n title,\n titleId,\n ...props\n}, svgRef) {\n return /*#__PURE__*/React.createElement(\"svg\", Object.assign({\n xmlns: \"http://www.w3.org/2000/svg\",\n fill: \"none\",\n viewBox: \"0 0 24 24\",\n strokeWidth: 1.5,\n stroke: \"currentColor\",\n \"aria-hidden\": \"true\",\n \"data-slot\": \"icon\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, /*#__PURE__*/React.createElement(\"path\", {\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\",\n d: \"M6 18 18 6M6 6l12 12\"\n }));\n}\nconst ForwardRef = /*#__PURE__*/ React.forwardRef(XMarkIcon);\nexport default ForwardRef;","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} from \"../styles/constants\";\r\nimport { MicrophoneIcon, StopIcon, XMarkIcon } from \"@heroicons/react/24/outline\";\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 accessibilityMode?: 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 accessibilityMode = false,\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 const popupBoxShadow = accessibilityMode\r\n ? `inset 0 0 0 2px ${COLORS.primary}, ${SHADOW}`\r\n : SHADOW;\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 };\r\n\r\n const showStopButton = isBusy && !isRecording;\r\n const MainIcon = showStopButton ? StopIcon : isRecording ? XMarkIcon : MicrophoneIcon;\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 <XMarkIcon aria-hidden=\"true\" width={14} height={14} strokeWidth={3} />\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: ${popupBoxShadow};\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 <MainIcon\r\n aria-hidden=\"true\"\r\n style={iconStyle}\r\n strokeWidth={2.25}\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 styleSelectors: 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 styleSelectors: 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_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_STYLESHEET_SELECTORS,\r\n MAX_STYLESHEET_RULES,\r\n} from \"./contextConfig\";\r\n\r\nexport const PAGE_CONTEXT_CACHE_VERSION = 3;\r\nexport const PAGE_CONTEXT_CACHE_KEY = \"auticbot_page_context_cache_v3\";\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 STYLESHEET_SELECTOR_PATTERN =\r\n /(:hover|:focus|:active|button|a\\b|input|textarea|select|\\[role=|\\[aria-|\\[data-|\\.btn|\\.link)/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 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): string => {\r\n const compact = value.replace(/\\s+/g, \"-\").replace(/[^a-zA-Z0-9_-]/g, \"\");\r\n return compact || \"\";\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);\r\n return `- ${entry.url} :: ${compactSummary}`;\r\n }),\r\n ].join(\"\\n\");\r\n\r\n return `${current.summary}\\n\\n${historySection}`;\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 buildSelectorSegment = (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 attrCandidates: Array<[name: string, value: string | null]> = [\r\n [\"name\", element.getAttribute(\"name\")],\r\n [\"data-testid\", element.getAttribute(\"data-testid\")],\r\n [\"data-test-id\", element.getAttribute(\"data-test-id\")],\r\n [\"aria-label\", element.getAttribute(\"aria-label\")],\r\n [\"role\", element.getAttribute(\"role\")],\r\n [\"type\", element.getAttribute(\"type\")],\r\n ];\r\n\r\n for (const [attrName, attrValue] of attrCandidates) {\r\n if (attrValue) {\r\n return `${tag}[${attrName}=\"${escapeCssValue(attrValue)}\"]`;\r\n }\r\n }\r\n\r\n const classes = Array.from(element.classList)\r\n .filter(Boolean)\r\n .slice(0, 3)\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 buildSelector = (element: Element): string => {\r\n const segments: string[] = [];\r\n let cursor: Element | null = element;\r\n let depth = 0;\r\n\r\n while (cursor && depth < 4) {\r\n const segment = buildSelectorSegment(cursor);\r\n segments.unshift(segment);\r\n if (segment.startsWith(\"#\")) {\r\n break;\r\n }\r\n cursor = cursor.parentElement;\r\n depth += 1;\r\n }\r\n\r\n return segments.join(\" > \");\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))\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 getComputedStyleSignals = (style: CSSStyleDeclaration): string[] => {\r\n const signals: string[] = [];\r\n\r\n if (style.cursor && style.cursor !== \"auto\") {\r\n signals.push(`cursor:${style.cursor}`);\r\n }\r\n if (style.display) {\r\n signals.push(`display:${style.display}`);\r\n }\r\n if (style.position) {\r\n signals.push(`position:${style.position}`);\r\n }\r\n if (style.zIndex && style.zIndex !== \"auto\") {\r\n signals.push(`z-index:${style.zIndex}`);\r\n }\r\n if (style.pointerEvents && style.pointerEvents !== \"auto\") {\r\n signals.push(`pointer-events:${style.pointerEvents}`);\r\n }\r\n if (style.visibility && style.visibility !== \"visible\") {\r\n signals.push(`visibility:${style.visibility}`);\r\n }\r\n if (style.opacity && style.opacity !== \"1\") {\r\n signals.push(`opacity:${style.opacity}`);\r\n }\r\n\r\n return Array.from(new Set(signals));\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))\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 buildBranchDigest(child, MAX_BRANCH_DEPTH),\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 structural;\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 if (seen.has(text)) {\r\n continue;\r\n }\r\n\r\n seen.add(text);\r\n snippets.push(`- ${text}`);\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 collectSelectorsFromRuleList = (\r\n rules: CSSRuleList,\r\n selectors: Set<string>,\r\n scanned: { count: number },\r\n): void => {\r\n for (const rule of Array.from(rules)) {\r\n if (\r\n scanned.count >= MAX_STYLESHEET_RULES ||\r\n selectors.size >= MAX_STYLESHEET_SELECTORS\r\n ) {\r\n return;\r\n }\r\n\r\n scanned.count += 1;\r\n\r\n if (rule instanceof CSSStyleRule) {\r\n const parts = rule.selectorText\r\n .split(\",\")\r\n .map((selector) => normalizeWhitespace(selector))\r\n .filter(Boolean);\r\n\r\n for (const selector of parts) {\r\n if (!STYLESHEET_SELECTOR_PATTERN.test(selector)) {\r\n continue;\r\n }\r\n selectors.add(selector);\r\n if (selectors.size >= MAX_STYLESHEET_SELECTORS) {\r\n return;\r\n }\r\n }\r\n continue;\r\n }\r\n\r\n if (\"cssRules\" in rule) {\r\n try {\r\n const nestedRules = (rule as CSSMediaRule).cssRules;\r\n collectSelectorsFromRuleList(nestedRules, selectors, scanned);\r\n } catch {\r\n // Ignore inaccessible nested rules.\r\n }\r\n }\r\n }\r\n};\r\n\r\nconst collectStylesheetSelectors = (): string[] => {\r\n const selectors = new Set<string>();\r\n const scanned = { count: 0 };\r\n\r\n for (const stylesheet of Array.from(document.styleSheets)) {\r\n if (\r\n scanned.count >= MAX_STYLESHEET_RULES ||\r\n selectors.size >= MAX_STYLESHEET_SELECTORS\r\n ) {\r\n break;\r\n }\r\n\r\n try {\r\n if (!stylesheet.cssRules) {\r\n continue;\r\n }\r\n collectSelectorsFromRuleList(stylesheet.cssRules, selectors, scanned);\r\n } catch {\r\n // Ignore cross-origin stylesheets.\r\n }\r\n }\r\n\r\n return Array.from(selectors).map((selector) => `- ${selector}`);\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 const styleSignalCounts = 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 computedStyleSignals = getComputedStyleSignals(style);\r\n for (const styleSignal of computedStyleSignals) {\r\n bumpCount(styleSignalCounts, styleSignal);\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 = `- ${label} -> ${absoluteHref}`;\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 = getElementLabel(element);\r\n const styleSignals = computedStyleSignals;\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 (styleSignals.length > 0) {\r\n signalTokens.push(`css:${styleSignals.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 = `- ${tag} ${selector}${signalBlock} (${label})`;\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 `- css footprint: ${formatTopCounts(styleSignalCounts, 10)}`,\r\n \"- listener scope: inline/on* handlers are detected directly; addEventListener handlers are inferred via cues.\",\r\n ];\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 ];\r\n\r\n return {\r\n links: links.slice(0, MAX_LINKS),\r\n interactables,\r\n interactionSignals,\r\n styleSelectors: collectStylesheetSelectors(),\r\n pageBlueprint,\r\n };\r\n};\r\n\r\nexport const buildPageContextSummary = (\r\n input: PageContextSummaryInput,\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(\"Stylesheet Selector Snapshot\", input.styleSelectors),\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 sections.join(\"\\n\\n\");\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 `- ${normalizeWhitespace(element.textContent || \"\")}`,\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 styleSelectors: snapshot.styleSelectors,\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 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 stylesheet selectors to include in summary. */\r\nexport const MAX_STYLESHEET_SELECTORS = 80;\r\n\r\n/** Maximum CSS rules to scan while collecting stylesheet selectors. */\r\nexport const MAX_STYLESHEET_RULES = 700;\r\n","import { getPageContext } from \"./context\";\r\nimport { COLORS } from \"../styles/constants\";\r\n\r\nconst AGENT_CURSOR_ID = \"auticbot-agent-cursor\";\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\nconst CURSOR_DIAMETER_PX = 25;\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\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 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\nconst isVisibleElement = (element: HTMLElement): boolean => {\r\n const style = window.getComputedStyle(element);\r\n return style.display !== \"none\" && style.visibility !== \"hidden\" && style.opacity !== \"0\";\r\n};\r\n\r\nconst getBulutShadowRoots = (): ShadowRoot[] => {\r\n const roots: ShadowRoot[] = [];\r\n\r\n const defaultHost = document.getElementById(\"bulut-container\");\r\n if (defaultHost?.shadowRoot) {\r\n roots.push(defaultHost.shadowRoot);\r\n }\r\n\r\n const allElements = document.querySelectorAll<HTMLElement>(\"*\");\r\n for (const el of allElements) {\r\n if (!el.shadowRoot) {\r\n continue;\r\n }\r\n if (!roots.includes(el.shadowRoot)) {\r\n roots.push(el.shadowRoot);\r\n }\r\n }\r\n\r\n return roots;\r\n};\r\n\r\nconst findAgentUiAnchorElement = (): HTMLElement | null => {\r\n const roots = getBulutShadowRoots();\r\n\r\n for (const root of roots) {\r\n const panel = root.querySelector<HTMLElement>(\".bulut-chat-window\");\r\n if (panel && isVisibleElement(panel)) {\r\n return panel;\r\n }\r\n }\r\n\r\n for (const root of roots) {\r\n const button = root.querySelector<HTMLElement>(\".bulut-fab-container\");\r\n if (button && isVisibleElement(button)) {\r\n return button;\r\n }\r\n }\r\n\r\n return null;\r\n};\r\n\r\nconst getAgentWindowTopLeft = (): { x: number; y: number } => {\r\n const anchor = findAgentUiAnchorElement();\r\n if (!anchor) {\r\n return {\r\n x: CURSOR_DIAMETER_PX / 2,\r\n y: CURSOR_DIAMETER_PX / 2,\r\n };\r\n }\r\n\r\n const rect = anchor.getBoundingClientRect();\r\n return {\r\n x: rect.left + window.scrollX + CURSOR_DIAMETER_PX / 2,\r\n y: rect.top + window.scrollY + CURSOR_DIAMETER_PX / 2,\r\n };\r\n};\r\n\r\nexport const hideAgentCursor = (): void => {\r\n if (typeof document === \"undefined\" || typeof window === \"undefined\") {\r\n return;\r\n }\r\n\r\n const cursor = document.getElementById(AGENT_CURSOR_ID);\r\n if (!(cursor instanceof HTMLElement)) {\r\n return;\r\n }\r\n\r\n setCursorVisibility(cursor, false);\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 }\r\n });\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 const startPosition = getAgentWindowTopLeft();\r\n cursor.style.left = `${startPosition.x}px`;\r\n cursor.style.top = `${startPosition.y}px`;\r\n cursor.style.opacity = \"0\";\r\n const width = CURSOR_DIAMETER_PX;\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 console.info(`[Autic] cursor created color=${baseColor} duration=${CURSOR_MOVE_DURATION_MS}ms`);\r\n return cursor;\r\n};\r\n\r\nconst waitForNextAnimationFrame = async (): Promise<void> => {\r\n const raf =\r\n window.requestAnimationFrame ||\r\n ((callback: FrameRequestCallback) => window.setTimeout(() => callback(performance.now()), 16));\r\n await new Promise<void>((resolve) => {\r\n raf(() => resolve());\r\n });\r\n};\r\n\r\nconst moveCursor = async (x: number, y: number) => {\r\n const cursor = ensureCursor();\r\n if (cursor.dataset.transitionReady !== \"true\") {\r\n cursor.dataset.transitionReady = \"true\";\r\n await waitForNextAnimationFrame();\r\n }\r\n\r\n const startPosition = getAgentWindowTopLeft();\r\n setCursorVisibility(cursor, true);\r\n setCursorPosition(cursor, startPosition.x, startPosition.y);\r\n await new Promise((resolve) => setTimeout(resolve, CURSOR_MOVE_DURATION_MS));\r\n\r\n setCursorPosition(cursor, x, y);\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 setNativeInputLikeValue = (\r\n element: HTMLInputElement | HTMLTextAreaElement,\r\n text: string,\r\n) => {\r\n const prototype =\r\n element instanceof HTMLTextAreaElement\r\n ? HTMLTextAreaElement.prototype\r\n : HTMLInputElement.prototype;\r\n const descriptor = Object.getOwnPropertyDescriptor(prototype, \"value\");\r\n if (descriptor?.set) {\r\n descriptor.set.call(element, text);\r\n } else {\r\n element.value = text;\r\n }\r\n\r\n // Keep both current and default values aligned so client re-focus\r\n // does not appear to \"erase\" tool-filled form fields.\r\n element.defaultValue = text;\r\n element.setAttribute(\"value\", text);\r\n};\r\n\r\nconst typeIntoElement = (element: HTMLElement, text: string) => {\r\n if (element instanceof HTMLInputElement || element instanceof HTMLTextAreaElement) {\r\n element.focus();\r\n setNativeInputLikeValue(element, 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","import {\r\n savePendingAgentResume,\r\n clearPendingAgentResume,\r\n hideAgentCursor,\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 BULUT_AUDIO_STOP_EVENT = \"bulut:audio-stop\";\r\nconst activeAudioElements = new Set<HTMLAudioElement>();\r\nlet audioPlaybackGeneration = 0;\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\nconst registerActiveAudioElement = (audioElement: HTMLAudioElement): void => {\r\n activeAudioElements.add(audioElement);\r\n};\r\n\r\nconst unregisterActiveAudioElement = (audioElement: HTMLAudioElement): void => {\r\n activeAudioElements.delete(audioElement);\r\n};\r\n\r\nconst wasPlaybackStoppedAfter = (generationAtStart: number): boolean =>\r\n audioPlaybackGeneration !== generationAtStart;\r\n\r\nexport const getAudioPlaybackGeneration = (): number => audioPlaybackGeneration;\r\n\r\nexport const stopActiveAudioPlayback = (): void => {\r\n audioPlaybackGeneration += 1;\r\n const active = Array.from(activeAudioElements);\r\n for (const audioElement of active) {\r\n try {\r\n audioElement.dispatchEvent(new Event(BULUT_AUDIO_STOP_EVENT));\r\n audioElement.pause();\r\n audioElement.removeAttribute(\"src\");\r\n audioElement.load();\r\n } catch {\r\n // Ignore playback stop errors.\r\n }\r\n }\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 onForcedStop = () => {\r\n cleanup();\r\n resolve();\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 audioElement.removeEventListener(BULUT_AUDIO_STOP_EVENT, onForcedStop);\r\n };\r\n\r\n audioElement.addEventListener(\"ended\", onEnded);\r\n audioElement.addEventListener(\"error\", onError);\r\n audioElement.addEventListener(BULUT_AUDIO_STOP_EVENT, onForcedStop);\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 const playbackGeneration = getAudioPlaybackGeneration();\r\n if (chunks.length === 0) {\r\n onAudioStateChange?.(\"done\");\r\n return;\r\n }\r\n\r\n if (wasPlaybackStoppedAfter(playbackGeneration)) {\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 registerActiveAudioElement(audioElement);\r\n\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 if (wasPlaybackStoppedAfter(playbackGeneration)) {\r\n onAudioStateChange?.(\"done\");\r\n return;\r\n }\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 unregisterActiveAudioElement(audioElement);\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, expectsReply?: boolean) => 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 const playbackGeneration = getAudioPlaybackGeneration();\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 (wasPlaybackStoppedAfter(playbackGeneration)) {\r\n onAudioStateChange?.(\"done\");\r\n return;\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 const replyExpectsReply = data.expects_reply !== false;\r\n events.onAssistantDone?.(finalReply, replyExpectsReply);\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 if (!isStopped) {\r\n hideAgentCursor();\r\n }\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) {\r\n hideAgentCursor();\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 stopActiveAudioPlayback();\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 const replyExpectsReply = data.expects_reply !== false;\r\n events.onAssistantDone?.(finalReply, replyExpectsReply);\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) {\r\n if (!isStopped) {\r\n hideAgentCursor();\r\n }\r\n return resolve();\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, 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) {\r\n hideAgentCursor();\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 stopActiveAudioPlayback();\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 const replyExpectsReply = data.expects_reply !== false;\r\n events.onAssistantDone?.(finalReply, replyExpectsReply);\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) {\r\n if (!isStopped) {\r\n hideAgentCursor();\r\n }\r\n return resolve();\r\n }\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) {\r\n hideAgentCursor();\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 stopActiveAudioPlayback();\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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\"","export default \"data:audio/mpeg;base64,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VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVQ==\"","export default \"data:audio/mpeg;base64,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qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqgU7bdtbNa5MIRBHgnj4UR9JwIgVBwG4sGQ6iUOI9A8D4gD+UB2EkchSQR4JZYNzUyKpeTJzhe5G6uhMjIwPOFopGnGihQsgHRJAooSJEExgcJJAooD/+rJs9RAqj/URY7JpgTYKAAANIAAAAQAAAaQAAAAgAAA0gAAABIWQTUkROElmHxaqlm7Oz/9nzZqWcuLUkicacUfCakiJxZZlwtGjSini42af/s7P3dtyppyij0FopETgMDMJoLRJGlFHmWpJE4sukDVJVUxBTUUzLjk5LjVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVU=\"","export default \"data:audio/mpeg;base64,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BpGoUioUhyHQcjkOIhCCIQkg1EYApIxw2dKsgSFBRY7KF9qKJlrzBofwHJWHEHg1GskL2IUxVHoaRPKh2w3AlLxBIIwjQThaxUZGCNA3myVKnEbD2UScIrTc0hRFSim+MkJEMh44vC5KlhkaDxdSdJrFSxxeE4XSqyy8Jw33Jf/6smxwIbyA+HBovGsrZIgAAA0gAAABFwmixmwxKYgAADSAAAAEk0Dbmma1Emo9lEQli6+eTKIhEQfOqTqKypYZOqL1dKlhkZKLwnSaxUZKI0E4WsVKnEbD3SvFUpueyiVUhvySEiKnDi/9pov9VVNvpoqVTEFNRTMuOTkuNVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVf/6smw7EwAP8AAAaQAAAAgAAA0gAAABAAABpAAAACAAADSAAAAETEFNRTMuOTkuNVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVTEFNRTMuOTkuNVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVQ==\"","\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 { 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 stopActiveAudioPlayback,\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 logoContent,\r\n} from \"../assets\";\r\nimport { StreamingJsonParser } from \"../utils/streamingJson\";\r\nimport { playCue, type SfxName } from \"../audio/sfxManager\";\r\nimport {\r\n ArrowPathIcon,\r\n CommandLineIcon,\r\n CursorArrowRaysIcon,\r\n FaceSmileIcon,\r\n HandRaisedIcon,\r\n MapIcon,\r\n MicrophoneIcon,\r\n QueueListIcon,\r\n StopIcon,\r\n XMarkIcon,\r\n} from \"@heroicons/react/24/outline\";\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 toolKind?: \"context\" | \"cursor\" | \"scroll\" | \"navigate\" | \"form\" | \"interact\" | \"unknown\";\r\n toolLabel?: string;\r\n toolCount?: number;\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\nconst ACCESSIBILITY_MIN_SPEECH_DURATION_MS = 1500;\r\nexport const HOLD_THRESHOLD_MS = 250;\r\n\r\nconst STATUS_LABELS = {\r\n ready: \"Hazır\",\r\n loading: \"Bir saniye\",\r\n micInitializing: \"Mikrofonu hazırlıyorum\",\r\n listening: \"Sizi dinliyorum\",\r\n accessibilityActive: \"Erişilebilirlik Aktif\",\r\n transcribing: \"Düşünüyorum\",\r\n thinking: \"Düşünüyorum\",\r\n playingAudio: \"\",\r\n runningTools: \"Siteyle ilgileniyorum\",\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 hasActiveStatus = (\r\n flags: StatusFlags,\r\n statusOverride: string | null,\r\n): boolean =>\r\n Boolean(\r\n statusOverride\r\n || flags.isBusy\r\n || flags.isRecording\r\n || flags.isTranscribing\r\n || flags.isThinking\r\n || flags.isRenderingAudio\r\n || flags.isPlayingAudio\r\n || flags.isRunningTools,\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 expectsReply: boolean,\r\n isRecording: boolean,\r\n isBusy: boolean,\r\n): boolean => (accessibilityMode || expectsReply) && !isRecording && !isBusy;\r\n\r\nexport const shouldAcceptVadSpeech = (\r\n speechDurationMs: number,\r\n enforceMinSpeechDuration: boolean,\r\n minSpeechDurationMs: number = ACCESSIBILITY_MIN_SPEECH_DURATION_MS,\r\n): boolean => !enforceMinSpeechDuration || speechDurationMs >= minSpeechDurationMs;\r\n\r\ninterface ToolIndicatorMessage {\r\n text: string;\r\n kind: \"context\" | \"cursor\" | \"scroll\" | \"navigate\" | \"form\" | \"interact\" | \"unknown\";\r\n}\r\n\r\nconst getToolIndicatorMessage = (\r\n call: AgentToolCallInfo,\r\n): ToolIndicatorMessage => {\r\n if (call.tool === \"getPageContext\") {\r\n return { text: \"Algılama\", kind: \"context\" };\r\n }\r\n if (call.tool === \"scroll\") {\r\n return { text: \"Kaydırma\", kind: \"scroll\" };\r\n }\r\n if (call.tool === \"navigate\") {\r\n const url = typeof call.args.url === \"string\" ? call.args.url.trim() : \"\";\r\n return {\r\n text: url ? `Sayfa Geçişi: ${url}` : \"Sayfa Geçişi\",\r\n kind: \"navigate\",\r\n };\r\n }\r\n if (call.tool === \"interact\" && call.args.action === \"move\") {\r\n return { text: \"Serbest İmleç\", kind: \"cursor\" };\r\n }\r\n if (call.tool === \"interact\" && call.args.action === \"type\") {\r\n return { text: \"Form Doldurma\", kind: \"form\" };\r\n }\r\n if (call.tool === \"interact\" && call.args.action === \"submit\") {\r\n return { text: \"Form Gönderme\", kind: \"form\" };\r\n }\r\n if (call.tool === \"interact\" && call.args.action === \"click\") {\r\n return { text: \"Tıklama\", kind: \"interact\" };\r\n }\r\n if (call.tool === \"interact\") {\r\n return { text: \"Etkileşim\", kind: \"interact\" };\r\n }\r\n return {\r\n text: call.tool || \"Araç\",\r\n kind: \"unknown\",\r\n };\r\n};\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 [isMicPending, setIsMicPending] = useState(false);\r\n const [recordingDurationMs, setRecordingDurationMs] = useState(0);\r\n const [statusOverride, setStatusOverride] = useState<string | null>(null);\r\n const statusFlags: StatusFlags = {\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 resolvedStatusText = resolveStatusText(statusFlags);\r\n const showStatus = hasActiveStatus(statusFlags, statusOverride);\r\n const statusText = showStatus ? (statusOverride ?? resolvedStatusText) : STATUS_LABELS.ready;\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 const expectsReplyRef = useRef(true);\r\n const requestEpochRef = useRef(0);\r\n const sttSendCuePlayedRef = 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(statusOverride ?? 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 (showStatus) {\r\n const st = statusOverride ?? 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 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 }, [\r\n isRecording,\r\n isBusy,\r\n isTranscribing,\r\n isThinking,\r\n isRunningTools,\r\n isPlayingAudio,\r\n isRenderingAudio,\r\n statusOverride,\r\n showStatus,\r\n messages,\r\n ]);\r\n\r\n const playSfx = (name: SfxName) => {\r\n playCue(name);\r\n };\r\n\r\n const beginRequestEpoch = () => {\r\n requestEpochRef.current += 1;\r\n return requestEpochRef.current;\r\n };\r\n\r\n const invalidateRequestEpoch = () => {\r\n requestEpochRef.current += 1;\r\n };\r\n\r\n const isCurrentRequestEpoch = (epoch: number): boolean =>\r\n requestEpochRef.current === epoch;\r\n\r\n const playSttSentCueOnce = () => {\r\n if (sttSendCuePlayedRef.current) {\r\n return;\r\n }\r\n sttSendCuePlayedRef.current = true;\r\n playSfx(\"sent\");\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 invalidateRequestEpoch();\r\n clearMicHoldTimeout();\r\n pendingStopAfterStartRef.current = false;\r\n\r\n stopActiveStream();\r\n stopActiveAudioPlayback();\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 const requestEpoch = beginRequestEpoch();\r\n setIsBusy(true);\r\n isBusyRef.current = 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 (!isCurrentRequestEpoch(requestEpoch)) return;\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 if (!isCurrentRequestEpoch(requestEpoch)) return;\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, expectsReply) => {\r\n if (!isCurrentRequestEpoch(requestEpoch)) return;\r\n playSfx(\"completed\");\r\n expectsReplyRef.current = expectsReply !== 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 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 if (!isCurrentRequestEpoch(requestEpoch)) return;\r\n void speakText(\r\n config.backendBaseUrl, text, config.voice,\r\n accessibilityMode, (state) => handleAudioStateChange(state, requestEpoch),\r\n ).catch((err) => console.warn(\"[Bulut] intermediate TTS failed\", err));\r\n },\r\n onToolCalls: (calls) => {\r\n if (!isCurrentRequestEpoch(requestEpoch)) return;\r\n if (calls.length > 0) {\r\n playSfx(\"toolCall\");\r\n }\r\n setIsRunningTools(true);\r\n setStatusOverride(STATUS_LABELS.runningTools);\r\n appendToolIndicatorMessages(calls);\r\n\r\n assistantMessageIdRef.current = null;\r\n pendingAssistantTextRef.current = \"\";\r\n },\r\n onToolResult: () => {},\r\n onIteration: () => {\r\n if (!isCurrentRequestEpoch(requestEpoch)) return;\r\n playSfx(\"thinking\");\r\n setIsThinking(true);\r\n setStatusOverride(STATUS_LABELS.thinking);\r\n },\r\n onAudioStateChange: (state) => {\r\n handleAudioStateChange(state, requestEpoch);\r\n },\r\n onError: (err) => {\r\n if (!isCurrentRequestEpoch(requestEpoch)) return;\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 if (!isCurrentRequestEpoch(requestEpoch)) return;\r\n setIsBusy(false);\r\n isBusyRef.current = 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 expectsReplyRef.current,\r\n isRecordingRef.current,\r\n false,\r\n )\r\n ) {\r\n void startRecording(\"vad\");\r\n }\r\n // Reset for next turn\r\n expectsReplyRef.current = true;\r\n });\r\n }, []); // eslint-disable-line react-hooks/exhaustive-deps\r\n\r\n const appendMessage = (\r\n text: string,\r\n isUser: boolean,\r\n options?: {\r\n type?: \"message\" | \"tool\";\r\n toolKind?: Message[\"toolKind\"];\r\n toolLabel?: string;\r\n toolCount?: number;\r\n },\r\n ): 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 type: options?.type,\r\n toolKind: options?.toolKind,\r\n toolLabel: options?.toolLabel,\r\n toolCount: options?.toolCount,\r\n },\r\n ]);\r\n return id;\r\n };\r\n\r\n const appendToolIndicatorMessages = (calls: AgentToolCallInfo[]) => {\r\n setMessages((previous) => {\r\n const next = [...previous];\r\n\r\n for (const call of calls) {\r\n const indicator = getToolIndicatorMessage(call);\r\n const last = next[next.length - 1];\r\n const previousToolText = typeof last?.text === \"string\"\r\n ? last.text.replace(/\\s+\\(\\d+\\)$/, \"\")\r\n : \"\";\r\n\r\n if (\r\n last\r\n && !last.isUser\r\n && last.type === \"tool\"\r\n && previousToolText === indicator.text\r\n ) {\r\n const extractedCount = Number.parseInt(\r\n (last.text.match(/\\((\\d+)\\)\\s*$/)?.[1] ?? \"1\"),\r\n 10,\r\n );\r\n const safeCurrentCount = Number.isFinite(extractedCount) ? extractedCount : 1;\r\n const nextCount = safeCurrentCount + 1;\r\n const baseLabel = previousToolText || indicator.text;\r\n next[next.length - 1] = {\r\n ...last,\r\n toolLabel: baseLabel,\r\n toolCount: nextCount,\r\n text: `${baseLabel} (${nextCount})`,\r\n };\r\n continue;\r\n }\r\n\r\n const id = nextMessageIdRef.current++;\r\n next.push({\r\n id,\r\n text: indicator.text,\r\n isUser: false,\r\n type: \"tool\",\r\n toolKind: indicator.kind,\r\n toolLabel: indicator.text,\r\n toolCount: 1,\r\n });\r\n }\r\n\r\n return next;\r\n });\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, requestEpoch?: number) => {\r\n if (typeof requestEpoch === \"number\" && !isCurrentRequestEpoch(requestEpoch)) {\r\n return;\r\n }\r\n\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 = (requestEpoch?: number) => {\r\n if (typeof requestEpoch === \"number\" && !isCurrentRequestEpoch(requestEpoch)) {\r\n return;\r\n }\r\n\r\n awaitingAssistantResponseRef.current = false;\r\n setStatusOverride(null);\r\n setIsBusy(false);\r\n isBusyRef.current = 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 expectsReplyRef.current,\r\n isRecordingRef.current,\r\n false,\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 // Reset for next turn\r\n expectsReplyRef.current = true;\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 const requestEpoch = beginRequestEpoch();\r\n setIsBusy(true);\r\n isBusyRef.current = 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 (!isCurrentRequestEpoch(requestEpoch)) return;\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 if (!isCurrentRequestEpoch(requestEpoch)) return;\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, expectsReply) => {\r\n if (!isCurrentRequestEpoch(requestEpoch)) return;\r\n playSfx(\"completed\");\r\n expectsReplyRef.current = expectsReply !== false;\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 if (!isCurrentRequestEpoch(requestEpoch)) return;\r\n void speakText(\r\n config.backendBaseUrl, text, config.voice,\r\n accessibilityMode, (state) => handleAudioStateChange(state, requestEpoch),\r\n ).catch((err) => console.warn(\"[Bulut] intermediate TTS failed\", err));\r\n },\r\n onToolCalls: (calls) => {\r\n if (!isCurrentRequestEpoch(requestEpoch)) return;\r\n if (calls.length > 0) {\r\n playSfx(\"toolCall\");\r\n }\r\n setIsRunningTools(true);\r\n setStatusOverride(STATUS_LABELS.runningTools);\r\n appendToolIndicatorMessages(calls);\r\n\r\n assistantMessageIdRef.current = null;\r\n pendingAssistantTextRef.current = \"\";\r\n },\r\n onToolResult: () => {},\r\n onIteration: () => {\r\n if (!isCurrentRequestEpoch(requestEpoch)) return;\r\n playSfx(\"thinking\");\r\n setIsThinking(true);\r\n setStatusOverride(STATUS_LABELS.thinking);\r\n },\r\n onAudioStateChange: (state) => {\r\n handleAudioStateChange(state, requestEpoch);\r\n },\r\n onError: (err) => {\r\n if (!isCurrentRequestEpoch(requestEpoch)) return;\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 if (!isCurrentRequestEpoch(requestEpoch)) return;\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(requestEpoch);\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 const requestEpoch = beginRequestEpoch();\r\n setIsBusy(true);\r\n isBusyRef.current = 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 if (!isCurrentRequestEpoch(requestEpoch)) return;\r\n playSttSentCueOnce();\r\n },\r\n onTranscription: (data) => {\r\n if (!isCurrentRequestEpoch(requestEpoch)) return;\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 (!isCurrentRequestEpoch(requestEpoch)) return;\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 if (!isCurrentRequestEpoch(requestEpoch)) return;\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, expectsReply) => {\r\n if (!isCurrentRequestEpoch(requestEpoch)) return;\r\n playSfx(\"completed\");\r\n expectsReplyRef.current = expectsReply !== false;\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 if (!isCurrentRequestEpoch(requestEpoch)) return;\r\n void speakText(\r\n config.backendBaseUrl, text, config.voice,\r\n accessibilityMode, (state) => handleAudioStateChange(state, requestEpoch),\r\n ).catch((err) => console.warn(\"[Bulut] intermediate TTS failed\", err));\r\n },\r\n onToolCalls: (calls) => {\r\n if (!isCurrentRequestEpoch(requestEpoch)) return;\r\n if (calls.length > 0) {\r\n playSfx(\"toolCall\");\r\n }\r\n setIsRunningTools(true);\r\n setStatusOverride(STATUS_LABELS.runningTools);\r\n appendToolIndicatorMessages(calls);\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 if (!isCurrentRequestEpoch(requestEpoch)) return;\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: (state) => {\r\n handleAudioStateChange(state, requestEpoch);\r\n },\r\n onError: (err) => {\r\n if (!isCurrentRequestEpoch(requestEpoch)) return;\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 if (!isCurrentRequestEpoch(requestEpoch)) return;\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(requestEpoch);\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 let speechStartedAt: number | null = null;\r\n const enforceMinSpeechDuration = accessibilityMode;\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 (!speechDetected) {\r\n speechStartedAt = null;\r\n silenceStartRef.current = null;\r\n return;\r\n }\r\n\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 silenceStartRef.current = null;\r\n if (speechStartedAt === null) {\r\n speechStartedAt = Date.now();\r\n }\r\n\r\n if (!speechDetected) {\r\n const speechDuration = Date.now() - speechStartedAt;\r\n if (shouldAcceptVadSpeech(speechDuration, enforceMinSpeechDuration)) {\r\n speechDetected = true;\r\n if (enforceMinSpeechDuration) {\r\n setStatusOverride(STATUS_LABELS.listening);\r\n }\r\n }\r\n }\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.micInitializing);\r\n setIsMicPending(true);\r\n\r\n if (!navigator.mediaDevices?.getUserMedia) {\r\n setStatusOverride(null);\r\n setIsMicPending(false);\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 setIsMicPending(false);\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 sttSendCuePlayedRef.current = false;\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 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 playSttSentCueOnce();\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 setStatusOverride(\r\n accessibilityMode && mode === \"vad\"\r\n ? STATUS_LABELS.accessibilityActive\r\n : STATUS_LABELS.listening,\r\n );\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 setIsMicPending(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 invalidateRequestEpoch();\r\n sttSendCuePlayedRef.current = false;\r\n resetMicGesture();\r\n pendingStopAfterStartRef.current = false;\r\n\r\n stopActiveStream();\r\n stopActiveAudioPlayback();\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 invalidateRequestEpoch();\r\n sttSendCuePlayedRef.current = false;\r\n stopActiveStream();\r\n stopActiveAudioPlayback();\r\n cancelActiveSttWs();\r\n stopRecording({ discard: true });\r\n cleanupVAD();\r\n stopStreamTracks();\r\n resetProcessingFlags();\r\n setIsBusy(false);\r\n isBusyRef.current = 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 stopActiveAudioPlayback();\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: accessibilityMode\r\n ? `inset 0 0 0 2px ${COLORS.primary}, ${SHADOW}`\r\n : 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 resolveToolIcon = (kind: Message[\"toolKind\"]) => {\r\n if (kind === \"cursor\") {\r\n return CursorArrowRaysIcon;\r\n }\r\n if (kind === \"scroll\") {\r\n return HandRaisedIcon;\r\n }\r\n if (kind === \"navigate\") {\r\n return MapIcon;\r\n }\r\n if (kind === \"form\") {\r\n return QueueListIcon;\r\n }\r\n if (kind === \"interact\") {\r\n return HandRaisedIcon;\r\n }\r\n if (kind === \"unknown\") {\r\n return CommandLineIcon;\r\n }\r\n return FaceSmileIcon;\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 hideMicButton = isMicPending && !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 <ArrowPathIcon aria-hidden=\"true\" width={22} height={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 <XMarkIcon aria-hidden=\"true\" width={22} height={22} />\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 if (message.type === \"tool\") {\r\n const ToolIcon = resolveToolIcon(message.toolKind);\r\n return (\r\n <div\r\n key={message.id}\r\n style={{\r\n ...messageStyle(false),\r\n opacity: \"0.7\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n gap: \"8px\",\r\n }}\r\n >\r\n <ToolIcon\r\n aria-hidden=\"true\"\r\n width={20}\r\n height={20}\r\n style={{ flexShrink: \"0\" }}\r\n />\r\n <span>{message.text}</span>\r\n </div>\r\n );\r\n }\r\n\r\n return (\r\n <div key={message.id} style={messageStyle(message.isUser)}>\r\n {message.text}\r\n </div>\r\n );\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 {showStatus ? (\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 <StopIcon\r\n aria-hidden=\"true\"\r\n width={22}\r\n height={22}\r\n style={{ color: \"hsla(215, 100%, 5%, 1)\" }}\r\n />\r\n </button>\r\n ) : hideMicButton ? null : (\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 {isVadRecording ? (\r\n <XMarkIcon\r\n aria-hidden=\"true\"\r\n width={22}\r\n height={22}\r\n style={{ color: \"hsla(215, 100%, 5%, 1)\" }}\r\n />\r\n ) : (\r\n <MicrophoneIcon\r\n aria-hidden=\"true\"\r\n width={22}\r\n height={22}\r\n style={{ color: \"hsla(215, 100%, 5%, 1)\" }}\r\n />\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\"","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: \"http://localhost:8000\",\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 accessibilityMode={isAccessibilityEnabled}\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","BORDER_RADIUS","SHADOW","TRANSITIONS","ArrowPathIcon","title","titleId","svgRef","React","createElement","Object","assign","xmlns","fill","viewBox","strokeWidth","stroke","id","strokeLinecap","strokeLinejoin","ForwardRef","forwardRef","CommandLineIcon","CursorArrowRaysIcon","FaceSmileIcon","HandRaisedIcon","MapIcon","MicrophoneIcon","QueueListIcon","StopIcon","XMarkIcon","ChatButton","onMicClick","onCancelRecording","onStopTask","isRecording","isBusy","accessibilityMode","showBubble","onBubbleClick","previewMessage","onPreviewClick","onPreviewClose","bgColor","popupBoxShadow","containerStyle","position","right","bottom","display","flexDirection","alignItems","gap","zIndex","fontFamily","buttonStyle","width","height","minWidth","minHeight","borderRadius","backgroundColor","color","border","cursor","justifyContent","transition","flexShrink","showStopButton","MainIcon","closeBtnStyle","top","background","fontSize","lineHeight","padding","renderPopup","onClick","onClose","extraClass","scrollable","jsxs","className","jsx","stopPropagation","paddingRight","wordBreak","maxHeight","overflowY","Fragment","onMouseEnter","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","trim","isCacheEntry","obj","url","summary","links","interactables","capturedAt","version","bumpCount","set","get","formatTopCounts","maxItems","size","from","entries","localeCompare","count","join","parseTabIndex","parsed","Number","parseInt","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","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","outerHTML","Date","now","sorted","delete","pruneOldestCacheEntries","serialized","stringify","setItem","persistCacheToStorage","AGENT_CURSOR_ID","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","setCursorPosition","left","setCursorVisibility","visible","isVisibleElement","findAgentUiAnchorElement","roots","defaultHost","getElementById","shadowRoot","el","includes","getBulutShadowRoots","panel","button","getAgentWindowTopLeft","anchor","CURSOR_DIAMETER_PX","scrollX","hideAgentCursor","cursorHoverTrackingInitialized","initializeCursorHoverTracking","parseFloat","getCursorPosition","pointerX","pageX","pointerY","pageY","hypot","moveCursor","startPosition","baseColor","boxShadow","boxSizing","appendChild","ensureCursor","dataset","transitionReady","waitForNextAnimationFrame","getElementCenter","CONTAINS_SELECTOR_PATTERN","findElementBySelector","containsMatch","match","baseSelector","expectedText","fallbackError","dispatchMouseEvent","dispatchEvent","MouseEvent","bubbles","cancelable","view","clientX","clientY","typeIntoElement","focus","descriptor","getOwnPropertyDescriptor","defaultValue","setNativeInputLikeValue","Event","slowScrollElementIntoView","slowScrollElementIntoViewWithMode","forceCenter","viewportHeight","innerHeight","isRectOutsideViewport","maxScrollTop","scrollHeight","currentScrollY","rectTop","rectHeight","computeCenteredScrollTop","executeInteract","target","selected","center","resolveTarget","action","click","requestSubmit","form","parentForm","closest","submitElement","executeNavigate","targetUrl","resolvedUrl","matchingElement","parsedTarget","allLinks","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","TTS_WS_RETRY_DELAYS_MS","BULUT_AUDIO_STOP_EVENT","activeAudioElements","audioPlaybackGeneration","normalizeBaseUrl","baseUrl","trimmed","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","toUpperCase","safeMimeType","finalBlobParts","ArrayBuffer","DataView","setUint32","setUint16","channels","createWavHeader","blob","Blob","Audio","objectUrl","createObjectURL","registerActiveAudioElement","preload","autoplay","src","play","ended","reject","watchdog","setInterval","onEnded","cleanup","onError","onForcedStop","clearInterval","waitForPlaybackEnd","err","unregisterActiveAudioElement","revokeObjectURL","parseSseEventPayload","eventBlock","dataLines","trimStart","dataStr","isAudioSsePayload","payload","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","readyState","OPEN","debug","stop","cancel","collectTtsViaSse","assistantText","voice","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","onIntermediateReply","onToolCalls","results","isNavigate","pendingToolCalls","args","completedResults","onToolResult","final_reply","replyExpectsReply","expects_reply","onAssistantDone","errMsg","onIteration","iteration","max_iterations","wsError","catch","SFX_SOURCES","sent","thinking","toolCall","completed","sfxManager","queue","playNow","onended","drain","next","playCue","SvgIcon","stripColors","useMemo","trimmedSrc","viewBoxMatch","verticalAlign","dangerouslySetInnerHTML","nextContent","strokeWidthValue","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","expectsReply","getToolIndicatorMessage","kind","ChatWindow","onAccessibilityToggle","actionsRef","onRecordingChange","onBusyChange","onPreviewChange","setMessages","useState","saved","timestamp","setIsBusy","setIsRecording","setIsTranscribing","setIsThinking","isRenderingAudio","setIsRenderingAudio","setIsPlayingAudio","setIsRunningTools","isMicPending","setIsMicPending","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","expectsReplyRef","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","appendToolIndicatorMessages","finally","startRecording","options","previous","toolKind","toolLabel","toolCount","indicator","last","previousToolText","extractedCount","nextCount","isFinite","baseLabel","upsertLiveUserTranscription","clearLiveUserTranscriptionState","finalizeStreamCycle","runAgentForUserText","normalizedUserText","handleToolExecution","agentTextChatStream","stopRecording","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","speechStartedAt","enforceMinSpeechDuration","getByteFrequencyData","sum","silenceDuration","speechDurationMs","minSpeechDurationMs","shouldAcceptVadSpeech","setupVAD","start","startedAt","normalizeError","resetMicGesture","handleMicPointerUp","preventDefault","releasePointerCapture","pointerId","wasHold","thresholdMs","classifyMicGesture","timer","stopTask","cancelRecording","windowStyle","animation","headerButtonStyle","messageStyle","maxWidth","wordWrap","whiteSpace","alignSelf","statusPanelStyle","flex","textOverflow","recordingTimerStyle","fontWeight","textAlign","micFooterButtonStyle","isVadRecording","hideMicButton","disableMicControl","initialMessages","ToolIcon","onPointerDown","setPointerCapture","onPointerUp","onPointerCancel","disabled","DEFAULT_CONFIG","normalizeHexColor","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","attachShadow","replaceChildren","mountNode","destroy","isReady","Bulut"],"mappings":"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","x_google_ignoreList":[0,1,2,4,5,6,7,8,9,10,11,12,13]}