@centive/aria-sdk 0.8.7 → 0.8.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,6 +1,6 @@
1
- import { jsx as n, jsxs as E, Fragment as Ve } from "react/jsx-runtime";
2
- import { useRef as me, useState as I, useEffect as ee, useCallback as j } from "react";
3
- import { Sparkles as Ne, Wrench as je, MicOff as De, Mic as He, Maximize2 as dr, Phone as We, X as Oe, RefreshCw as Be, MessageCircle as Fe, Minimize2 as gr, User as hr, Bot as ur, Send as pr } from "lucide-react";
1
+ import { jsx as n, jsxs as E, Fragment as He } from "react/jsx-runtime";
2
+ import { useRef as me, useState as I, useEffect as ee, useCallback as V } from "react";
3
+ import { Sparkles as Re, Wrench as Ve, MicOff as je, Mic as Be, Maximize2 as dr, Phone as De, X as Oe, RefreshCw as We, MessageCircle as Fe, Minimize2 as gr, User as hr, Bot as ur, Send as pr } from "lucide-react";
4
4
  import { createPortal as mr } from "react-dom";
5
5
  function fr(r) {
6
6
  return typeof r == "object" && r !== null && "status" in r && (r.status === "success" || r.status === "error") && !("type" in r);
@@ -90,6 +90,9 @@ class U {
90
90
  // Auto-reconnect on Anam disconnect (for inactivity timeout)
91
91
  isReconnecting = !1;
92
92
  autoReconnectOnAnamDisconnect = !0;
93
+ // Track if user has had a session before (to skip greeting on subsequent sessions)
94
+ // This persists across session restarts within the same app lifecycle
95
+ hasHadSessionBefore = !1;
93
96
  // ============================================================================
94
97
  // Singleton Pattern
95
98
  // ============================================================================
@@ -143,8 +146,8 @@ class U {
143
146
  t && t.forEach((o) => {
144
147
  try {
145
148
  o(e);
146
- } catch (i) {
147
- console.error("[AriaSessionManager] Error in event listener:", i);
149
+ } catch (a) {
150
+ console.error("[AriaSessionManager] Error in event listener:", a);
148
151
  }
149
152
  });
150
153
  }
@@ -369,8 +372,8 @@ class U {
369
372
  // Token is ready for use
370
373
  }), this.scheduleRefresh(), this.deferAnamInit ? t ? (console.log("[AriaSessionManager] Session token refreshed proactively"), this.config.onSessionRefresh?.(), this.emit({ type: "session_refresh", data: { token: o } }), this.anamClient ? this.setStatus("ready") : this.setStatus("connected")) : this.isReconnecting ? (console.log("[AriaSessionManager] Token received during reconnect, initializing Anam client"), this.initializeAnamClient(o).then(() => {
371
374
  console.log("[AriaSessionManager] Anam client initialized after reconnect"), this.isReconnecting = !1, this.emit({ type: "reconnecting", data: { isReconnecting: !1 } });
372
- }).catch((i) => {
373
- console.error("[AriaSessionManager] Failed to initialize Anam client during reconnect:", i), this.isReconnecting = !1, this.emit({ type: "reconnecting", data: { isReconnecting: !1 } }), this.setStatus("error"), this.updateSessionState({ lastError: "Failed to reconnect session" });
375
+ }).catch((a) => {
376
+ console.error("[AriaSessionManager] Failed to initialize Anam client during reconnect:", a), this.isReconnecting = !1, this.emit({ type: "reconnecting", data: { isReconnecting: !1 } }), this.setStatus("error"), this.updateSessionState({ lastError: "Failed to reconnect session" });
374
377
  })) : (console.log("[AriaSessionManager] Session token ready, waiting for user to open widget"), this.setStatus("connected"), this.emit({ type: "session_ready", data: { sessionId: null, tokenReady: !0, lazyInit: !0 } }), this.config.onSessionPreloaded?.()) : this.anamClient ? t && (console.log("[AriaSessionManager] Session refreshed, token updated"), this.config.onSessionRefresh?.(), this.emit({ type: "session_refresh", data: { token: o } })) : this.initializeAnamClient(o);
375
378
  } else
376
379
  console.log("[AriaSessionManager] Session response without data:", e.message), this.updateSessionState({
@@ -393,6 +396,9 @@ class U {
393
396
  * Request a session token from the backend with user_trigger=true
394
397
  * This is called automatically when WebSocket connects
395
398
  * The token is stored and used when user opens the widget for the first time
399
+ *
400
+ * If user has had a session before (in this app lifecycle), skip_greeting is sent
401
+ * to prevent the greeting from playing again on subsequent sessions.
396
402
  */
397
403
  requestSessionToken() {
398
404
  if (this.sessionState.token && !this.isTokenExpired()) {
@@ -407,16 +413,22 @@ class U {
407
413
  console.warn("[AriaSessionManager] Cannot request session token: WebSocket not connected");
408
414
  return;
409
415
  }
410
- console.log("[AriaSessionManager] Requesting session token with user_trigger=true for user:", this.config.userId), this.setStatus("preloading");
416
+ const e = this.hasHadSessionBefore;
417
+ console.log(
418
+ "[AriaSessionManager] Requesting session token with user_trigger=true for user:",
419
+ this.config.userId,
420
+ e ? "(skip_greeting: true)" : "(with greeting)"
421
+ ), this.setStatus("preloading");
411
422
  try {
412
- const e = JSON.stringify({
423
+ const t = JSON.stringify({
413
424
  user_trigger: !0,
414
- ...this.config.userId && { userId: this.config.userId }
425
+ ...this.config.userId && { userId: this.config.userId },
426
+ ...e && { skip_greeting: !0 }
415
427
  });
416
- console.log("[AriaSessionManager] Sending message:", e), this.ws.send(e);
417
- } catch (e) {
418
- const t = e instanceof Error ? e.message : "Failed to request session token";
419
- console.error("[AriaSessionManager] Session token request error:", t), this.handleSessionError(t);
428
+ console.log("[AriaSessionManager] Sending message:", t), this.ws.send(t);
429
+ } catch (t) {
430
+ const o = t instanceof Error ? t.message : "Failed to request session token";
431
+ console.error("[AriaSessionManager] Session token request error:", o), this.handleSessionError(o);
420
432
  }
421
433
  }
422
434
  /**
@@ -439,15 +451,21 @@ class U {
439
451
  console.error("[AriaSessionManager] Cannot trigger session: WebSocket not connected");
440
452
  return;
441
453
  }
454
+ const t = this.hasHadSessionBefore;
442
455
  try {
443
- const t = JSON.stringify({
456
+ const o = JSON.stringify({
444
457
  user_trigger: !0,
445
- userId: this.config.userId
458
+ userId: this.config.userId,
459
+ ...t && { skip_greeting: !0 }
446
460
  });
447
- this.ws.send(t), console.log("[AriaSessionManager] Sent session request with user_trigger: true, userId:", this.config.userId), e && this.config.userId && this.config.onManualTrigger?.(this.config.userId);
448
- } catch (t) {
449
- const o = t instanceof Error ? t.message : "Failed to trigger session";
450
- console.error("[AriaSessionManager] Trigger error:", o), this.config.onError?.(t instanceof Error ? t : new Error(o));
461
+ this.ws.send(o), console.log(
462
+ "[AriaSessionManager] Sent session request with user_trigger: true, userId:",
463
+ this.config.userId,
464
+ t ? "(skip_greeting: true)" : "(with greeting)"
465
+ ), e && this.config.userId && this.config.onManualTrigger?.(this.config.userId);
466
+ } catch (o) {
467
+ const a = o instanceof Error ? o.message : "Failed to trigger session";
468
+ console.error("[AriaSessionManager] Trigger error:", a), this.config.onError?.(o instanceof Error ? o : new Error(a));
451
469
  }
452
470
  }
453
471
  // ============================================================================
@@ -496,13 +514,17 @@ class U {
496
514
  this.isAnamInitializing = !0, console.log("[AriaSessionManager] Initializing Anam client"), this.setStatus("preloading");
497
515
  try {
498
516
  this.createHiddenVideoElement();
499
- const { createClient: t, AnamEvent: o } = await import("@anam-ai/js-sdk"), i = t(e);
500
- i.addListener(o.SESSION_READY, () => {
501
- const m = i.getActiveSessionId();
517
+ const { createClient: t, AnamEvent: o } = await import("@anam-ai/js-sdk"), a = t(e);
518
+ a.addListener(o.SESSION_READY, () => {
519
+ const m = a.getActiveSessionId();
502
520
  m && (this.updateSessionState({ session_id: m }), console.log("[AriaSessionManager] Anam session ready with ID:", m));
503
- }), i.addListener(o.CONNECTION_CLOSED, () => {
504
- console.log("[AriaSessionManager] Anam connection closed"), this.emit({ type: "connection_change", data: { connected: !1 } }), this.autoReconnectOnAnamDisconnect && !this.isIntentionalDisconnect && !this.isPaused && !this.isReconnecting && (console.log("[AriaSessionManager] Anam disconnected unexpectedly, auto-reconnecting..."), this.autoReconnectSession());
505
- }), i.addListener(o.MESSAGE_HISTORY_UPDATED, (m) => {
521
+ }), a.addListener(o.CONNECTION_CLOSED, () => {
522
+ if (console.log("[AriaSessionManager] Anam connection closed"), this.emit({ type: "connection_change", data: { connected: !1 } }), this.isPaused) {
523
+ console.log("[AriaSessionManager] Anam disconnected while paused, clearing stale session"), this.clearStaleSessionForResume();
524
+ return;
525
+ }
526
+ this.autoReconnectOnAnamDisconnect && !this.isIntentionalDisconnect && !this.isReconnecting && (console.log("[AriaSessionManager] Anam disconnected unexpectedly, auto-reconnecting..."), this.autoReconnectSession());
527
+ }), a.addListener(o.MESSAGE_HISTORY_UPDATED, (m) => {
506
528
  this.chatMessages = m.map((A) => ({
507
529
  role: A.role,
508
530
  content: A.content,
@@ -514,7 +536,7 @@ class U {
514
536
  timestamp: (/* @__PURE__ */ new Date()).toISOString()
515
537
  }));
516
538
  this.sendMessageHistory(f), this.emit({ type: "message_history", data: { messages: this.chatMessages } });
517
- }), i.addListener(o.MESSAGE_STREAM_EVENT_RECEIVED, (m) => {
539
+ }), a.addListener(o.MESSAGE_STREAM_EVENT_RECEIVED, (m) => {
518
540
  m.role === "persona" ? this.liveTranscript += m.content : m.role === "user" && (this.liveTranscript = "");
519
541
  const f = {
520
542
  role: m.role,
@@ -522,7 +544,7 @@ class U {
522
544
  timestamp: (/* @__PURE__ */ new Date()).toISOString()
523
545
  };
524
546
  this.sendMessageStream(f, m.is_final ?? !1), this.emit({ type: "message_stream", data: { event: m, liveTranscript: this.liveTranscript } });
525
- }), i.addListener(o.CLIENT_TOOL_EVENT_RECEIVED, (m) => {
547
+ }), a.addListener(o.CLIENT_TOOL_EVENT_RECEIVED, (m) => {
526
548
  console.log("[AriaSessionManager] Tool call event received:", m.eventName), this.isToolCallActive = !0, this.activeToolCall = m, this.emit({
527
549
  type: "tool_call",
528
550
  data: {
@@ -534,13 +556,13 @@ class U {
534
556
  }), setTimeout(() => {
535
557
  this.activeToolCall?.eventUid === m.eventUid && this.clearToolCallState();
536
558
  }, 3e4);
537
- }), this.anamClient = i, this.audioInputStream = await navigator.mediaDevices.getUserMedia({ audio: !0 }), this.createHiddenAudioElement();
538
- const l = await i.stream(this.audioInputStream), a = l[0], b = l[1];
539
- this.videoStream = a, this.hiddenVideoElement && (this.hiddenVideoElement.srcObject = a, this.hiddenVideoElement.muted = !0), this.hiddenAudioElement && b ? (this.hiddenAudioElement.srcObject = b, this.hiddenAudioElement.muted = !1, this.hiddenAudioElement.play().catch((m) => {
559
+ }), this.anamClient = a, this.audioInputStream = await navigator.mediaDevices.getUserMedia({ audio: !0 }), this.createHiddenAudioElement();
560
+ const l = await a.stream(this.audioInputStream), i = l[0], b = l[1];
561
+ this.videoStream = i, this.hiddenVideoElement && (this.hiddenVideoElement.srcObject = i, this.hiddenVideoElement.muted = !0), this.hiddenAudioElement && b ? (this.hiddenAudioElement.srcObject = b, this.hiddenAudioElement.muted = !1, this.hiddenAudioElement.play().catch((m) => {
540
562
  console.warn("[AriaSessionManager] Initial audio play failed (may need user interaction):", m);
541
563
  }), console.log("[AriaSessionManager] Audio stream attached to audio element")) : console.log("[AriaSessionManager] No separate audio stream available, audio may come through video"), this.isAnamInitializing = !1, this.setStatus("ready");
542
- const d = i.getActiveSessionId();
543
- console.log("[AriaSessionManager] Session fully ready with video stream, ID:", d), this.emit({ type: "session_ready", data: { sessionId: d, streamReady: !0 } }), this.config.onSessionReady?.(), console.log("[AriaSessionManager] Anam client initialized and streaming");
564
+ const d = a.getActiveSessionId();
565
+ console.log("[AriaSessionManager] Session fully ready with video stream, ID:", d), this.emit({ type: "session_ready", data: { sessionId: d, streamReady: !0 } }), this.config.onSessionReady?.(), this.hasHadSessionBefore || (this.hasHadSessionBefore = !0, console.log("[AriaSessionManager] First session started - subsequent sessions will skip greeting")), console.log("[AriaSessionManager] Anam client initialized and streaming");
544
566
  } catch (t) {
545
567
  this.isAnamInitializing = !1;
546
568
  const o = t instanceof Error ? t.message : "Failed to initialize Anam client";
@@ -590,11 +612,11 @@ class U {
590
612
  */
591
613
  attachToVideoElement(e) {
592
614
  if (this.videoStream) {
593
- const t = this.videoStream.getTracks(), o = t.filter((a) => a.readyState === "live"), i = t.filter((a) => a.kind === "audio");
594
- console.log("[AriaSessionManager] Attaching video stream, tracks:", t.length, "active:", o.length, "audio:", i.length), e.srcObject = this.videoStream, this.hiddenAudioElement && this.hiddenAudioElement.srcObject ? (e.muted = !0, this.hiddenAudioElement.muted = !1, this.hiddenAudioElement.play().catch((a) => {
595
- console.warn("[AriaSessionManager] Audio play failed:", a);
596
- }), console.log("[AriaSessionManager] Audio playing through separate audio element")) : (e.muted = !1, console.log("[AriaSessionManager] Audio playing through video element")), e.play().catch((a) => {
597
- console.warn("[AriaSessionManager] Video play failed:", a);
615
+ const t = this.videoStream.getTracks(), o = t.filter((i) => i.readyState === "live"), a = t.filter((i) => i.kind === "audio");
616
+ console.log("[AriaSessionManager] Attaching video stream, tracks:", t.length, "active:", o.length, "audio:", a.length), e.srcObject = this.videoStream, this.hiddenAudioElement && this.hiddenAudioElement.srcObject ? (e.muted = !0, this.hiddenAudioElement.muted = !1, this.hiddenAudioElement.play().catch((i) => {
617
+ console.warn("[AriaSessionManager] Audio play failed:", i);
618
+ }), console.log("[AriaSessionManager] Audio playing through separate audio element")) : (e.muted = !1, console.log("[AriaSessionManager] Audio playing through video element")), e.play().catch((i) => {
619
+ console.warn("[AriaSessionManager] Video play failed:", i);
598
620
  });
599
621
  } else
600
622
  console.log("[AriaSessionManager] No video stream available to attach (session may be initializing)");
@@ -632,8 +654,8 @@ class U {
632
654
  };
633
655
  try {
634
656
  this.ws.send(JSON.stringify(o)), console.log("[AriaSessionManager] Sent message history:", e.length, "messages");
635
- } catch (i) {
636
- console.error("[AriaSessionManager] Failed to send message history:", i);
657
+ } catch (a) {
658
+ console.error("[AriaSessionManager] Failed to send message history:", a);
637
659
  }
638
660
  }
639
661
  sendMessageStream(e, t) {
@@ -646,8 +668,8 @@ class U {
646
668
  };
647
669
  try {
648
670
  this.ws.send(JSON.stringify(o));
649
- } catch (i) {
650
- console.error("[AriaSessionManager] Failed to send message stream:", i);
671
+ } catch (a) {
672
+ console.error("[AriaSessionManager] Failed to send message stream:", a);
651
673
  }
652
674
  }
653
675
  sendSessionEnd() {
@@ -702,8 +724,8 @@ class U {
702
724
  console.log("[AriaSessionManager] No expiration time, skipping refresh scheduling");
703
725
  return;
704
726
  }
705
- const e = new Date(this.sessionState.expires_at).getTime(), t = Date.now(), o = this.refreshConfig.bufferMinutes * 60 * 1e3, i = e - o, l = Math.max(0, i - t), a = e - t;
706
- console.log(`[AriaSessionManager] Token expires at: ${new Date(e).toISOString()}`), console.log(`[AriaSessionManager] Time until expiry: ${Math.round(a / 1e3 / 60)} minutes`), console.log(`[AriaSessionManager] Refresh buffer: ${this.refreshConfig.bufferMinutes} minutes`), l <= 0 ? (console.log("[AriaSessionManager] Session expiring soon, refreshing immediately"), this.refreshSession()) : (console.log(`[AriaSessionManager] Scheduling proactive refresh in ${Math.round(l / 1e3 / 60)} minutes`), this.refreshTimer = setTimeout(() => {
727
+ const e = new Date(this.sessionState.expires_at).getTime(), t = Date.now(), o = this.refreshConfig.bufferMinutes * 60 * 1e3, a = e - o, l = Math.max(0, a - t), i = e - t;
728
+ console.log(`[AriaSessionManager] Token expires at: ${new Date(e).toISOString()}`), console.log(`[AriaSessionManager] Time until expiry: ${Math.round(i / 1e3 / 60)} minutes`), console.log(`[AriaSessionManager] Refresh buffer: ${this.refreshConfig.bufferMinutes} minutes`), l <= 0 ? (console.log("[AriaSessionManager] Session expiring soon, refreshing immediately"), this.refreshSession()) : (console.log(`[AriaSessionManager] Scheduling proactive refresh in ${Math.round(l / 1e3 / 60)} minutes`), this.refreshTimer = setTimeout(() => {
707
729
  console.log("[AriaSessionManager] Proactive refresh timer fired"), this.refreshSession();
708
730
  }, l));
709
731
  }
@@ -721,15 +743,17 @@ class U {
721
743
  return;
722
744
  }
723
745
  console.log("[AriaSessionManager] Refreshing session token (proactive refresh)"), this.updateSessionState({ isRefreshing: !0 }), this.setStatus("refreshing");
746
+ const e = this.hasHadSessionBefore;
724
747
  try {
725
- const e = JSON.stringify({
748
+ const t = JSON.stringify({
726
749
  user_trigger: !0,
727
- userId: this.config.userId
750
+ userId: this.config.userId,
751
+ ...e && { skip_greeting: !0 }
728
752
  });
729
- this.ws.send(e);
730
- } catch (e) {
731
- const t = e instanceof Error ? e.message : "Failed to refresh session";
732
- console.error("[AriaSessionManager] Refresh error:", t), this.updateSessionState({ isRefreshing: !1 }), this.config.onSessionRefreshError?.(e instanceof Error ? e : new Error(t)), this.scheduleRetry();
753
+ this.ws.send(t);
754
+ } catch (t) {
755
+ const o = t instanceof Error ? t.message : "Failed to refresh session";
756
+ console.error("[AriaSessionManager] Refresh error:", o), this.updateSessionState({ isRefreshing: !1 }), this.config.onSessionRefreshError?.(t instanceof Error ? t : new Error(o)), this.scheduleRetry();
733
757
  }
734
758
  }
735
759
  // ============================================================================
@@ -770,11 +794,11 @@ class U {
770
794
  // ============================================================================
771
795
  /**
772
796
  * Check if session persistence is enabled
773
- * Always returns TRUE - sessions always persist when widget closes
774
- * Session only ends on logout (forceEndSession) or component unmount
797
+ * Returns FALSE - sessions are ended when widget closes to save Anam resources
798
+ * A new session with skip_greeting is created when widget reopens
775
799
  */
776
800
  isPersistSessionEnabled() {
777
- return !0;
801
+ return !1;
778
802
  }
779
803
  /**
780
804
  * Check if WebSocket should stay alive when paused
@@ -783,78 +807,50 @@ class U {
783
807
  return this.config.keepWebSocketAlive !== !1;
784
808
  }
785
809
  /**
786
- * Check if session is currently paused
810
+ * Check if widget is closed (session was ended on close)
811
+ * Note: With the new behavior, sessions are ended when widget closes,
812
+ * not paused. This returns true if the widget was closed.
787
813
  */
788
814
  isSessionPaused() {
789
- return this.isPaused;
815
+ return !this.anamClient && this.hasHadSessionBefore;
790
816
  }
791
817
  /**
792
- * Pause the session (called when widget closes)
793
- * - Does NOT end the session - keeps Anam client and video stream alive
794
- * - Optionally disconnects WebSocket (based on keepWebSocketAlive)
795
- * - Keeps session token and state in memory
796
- * - Session can be resumed when widget reopens
818
+ * Pause the session (called when widget closes / user hangs up)
819
+ *
820
+ * NEW BEHAVIOR: Ends the Anam session to save resources.
821
+ * When widget reopens, a new session is created with skip_greeting: true
822
+ * so the greeting doesn't play again.
823
+ *
824
+ * This is more resource-efficient than keeping the session alive.
797
825
  */
798
- pauseSession() {
799
- if (this.isPaused) {
800
- console.log("[AriaSessionManager] Session already paused");
801
- return;
802
- }
826
+ async pauseSession() {
803
827
  if (!this.anamClient) {
804
- console.log("[AriaSessionManager] No active Anam client, nothing to pause");
828
+ console.log("[AriaSessionManager] No active Anam client, nothing to pause/end");
805
829
  return;
806
830
  }
807
- console.log("[AriaSessionManager] Pausing session - keeping Anam client alive"), this.isPaused = !0, this.hiddenVideoElement && (this.hiddenVideoElement.muted = !0), this.hiddenAudioElement && (this.hiddenAudioElement.muted = !0, console.log("[AriaSessionManager] Audio element muted (session paused)")), this.shouldKeepWebSocketAlive() || (console.log("[AriaSessionManager] Disconnecting WebSocket (keepWebSocketAlive: false)"), this.ws && (this.ws.close(), this.ws = null)), this.config.onSessionPaused?.();
831
+ console.log("[AriaSessionManager] Widget closed - ending Anam session (will skip greeting on reopen)"), await this.endCurrentSession(), this.config.onSessionPaused?.();
808
832
  }
809
833
  /**
810
834
  * Resume the session (called when widget reopens)
811
- * - Reconnects WebSocket if needed
812
- * - Reuses existing Anam client and video stream
813
- * - Does NOT create a new session
814
- * @returns true if session was successfully resumed, false if a new session is needed
835
+ *
836
+ * NEW BEHAVIOR: Since we end the session on pause, this now creates a new session
837
+ * with skip_greeting: true. The new session token should already be preloaded
838
+ * (requested in endCurrentSession), so initialization should be fast.
839
+ *
840
+ * @returns true if session initialization started, false if already has active session
815
841
  */
816
842
  async resumeSession() {
817
- if (!this.isPaused)
818
- return console.log("[AriaSessionManager] Session not paused, nothing to resume"), !1;
819
- if (console.log("[AriaSessionManager] Resuming session"), this.isPaused = !1, !this.anamClient)
820
- return console.log("[AriaSessionManager] No Anam client, cannot resume - will create new session"), !1;
821
- if (this.sessionState.expires_at) {
822
- const o = new Date(this.sessionState.expires_at).getTime();
823
- if (Date.now() >= o)
824
- return console.log("[AriaSessionManager] Session expired, will create new session"), await this.stopStreaming(), this.resetSessionState(), !1;
825
- }
826
- if (!this.videoStream)
827
- return console.log("[AriaSessionManager] No video stream available, will create new session"), await this.stopStreaming(), this.resetSessionState(), !1;
828
- const e = this.videoStream.getTracks(), t = e.filter((o) => o.readyState === "live");
829
- return console.log("[AriaSessionManager] Video stream tracks:", e.length, "active:", t.length), this.hiddenAudioElement && (this.hiddenAudioElement.muted = !1, this.hiddenAudioElement.play().catch((o) => {
830
- console.warn("[AriaSessionManager] Audio play failed on resume:", o);
831
- }), console.log("[AriaSessionManager] Audio element unmuted (session resumed)")), this.isConnected() || (console.log("[AriaSessionManager] Reconnecting WebSocket for resumed session"), this.reconnectForResume()), this.setStatus("ready"), this.config.onSessionResumed?.(), !0;
832
- }
833
- /**
834
- * Reconnect WebSocket for session resume (without triggering new session)
835
- */
836
- reconnectForResume() {
837
- if (this.ws?.readyState === WebSocket.OPEN) {
838
- console.log("[AriaSessionManager] WebSocket already connected");
839
- return;
840
- }
841
- if (this.ws?.readyState === WebSocket.CONNECTING) {
842
- console.log("[AriaSessionManager] WebSocket already connecting");
843
- return;
844
- }
845
- this.setStatus("connecting");
846
- try {
847
- this.ws = new WebSocket(this.config.websocketUrl), this.ws.onopen = () => {
848
- console.log("[AriaSessionManager] WebSocket reconnected for resumed session"), this.setStatus("ready"), this.retryCount = 0, this.emit({ type: "connection_change", data: { connected: !0 } }), this.config.onConnectionStateChange?.(!0), console.log("[AriaSessionManager] Session resumed with existing token");
849
- }, this.ws.onmessage = (e) => this.handleWebSocketMessage(e), this.ws.onerror = (e) => {
850
- console.error("[AriaSessionManager] WebSocket error during resume:", e), this.setStatus("error"), this.updateSessionState({ lastError: "WebSocket connection error" }), this.config.onError?.(new Error("WebSocket connection failed"));
851
- }, this.ws.onclose = () => {
852
- console.log("[AriaSessionManager] WebSocket disconnected"), this.emit({ type: "connection_change", data: { connected: !1 } }), this.config.onConnectionStateChange?.(!1), !this.sessionState.isRefreshing && !this.isPaused && this.setStatus("idle");
853
- };
854
- } catch (e) {
855
- const t = e instanceof Error ? e.message : "Failed to reconnect WebSocket";
856
- console.error("[AriaSessionManager] Reconnection error:", t), this.setStatus("error"), this.updateSessionState({ lastError: t }), this.config.onError?.(e instanceof Error ? e : new Error(t));
843
+ if (console.log("[AriaSessionManager] Widget reopened - will create new session with skip_greeting"), this.anamClient && this.videoStream)
844
+ return console.log("[AriaSessionManager] Active session exists, no need to create new one"), this.setStatus("ready"), this.config.onSessionResumed?.(), !0;
845
+ if (this.sessionState.token && !this.isTokenExpired()) {
846
+ console.log("[AriaSessionManager] Session token ready, initializing Anam client (skip_greeting applied)");
847
+ try {
848
+ return await this.initializeAnamClient(this.sessionState.token), this.config.onSessionResumed?.(), !0;
849
+ } catch (e) {
850
+ console.error("[AriaSessionManager] Failed to initialize session on resume:", e), this.updateSessionState({ token: null, isSessionReady: !1 });
851
+ }
857
852
  }
853
+ return this.isConnected() ? (console.log("[AriaSessionManager] Requesting new session token for resume"), this.requestSessionToken()) : (console.log("[AriaSessionManager] WebSocket not connected, reconnecting..."), this.connect()), !1;
858
854
  }
859
855
  /**
860
856
  * Reset session state (used when session expires or needs to be recreated)
@@ -873,9 +869,24 @@ class U {
873
869
  /**
874
870
  * Force end the session (explicit user action or logout)
875
871
  * This always ends the session regardless of persistSession setting
872
+ *
873
+ * @param resetGreeting - If true, resets the greeting state so next session shows greeting (useful for logout)
874
+ */
875
+ async forceEndSession(e = !1) {
876
+ console.log("[AriaSessionManager] Force ending session", e ? "(resetting greeting state)" : ""), this.sendSessionEnd(), await this.stopStreaming(), this.resetSessionState(), this.isPaused = !1, e && (this.hasHadSessionBefore = !1, console.log("[AriaSessionManager] Greeting state reset - next session will show greeting")), this.setStatus("idle");
877
+ }
878
+ /**
879
+ * Reset the greeting state so the next session will show the greeting
880
+ * Call this when user logs out or you want to show greeting again
881
+ */
882
+ resetGreetingState() {
883
+ this.hasHadSessionBefore = !1, console.log("[AriaSessionManager] Greeting state reset - next session will show greeting");
884
+ }
885
+ /**
886
+ * Check if greeting will be skipped on next session
876
887
  */
877
- async forceEndSession() {
878
- console.log("[AriaSessionManager] Force ending session"), this.sendSessionEnd(), await this.stopStreaming(), this.resetSessionState(), this.isPaused = !1, this.setStatus("idle");
888
+ willSkipGreeting() {
889
+ return this.hasHadSessionBefore;
879
890
  }
880
891
  // ============================================================================
881
892
  // Auto-Reconnect on Anam Disconnect (Inactivity Timeout)
@@ -934,6 +945,18 @@ class U {
934
945
  isRefreshing: !1
935
946
  }), this.isAnamInitializing = !1;
936
947
  }
948
+ /**
949
+ * Clear stale session data when Anam disconnects while paused
950
+ * This ensures a fresh session is created when the widget reopens
951
+ */
952
+ clearStaleSessionForResume() {
953
+ console.log("[AriaSessionManager] Clearing stale session for resume"), this.anamClient = null, this.videoStream = null, this.audioInputStream && (this.audioInputStream.getTracks().forEach((e) => e.stop()), this.audioInputStream = null), this.removeHiddenVideoElement(), this.removeHiddenAudioElement(), this.updateSessionState({
954
+ session_id: null,
955
+ token: null,
956
+ isSessionReady: !1,
957
+ isPreloaded: !1
958
+ }), this.isAnamInitializing = !1, console.log("[AriaSessionManager] Stale session cleared, ready for fresh session on resume");
959
+ }
937
960
  /**
938
961
  * End the current session but keep WebSocket connected for new session creation
939
962
  * This is called when widget closes without persistSession enabled
@@ -1206,16 +1229,16 @@ class xe {
1206
1229
  */
1207
1230
  static async renderReactUI(e, t, o) {
1208
1231
  try {
1209
- const i = await import("react"), l = await import("react-dom/client"), { AriaStandaloneUI: a } = await Promise.resolve().then(() => vt), b = l.createRoot(e);
1232
+ const a = await import("react"), l = await import("react-dom/client"), { AriaStandaloneUI: i } = await Promise.resolve().then(() => vt), b = l.createRoot(e);
1210
1233
  S.reactRoot = b, b.render(
1211
- i.createElement(a, {
1234
+ a.createElement(i, {
1212
1235
  theme: t,
1213
1236
  triggerLabel: o,
1214
1237
  container: e
1215
1238
  })
1216
1239
  ), console.log("[AriaCore] React UI mounted");
1217
- } catch (i) {
1218
- console.error("[AriaCore] Failed to mount React UI:", i), S.config?.onError?.(i instanceof Error ? i : new Error(String(i)));
1240
+ } catch (a) {
1241
+ console.error("[AriaCore] Failed to mount React UI:", a), S.config?.onError?.(a instanceof Error ? a : new Error(String(a)));
1219
1242
  }
1220
1243
  }
1221
1244
  /**
@@ -1232,7 +1255,7 @@ function Ie(r) {
1232
1255
  if (!Sr(r))
1233
1256
  return null;
1234
1257
  try {
1235
- const o = r.split(".")[1].replace(/-/g, "+").replace(/_/g, "/"), i = o.padEnd(o.length + (4 - o.length % 4) % 4, "="), l = atob(i);
1258
+ const o = r.split(".")[1].replace(/-/g, "+").replace(/_/g, "/"), a = o.padEnd(o.length + (4 - o.length % 4) % 4, "="), l = atob(a);
1236
1259
  return JSON.parse(l);
1237
1260
  } catch (e) {
1238
1261
  return console.error("Failed to decode JWT:", e), null;
@@ -1265,12 +1288,12 @@ function St(r) {
1265
1288
  exp: null,
1266
1289
  iat: null
1267
1290
  };
1268
- const t = Er(r), o = typeof e.exp == "number" ? e.exp : null, i = typeof e.iat == "number" ? e.iat : null;
1291
+ const t = Er(r), o = typeof e.exp == "number" ? e.exp : null, a = typeof e.iat == "number" ? e.iat : null;
1269
1292
  return {
1270
1293
  sessionId: t,
1271
1294
  payload: e,
1272
1295
  exp: o,
1273
- iat: i
1296
+ iat: a
1274
1297
  };
1275
1298
  }
1276
1299
  function Et(r) {
@@ -1285,33 +1308,33 @@ const Ke = ({
1285
1308
  styles: e = "",
1286
1309
  className: t,
1287
1310
  style: o,
1288
- as: i = "div"
1311
+ as: a = "div"
1289
1312
  }) => {
1290
- const l = me(null), [a, b] = I(null);
1313
+ const l = me(null), [i, b] = I(null);
1291
1314
  ee(() => {
1292
1315
  const f = l.current;
1293
1316
  if (!f) return;
1294
1317
  let A = f.shadowRoot;
1295
1318
  A || (A = f.attachShadow({ mode: "open" })), b(A);
1296
1319
  }, []), ee(() => {
1297
- if (!a || !e) return;
1298
- const f = a.querySelector("style[data-aria-styles]");
1320
+ if (!i || !e) return;
1321
+ const f = i.querySelector("style[data-aria-styles]");
1299
1322
  if (f) {
1300
1323
  f.textContent = e;
1301
1324
  return;
1302
1325
  }
1303
1326
  const A = document.createElement("style");
1304
- return A.setAttribute("data-aria-styles", "true"), A.textContent = e, a.prepend(A), () => {
1327
+ return A.setAttribute("data-aria-styles", "true"), A.textContent = e, i.prepend(A), () => {
1305
1328
  A.remove();
1306
1329
  };
1307
- }, [a, e]);
1330
+ }, [i, e]);
1308
1331
  const [d, m] = I(null);
1309
1332
  return ee(() => {
1310
- if (!a) return;
1311
- let f = a.querySelector(".aria-shadow-content");
1312
- f || (f = document.createElement("div"), f.className = "aria-shadow-content", a.appendChild(f)), m(f);
1313
- }, [a]), /* @__PURE__ */ n(
1314
- i,
1333
+ if (!i) return;
1334
+ let f = i.querySelector(".aria-shadow-content");
1335
+ f || (f = document.createElement("div"), f.className = "aria-shadow-content", i.appendChild(f)), m(f);
1336
+ }, [i]), /* @__PURE__ */ n(
1337
+ a,
1315
1338
  {
1316
1339
  ref: l,
1317
1340
  className: t,
@@ -1327,23 +1350,23 @@ function Xe(r) {
1327
1350
  var e, t, o = "";
1328
1351
  if (typeof r == "string" || typeof r == "number") o += r;
1329
1352
  else if (typeof r == "object") if (Array.isArray(r)) {
1330
- var i = r.length;
1331
- for (e = 0; e < i; e++) r[e] && (t = Xe(r[e])) && (o && (o += " "), o += t);
1353
+ var a = r.length;
1354
+ for (e = 0; e < a; e++) r[e] && (t = Xe(r[e])) && (o && (o += " "), o += t);
1332
1355
  } else for (t in r) r[t] && (o && (o += " "), o += t);
1333
1356
  return o;
1334
1357
  }
1335
1358
  function Cr() {
1336
- for (var r, e, t = 0, o = "", i = arguments.length; t < i; t++) (r = arguments[t]) && (e = Xe(r)) && (o && (o += " "), o += e);
1359
+ for (var r, e, t = 0, o = "", a = arguments.length; t < a; t++) (r = arguments[t]) && (e = Xe(r)) && (o && (o += " "), o += e);
1337
1360
  return o;
1338
1361
  }
1339
- const Nr = (r, e) => {
1362
+ const Rr = (r, e) => {
1340
1363
  const t = new Array(r.length + e.length);
1341
1364
  for (let o = 0; o < r.length; o++)
1342
1365
  t[o] = r[o];
1343
1366
  for (let o = 0; o < e.length; o++)
1344
1367
  t[r.length + o] = e[o];
1345
1368
  return t;
1346
- }, Rr = (r, e) => ({
1369
+ }, Nr = (r, e) => ({
1347
1370
  classGroupId: r,
1348
1371
  validator: e
1349
1372
  }), Ze = (r = /* @__PURE__ */ new Map(), e = null, t) => ({
@@ -1356,34 +1379,34 @@ const Nr = (r, e) => {
1356
1379
  conflictingClassGroupModifiers: o
1357
1380
  } = r;
1358
1381
  return {
1359
- getClassGroupId: (a) => {
1360
- if (a.startsWith("[") && a.endsWith("]"))
1361
- return zr(a);
1362
- const b = a.split(Ee), d = b[0] === "" && b.length > 1 ? 1 : 0;
1382
+ getClassGroupId: (i) => {
1383
+ if (i.startsWith("[") && i.endsWith("]"))
1384
+ return zr(i);
1385
+ const b = i.split(Ee), d = b[0] === "" && b.length > 1 ? 1 : 0;
1363
1386
  return Ye(b, d, e);
1364
1387
  },
1365
- getConflictingClassGroupIds: (a, b) => {
1388
+ getConflictingClassGroupIds: (i, b) => {
1366
1389
  if (b) {
1367
- const d = o[a], m = t[a];
1368
- return d ? m ? Nr(m, d) : d : m || Le;
1390
+ const d = o[i], m = t[i];
1391
+ return d ? m ? Rr(m, d) : d : m || Le;
1369
1392
  }
1370
- return t[a] || Le;
1393
+ return t[i] || Le;
1371
1394
  }
1372
1395
  };
1373
1396
  }, Ye = (r, e, t) => {
1374
1397
  if (r.length - e === 0)
1375
1398
  return t.classGroupId;
1376
- const i = r[e], l = t.nextPart.get(i);
1399
+ const a = r[e], l = t.nextPart.get(a);
1377
1400
  if (l) {
1378
1401
  const m = Ye(r, e + 1, l);
1379
1402
  if (m) return m;
1380
1403
  }
1381
- const a = t.validators;
1382
- if (a === null)
1404
+ const i = t.validators;
1405
+ if (i === null)
1383
1406
  return;
1384
- const b = e === 0 ? r.join(Ee) : r.slice(e).join(Ee), d = a.length;
1407
+ const b = e === 0 ? r.join(Ee) : r.slice(e).join(Ee), d = i.length;
1385
1408
  for (let m = 0; m < d; m++) {
1386
- const f = a[m];
1409
+ const f = i[m];
1387
1410
  if (f.validator(b))
1388
1411
  return f.classGroupId;
1389
1412
  }
@@ -1395,55 +1418,55 @@ const Nr = (r, e) => {
1395
1418
  theme: e,
1396
1419
  classGroups: t
1397
1420
  } = r;
1398
- return Vr(t, e);
1399
- }, Vr = (r, e) => {
1421
+ return Hr(t, e);
1422
+ }, Hr = (r, e) => {
1400
1423
  const t = Ze();
1401
1424
  for (const o in r) {
1402
- const i = r[o];
1403
- ze(i, t, o, e);
1425
+ const a = r[o];
1426
+ ze(a, t, o, e);
1404
1427
  }
1405
1428
  return t;
1406
1429
  }, ze = (r, e, t, o) => {
1407
- const i = r.length;
1408
- for (let l = 0; l < i; l++) {
1409
- const a = r[l];
1410
- jr(a, e, t, o);
1430
+ const a = r.length;
1431
+ for (let l = 0; l < a; l++) {
1432
+ const i = r[l];
1433
+ Vr(i, e, t, o);
1411
1434
  }
1412
- }, jr = (r, e, t, o) => {
1435
+ }, Vr = (r, e, t, o) => {
1413
1436
  if (typeof r == "string") {
1414
- Dr(r, e, t);
1437
+ jr(r, e, t);
1415
1438
  return;
1416
1439
  }
1417
1440
  if (typeof r == "function") {
1418
- Hr(r, e, t, o);
1441
+ Br(r, e, t, o);
1419
1442
  return;
1420
1443
  }
1421
- Wr(r, e, t, o);
1422
- }, Dr = (r, e, t) => {
1444
+ Dr(r, e, t, o);
1445
+ }, jr = (r, e, t) => {
1423
1446
  const o = r === "" ? e : $e(e, r);
1424
1447
  o.classGroupId = t;
1425
- }, Hr = (r, e, t, o) => {
1448
+ }, Br = (r, e, t, o) => {
1426
1449
  if (Or(r)) {
1427
1450
  ze(r(o), e, t, o);
1428
1451
  return;
1429
1452
  }
1430
- e.validators === null && (e.validators = []), e.validators.push(Rr(t, r));
1431
- }, Wr = (r, e, t, o) => {
1432
- const i = Object.entries(r), l = i.length;
1433
- for (let a = 0; a < l; a++) {
1434
- const [b, d] = i[a];
1453
+ e.validators === null && (e.validators = []), e.validators.push(Nr(t, r));
1454
+ }, Dr = (r, e, t, o) => {
1455
+ const a = Object.entries(r), l = a.length;
1456
+ for (let i = 0; i < l; i++) {
1457
+ const [b, d] = a[i];
1435
1458
  ze(d, $e(e, b), t, o);
1436
1459
  }
1437
1460
  }, $e = (r, e) => {
1438
1461
  let t = r;
1439
- const o = e.split(Ee), i = o.length;
1440
- for (let l = 0; l < i; l++) {
1441
- const a = o[l];
1442
- let b = t.nextPart.get(a);
1443
- b || (b = Ze(), t.nextPart.set(a, b)), t = b;
1462
+ const o = e.split(Ee), a = o.length;
1463
+ for (let l = 0; l < a; l++) {
1464
+ const i = o[l];
1465
+ let b = t.nextPart.get(i);
1466
+ b || (b = Ze(), t.nextPart.set(i, b)), t = b;
1444
1467
  }
1445
1468
  return t;
1446
- }, Or = (r) => "isThemeGetter" in r && r.isThemeGetter === !0, Br = (r) => {
1469
+ }, Or = (r) => "isThemeGetter" in r && r.isThemeGetter === !0, Wr = (r) => {
1447
1470
  if (r < 1)
1448
1471
  return {
1449
1472
  get: () => {
@@ -1452,71 +1475,71 @@ const Nr = (r, e) => {
1452
1475
  }
1453
1476
  };
1454
1477
  let e = 0, t = /* @__PURE__ */ Object.create(null), o = /* @__PURE__ */ Object.create(null);
1455
- const i = (l, a) => {
1456
- t[l] = a, e++, e > r && (e = 0, o = t, t = /* @__PURE__ */ Object.create(null));
1478
+ const a = (l, i) => {
1479
+ t[l] = i, e++, e > r && (e = 0, o = t, t = /* @__PURE__ */ Object.create(null));
1457
1480
  };
1458
1481
  return {
1459
1482
  get(l) {
1460
- let a = t[l];
1461
- if (a !== void 0)
1462
- return a;
1463
- if ((a = o[l]) !== void 0)
1464
- return i(l, a), a;
1483
+ let i = t[l];
1484
+ if (i !== void 0)
1485
+ return i;
1486
+ if ((i = o[l]) !== void 0)
1487
+ return a(l, i), i;
1465
1488
  },
1466
- set(l, a) {
1467
- l in t ? t[l] = a : i(l, a);
1489
+ set(l, i) {
1490
+ l in t ? t[l] = i : a(l, i);
1468
1491
  }
1469
1492
  };
1470
- }, Re = "!", _e = ":", Fr = [], Ge = (r, e, t, o, i) => ({
1493
+ }, Ne = "!", _e = ":", Fr = [], Ge = (r, e, t, o, a) => ({
1471
1494
  modifiers: r,
1472
1495
  hasImportantModifier: e,
1473
1496
  baseClassName: t,
1474
1497
  maybePostfixModifierPosition: o,
1475
- isExternal: i
1498
+ isExternal: a
1476
1499
  }), Ur = (r) => {
1477
1500
  const {
1478
1501
  prefix: e,
1479
1502
  experimentalParseClassName: t
1480
1503
  } = r;
1481
- let o = (i) => {
1504
+ let o = (a) => {
1482
1505
  const l = [];
1483
- let a = 0, b = 0, d = 0, m;
1484
- const f = i.length;
1485
- for (let H = 0; H < f; H++) {
1486
- const P = i[H];
1487
- if (a === 0 && b === 0) {
1506
+ let i = 0, b = 0, d = 0, m;
1507
+ const f = a.length;
1508
+ for (let B = 0; B < f; B++) {
1509
+ const P = a[B];
1510
+ if (i === 0 && b === 0) {
1488
1511
  if (P === _e) {
1489
- l.push(i.slice(d, H)), d = H + 1;
1512
+ l.push(a.slice(d, B)), d = B + 1;
1490
1513
  continue;
1491
1514
  }
1492
1515
  if (P === "/") {
1493
- m = H;
1516
+ m = B;
1494
1517
  continue;
1495
1518
  }
1496
1519
  }
1497
- P === "[" ? a++ : P === "]" ? a-- : P === "(" ? b++ : P === ")" && b--;
1520
+ P === "[" ? i++ : P === "]" ? i-- : P === "(" ? b++ : P === ")" && b--;
1498
1521
  }
1499
- const A = l.length === 0 ? i : i.slice(d);
1500
- let N = A, z = !1;
1501
- A.endsWith(Re) ? (N = A.slice(0, -1), z = !0) : (
1522
+ const A = l.length === 0 ? a : a.slice(d);
1523
+ let R = A, z = !1;
1524
+ A.endsWith(Ne) ? (R = A.slice(0, -1), z = !0) : (
1502
1525
  /**
1503
1526
  * In Tailwind CSS v3 the important modifier was at the start of the base class name. This is still supported for legacy reasons.
1504
1527
  * @see https://github.com/dcastil/tailwind-merge/issues/513#issuecomment-2614029864
1505
1528
  */
1506
- A.startsWith(Re) && (N = A.slice(1), z = !0)
1529
+ A.startsWith(Ne) && (R = A.slice(1), z = !0)
1507
1530
  );
1508
- const D = m && m > d ? m - d : void 0;
1509
- return Ge(l, z, N, D);
1531
+ const j = m && m > d ? m - d : void 0;
1532
+ return Ge(l, z, R, j);
1510
1533
  };
1511
1534
  if (e) {
1512
- const i = e + _e, l = o;
1513
- o = (a) => a.startsWith(i) ? l(a.slice(i.length)) : Ge(Fr, !1, a, void 0, !0);
1535
+ const a = e + _e, l = o;
1536
+ o = (i) => i.startsWith(a) ? l(i.slice(a.length)) : Ge(Fr, !1, i, void 0, !0);
1514
1537
  }
1515
1538
  if (t) {
1516
- const i = o;
1539
+ const a = o;
1517
1540
  o = (l) => t({
1518
1541
  className: l,
1519
- parseClassName: i
1542
+ parseClassName: a
1520
1543
  });
1521
1544
  }
1522
1545
  return o;
@@ -1526,15 +1549,15 @@ const Nr = (r, e) => {
1526
1549
  e.set(t, 1e6 + o);
1527
1550
  }), (t) => {
1528
1551
  const o = [];
1529
- let i = [];
1552
+ let a = [];
1530
1553
  for (let l = 0; l < t.length; l++) {
1531
- const a = t[l], b = a[0] === "[", d = e.has(a);
1532
- b || d ? (i.length > 0 && (i.sort(), o.push(...i), i = []), o.push(a)) : i.push(a);
1554
+ const i = t[l], b = i[0] === "[", d = e.has(i);
1555
+ b || d ? (a.length > 0 && (a.sort(), o.push(...a), a = []), o.push(i)) : a.push(i);
1533
1556
  }
1534
- return i.length > 0 && (i.sort(), o.push(...i)), o;
1557
+ return a.length > 0 && (a.sort(), o.push(...a)), o;
1535
1558
  };
1536
1559
  }, _r = (r) => ({
1537
- cache: Br(r.cacheSize),
1560
+ cache: Wr(r.cacheSize),
1538
1561
  parseClassName: Ur(r),
1539
1562
  sortModifiers: Lr(r),
1540
1563
  ...Ir(r)
@@ -1542,51 +1565,51 @@ const Nr = (r, e) => {
1542
1565
  const {
1543
1566
  parseClassName: t,
1544
1567
  getClassGroupId: o,
1545
- getConflictingClassGroupIds: i,
1568
+ getConflictingClassGroupIds: a,
1546
1569
  sortModifiers: l
1547
- } = e, a = [], b = r.trim().split(Gr);
1570
+ } = e, i = [], b = r.trim().split(Gr);
1548
1571
  let d = "";
1549
1572
  for (let m = b.length - 1; m >= 0; m -= 1) {
1550
1573
  const f = b[m], {
1551
1574
  isExternal: A,
1552
- modifiers: N,
1575
+ modifiers: R,
1553
1576
  hasImportantModifier: z,
1554
- baseClassName: D,
1555
- maybePostfixModifierPosition: H
1577
+ baseClassName: j,
1578
+ maybePostfixModifierPosition: B
1556
1579
  } = t(f);
1557
1580
  if (A) {
1558
1581
  d = f + (d.length > 0 ? " " + d : d);
1559
1582
  continue;
1560
1583
  }
1561
- let P = !!H, G = o(P ? D.substring(0, H) : D);
1584
+ let P = !!B, G = o(P ? j.substring(0, B) : j);
1562
1585
  if (!G) {
1563
1586
  if (!P) {
1564
1587
  d = f + (d.length > 0 ? " " + d : d);
1565
1588
  continue;
1566
1589
  }
1567
- if (G = o(D), !G) {
1590
+ if (G = o(j), !G) {
1568
1591
  d = f + (d.length > 0 ? " " + d : d);
1569
1592
  continue;
1570
1593
  }
1571
1594
  P = !1;
1572
1595
  }
1573
- const K = N.length === 0 ? "" : N.length === 1 ? N[0] : l(N).join(":"), Q = z ? K + Re : K, M = Q + G;
1574
- if (a.indexOf(M) > -1)
1596
+ const K = R.length === 0 ? "" : R.length === 1 ? R[0] : l(R).join(":"), Q = z ? K + Ne : K, M = Q + G;
1597
+ if (i.indexOf(M) > -1)
1575
1598
  continue;
1576
- a.push(M);
1577
- const L = i(G, P);
1599
+ i.push(M);
1600
+ const L = a(G, P);
1578
1601
  for (let _ = 0; _ < L.length; ++_) {
1579
1602
  const q = L[_];
1580
- a.push(Q + q);
1603
+ i.push(Q + q);
1581
1604
  }
1582
1605
  d = f + (d.length > 0 ? " " + d : d);
1583
1606
  }
1584
1607
  return d;
1585
1608
  }, qr = (...r) => {
1586
- let e = 0, t, o, i = "";
1609
+ let e = 0, t, o, a = "";
1587
1610
  for (; e < r.length; )
1588
- (t = r[e++]) && (o = er(t)) && (i && (i += " "), i += o);
1589
- return i;
1611
+ (t = r[e++]) && (o = er(t)) && (a && (a += " "), a += o);
1612
+ return a;
1590
1613
  }, er = (r) => {
1591
1614
  if (typeof r == "string")
1592
1615
  return r;
@@ -1595,18 +1618,18 @@ const Nr = (r, e) => {
1595
1618
  r[o] && (e = er(r[o])) && (t && (t += " "), t += e);
1596
1619
  return t;
1597
1620
  }, Kr = (r, ...e) => {
1598
- let t, o, i, l;
1599
- const a = (d) => {
1621
+ let t, o, a, l;
1622
+ const i = (d) => {
1600
1623
  const m = e.reduce((f, A) => A(f), r());
1601
- return t = _r(m), o = t.cache.get, i = t.cache.set, l = b, b(d);
1624
+ return t = _r(m), o = t.cache.get, a = t.cache.set, l = b, b(d);
1602
1625
  }, b = (d) => {
1603
1626
  const m = o(d);
1604
1627
  if (m)
1605
1628
  return m;
1606
1629
  const f = Qr(d, t);
1607
- return i(d, f), f;
1630
+ return a(d, f), f;
1608
1631
  };
1609
- return l = a, (...d) => l(qr(...d));
1632
+ return l = i, (...d) => l(qr(...d));
1610
1633
  }, Jr = [], T = (r) => {
1611
1634
  const e = (t) => t[r] || Jr;
1612
1635
  return e.isThemeGetter = !0, e;
@@ -1622,7 +1645,7 @@ const Nr = (r, e) => {
1622
1645
  const o = tr.exec(r);
1623
1646
  return o ? o[1] ? e(o[1]) : t : !1;
1624
1647
  }, ar = (r) => r === "position" || r === "percentage", ir = (r) => r === "image" || r === "url", nr = (r) => r === "length" || r === "size" || r === "bg-size", sr = (r) => r === "length", ht = (r) => r === "number", ut = (r) => r === "family-name", lr = (r) => r === "shadow", pt = () => {
1625
- const r = T("color"), e = T("font"), t = T("text"), o = T("font-weight"), i = T("tracking"), l = T("leading"), a = T("breakpoint"), b = T("container"), d = T("spacing"), m = T("radius"), f = T("shadow"), A = T("inset-shadow"), N = T("text-shadow"), z = T("drop-shadow"), D = T("blur"), H = T("perspective"), P = T("aspect"), G = T("ease"), K = T("animate"), Q = () => ["auto", "avoid", "all", "avoid-page", "page", "left", "right", "column"], M = () => [
1648
+ const r = T("color"), e = T("font"), t = T("text"), o = T("font-weight"), a = T("tracking"), l = T("leading"), i = T("breakpoint"), b = T("container"), d = T("spacing"), m = T("radius"), f = T("shadow"), A = T("inset-shadow"), R = T("text-shadow"), z = T("drop-shadow"), j = T("blur"), B = T("perspective"), P = T("aspect"), G = T("ease"), K = T("animate"), Q = () => ["auto", "avoid", "all", "avoid-page", "page", "left", "right", "column"], M = () => [
1626
1649
  "center",
1627
1650
  "top",
1628
1651
  "bottom",
@@ -1640,15 +1663,15 @@ const Nr = (r, e) => {
1640
1663
  "bottom-left",
1641
1664
  // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378
1642
1665
  "left-bottom"
1643
- ], L = () => [...M(), h, g], _ = () => ["auto", "hidden", "clip", "visible", "scroll"], q = () => ["auto", "contain", "none"], y = () => [h, g, d], W = () => [pe, "full", "auto", ...y()], s = () => [te, "none", "subgrid", h, g], O = () => ["auto", {
1666
+ ], L = () => [...M(), h, g], _ = () => ["auto", "hidden", "clip", "visible", "scroll"], q = () => ["auto", "contain", "none"], y = () => [h, g, d], D = () => [pe, "full", "auto", ...y()], s = () => [te, "none", "subgrid", h, g], O = () => ["auto", {
1644
1667
  span: ["full", te, h, g]
1645
- }, te, h, g], Y = () => [te, "auto", h, g], re = () => ["auto", "min", "max", "fr", h, g], J = () => ["start", "end", "center", "between", "around", "evenly", "stretch", "baseline", "center-safe", "end-safe"], w = () => ["start", "end", "center", "stretch", "center-safe", "end-safe"], p = () => ["auto", ...y()], V = () => [pe, "auto", "full", "dvw", "dvh", "lvw", "lvh", "svw", "svh", "min", "max", "fit", ...y()], v = () => [r, h, g], le = () => [...M(), qe, Qe, {
1668
+ }, te, h, g], Y = () => [te, "auto", h, g], re = () => ["auto", "min", "max", "fr", h, g], J = () => ["start", "end", "center", "between", "around", "evenly", "stretch", "baseline", "center-safe", "end-safe"], w = () => ["start", "end", "center", "stretch", "center-safe", "end-safe"], p = () => ["auto", ...y()], H = () => [pe, "auto", "full", "dvw", "dvh", "lvw", "lvh", "svw", "svh", "min", "max", "fit", ...y()], v = () => [r, h, g], le = () => [...M(), qe, Qe, {
1646
1669
  position: [h, g]
1647
1670
  }], ce = () => ["no-repeat", {
1648
1671
  repeat: ["", "x", "y", "space", "round"]
1649
1672
  }], de = () => ["auto", "cover", "contain", dt, st, {
1650
1673
  size: [h, g]
1651
- }], oe = () => [Me, ye, se], R = () => [
1674
+ }], oe = () => [Me, ye, se], N = () => [
1652
1675
  // Deprecated since Tailwind CSS v4.0.0
1653
1676
  "",
1654
1677
  "none",
@@ -1656,11 +1679,11 @@ const Nr = (r, e) => {
1656
1679
  m,
1657
1680
  h,
1658
1681
  g
1659
- ], B = () => ["", x, ye, se], X = () => ["solid", "dashed", "dotted", "double"], ae = () => ["normal", "multiply", "screen", "overlay", "darken", "lighten", "color-dodge", "color-burn", "hard-light", "soft-light", "difference", "exclusion", "hue", "saturation", "color", "luminosity"], C = () => [x, Me, qe, Qe], ge = () => [
1682
+ ], W = () => ["", x, ye, se], X = () => ["solid", "dashed", "dotted", "double"], ae = () => ["normal", "multiply", "screen", "overlay", "darken", "lighten", "color-dodge", "color-burn", "hard-light", "soft-light", "difference", "exclusion", "hue", "saturation", "color", "luminosity"], C = () => [x, Me, qe, Qe], ge = () => [
1660
1683
  // Deprecated since Tailwind CSS v4.0.0
1661
1684
  "",
1662
1685
  "none",
1663
- D,
1686
+ j,
1664
1687
  h,
1665
1688
  g
1666
1689
  ], ie = () => ["none", x, h, g], he = () => ["none", x, h, g], be = () => [x, h, g], ue = () => [pe, "full", ...y()];
@@ -1841,63 +1864,63 @@ const Nr = (r, e) => {
1841
1864
  * @see https://tailwindcss.com/docs/top-right-bottom-left
1842
1865
  */
1843
1866
  inset: [{
1844
- inset: W()
1867
+ inset: D()
1845
1868
  }],
1846
1869
  /**
1847
1870
  * Right / Left
1848
1871
  * @see https://tailwindcss.com/docs/top-right-bottom-left
1849
1872
  */
1850
1873
  "inset-x": [{
1851
- "inset-x": W()
1874
+ "inset-x": D()
1852
1875
  }],
1853
1876
  /**
1854
1877
  * Top / Bottom
1855
1878
  * @see https://tailwindcss.com/docs/top-right-bottom-left
1856
1879
  */
1857
1880
  "inset-y": [{
1858
- "inset-y": W()
1881
+ "inset-y": D()
1859
1882
  }],
1860
1883
  /**
1861
1884
  * Start
1862
1885
  * @see https://tailwindcss.com/docs/top-right-bottom-left
1863
1886
  */
1864
1887
  start: [{
1865
- start: W()
1888
+ start: D()
1866
1889
  }],
1867
1890
  /**
1868
1891
  * End
1869
1892
  * @see https://tailwindcss.com/docs/top-right-bottom-left
1870
1893
  */
1871
1894
  end: [{
1872
- end: W()
1895
+ end: D()
1873
1896
  }],
1874
1897
  /**
1875
1898
  * Top
1876
1899
  * @see https://tailwindcss.com/docs/top-right-bottom-left
1877
1900
  */
1878
1901
  top: [{
1879
- top: W()
1902
+ top: D()
1880
1903
  }],
1881
1904
  /**
1882
1905
  * Right
1883
1906
  * @see https://tailwindcss.com/docs/top-right-bottom-left
1884
1907
  */
1885
1908
  right: [{
1886
- right: W()
1909
+ right: D()
1887
1910
  }],
1888
1911
  /**
1889
1912
  * Bottom
1890
1913
  * @see https://tailwindcss.com/docs/top-right-bottom-left
1891
1914
  */
1892
1915
  bottom: [{
1893
- bottom: W()
1916
+ bottom: D()
1894
1917
  }],
1895
1918
  /**
1896
1919
  * Left
1897
1920
  * @see https://tailwindcss.com/docs/top-right-bottom-left
1898
1921
  */
1899
1922
  left: [{
1900
- left: W()
1923
+ left: D()
1901
1924
  }],
1902
1925
  /**
1903
1926
  * Visibility
@@ -2287,14 +2310,14 @@ const Nr = (r, e) => {
2287
2310
  * @see https://tailwindcss.com/docs/width#setting-both-width-and-height
2288
2311
  */
2289
2312
  size: [{
2290
- size: V()
2313
+ size: H()
2291
2314
  }],
2292
2315
  /**
2293
2316
  * Width
2294
2317
  * @see https://tailwindcss.com/docs/width
2295
2318
  */
2296
2319
  w: [{
2297
- w: [b, "screen", ...V()]
2320
+ w: [b, "screen", ...H()]
2298
2321
  }],
2299
2322
  /**
2300
2323
  * Min-Width
@@ -2306,7 +2329,7 @@ const Nr = (r, e) => {
2306
2329
  "screen",
2307
2330
  /** Deprecated. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */
2308
2331
  "none",
2309
- ...V()
2332
+ ...H()
2310
2333
  ]
2311
2334
  }],
2312
2335
  /**
@@ -2322,9 +2345,9 @@ const Nr = (r, e) => {
2322
2345
  "prose",
2323
2346
  /** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */
2324
2347
  {
2325
- screen: [a]
2348
+ screen: [i]
2326
2349
  },
2327
- ...V()
2350
+ ...H()
2328
2351
  ]
2329
2352
  }],
2330
2353
  /**
@@ -2332,21 +2355,21 @@ const Nr = (r, e) => {
2332
2355
  * @see https://tailwindcss.com/docs/height
2333
2356
  */
2334
2357
  h: [{
2335
- h: ["screen", "lh", ...V()]
2358
+ h: ["screen", "lh", ...H()]
2336
2359
  }],
2337
2360
  /**
2338
2361
  * Min-Height
2339
2362
  * @see https://tailwindcss.com/docs/min-height
2340
2363
  */
2341
2364
  "min-h": [{
2342
- "min-h": ["screen", "lh", "none", ...V()]
2365
+ "min-h": ["screen", "lh", "none", ...H()]
2343
2366
  }],
2344
2367
  /**
2345
2368
  * Max-Height
2346
2369
  * @see https://tailwindcss.com/docs/max-height
2347
2370
  */
2348
2371
  "max-h": [{
2349
- "max-h": ["screen", "lh", ...V()]
2372
+ "max-h": ["screen", "lh", ...H()]
2350
2373
  }],
2351
2374
  // ------------------
2352
2375
  // --- Typography ---
@@ -2424,7 +2447,7 @@ const Nr = (r, e) => {
2424
2447
  * @see https://tailwindcss.com/docs/letter-spacing
2425
2448
  */
2426
2449
  tracking: [{
2427
- tracking: [i, h, g]
2450
+ tracking: [a, h, g]
2428
2451
  }],
2429
2452
  /**
2430
2453
  * Line Clamp
@@ -2701,175 +2724,175 @@ const Nr = (r, e) => {
2701
2724
  * @see https://tailwindcss.com/docs/border-radius
2702
2725
  */
2703
2726
  rounded: [{
2704
- rounded: R()
2727
+ rounded: N()
2705
2728
  }],
2706
2729
  /**
2707
2730
  * Border Radius Start
2708
2731
  * @see https://tailwindcss.com/docs/border-radius
2709
2732
  */
2710
2733
  "rounded-s": [{
2711
- "rounded-s": R()
2734
+ "rounded-s": N()
2712
2735
  }],
2713
2736
  /**
2714
2737
  * Border Radius End
2715
2738
  * @see https://tailwindcss.com/docs/border-radius
2716
2739
  */
2717
2740
  "rounded-e": [{
2718
- "rounded-e": R()
2741
+ "rounded-e": N()
2719
2742
  }],
2720
2743
  /**
2721
2744
  * Border Radius Top
2722
2745
  * @see https://tailwindcss.com/docs/border-radius
2723
2746
  */
2724
2747
  "rounded-t": [{
2725
- "rounded-t": R()
2748
+ "rounded-t": N()
2726
2749
  }],
2727
2750
  /**
2728
2751
  * Border Radius Right
2729
2752
  * @see https://tailwindcss.com/docs/border-radius
2730
2753
  */
2731
2754
  "rounded-r": [{
2732
- "rounded-r": R()
2755
+ "rounded-r": N()
2733
2756
  }],
2734
2757
  /**
2735
2758
  * Border Radius Bottom
2736
2759
  * @see https://tailwindcss.com/docs/border-radius
2737
2760
  */
2738
2761
  "rounded-b": [{
2739
- "rounded-b": R()
2762
+ "rounded-b": N()
2740
2763
  }],
2741
2764
  /**
2742
2765
  * Border Radius Left
2743
2766
  * @see https://tailwindcss.com/docs/border-radius
2744
2767
  */
2745
2768
  "rounded-l": [{
2746
- "rounded-l": R()
2769
+ "rounded-l": N()
2747
2770
  }],
2748
2771
  /**
2749
2772
  * Border Radius Start Start
2750
2773
  * @see https://tailwindcss.com/docs/border-radius
2751
2774
  */
2752
2775
  "rounded-ss": [{
2753
- "rounded-ss": R()
2776
+ "rounded-ss": N()
2754
2777
  }],
2755
2778
  /**
2756
2779
  * Border Radius Start End
2757
2780
  * @see https://tailwindcss.com/docs/border-radius
2758
2781
  */
2759
2782
  "rounded-se": [{
2760
- "rounded-se": R()
2783
+ "rounded-se": N()
2761
2784
  }],
2762
2785
  /**
2763
2786
  * Border Radius End End
2764
2787
  * @see https://tailwindcss.com/docs/border-radius
2765
2788
  */
2766
2789
  "rounded-ee": [{
2767
- "rounded-ee": R()
2790
+ "rounded-ee": N()
2768
2791
  }],
2769
2792
  /**
2770
2793
  * Border Radius End Start
2771
2794
  * @see https://tailwindcss.com/docs/border-radius
2772
2795
  */
2773
2796
  "rounded-es": [{
2774
- "rounded-es": R()
2797
+ "rounded-es": N()
2775
2798
  }],
2776
2799
  /**
2777
2800
  * Border Radius Top Left
2778
2801
  * @see https://tailwindcss.com/docs/border-radius
2779
2802
  */
2780
2803
  "rounded-tl": [{
2781
- "rounded-tl": R()
2804
+ "rounded-tl": N()
2782
2805
  }],
2783
2806
  /**
2784
2807
  * Border Radius Top Right
2785
2808
  * @see https://tailwindcss.com/docs/border-radius
2786
2809
  */
2787
2810
  "rounded-tr": [{
2788
- "rounded-tr": R()
2811
+ "rounded-tr": N()
2789
2812
  }],
2790
2813
  /**
2791
2814
  * Border Radius Bottom Right
2792
2815
  * @see https://tailwindcss.com/docs/border-radius
2793
2816
  */
2794
2817
  "rounded-br": [{
2795
- "rounded-br": R()
2818
+ "rounded-br": N()
2796
2819
  }],
2797
2820
  /**
2798
2821
  * Border Radius Bottom Left
2799
2822
  * @see https://tailwindcss.com/docs/border-radius
2800
2823
  */
2801
2824
  "rounded-bl": [{
2802
- "rounded-bl": R()
2825
+ "rounded-bl": N()
2803
2826
  }],
2804
2827
  /**
2805
2828
  * Border Width
2806
2829
  * @see https://tailwindcss.com/docs/border-width
2807
2830
  */
2808
2831
  "border-w": [{
2809
- border: B()
2832
+ border: W()
2810
2833
  }],
2811
2834
  /**
2812
2835
  * Border Width X
2813
2836
  * @see https://tailwindcss.com/docs/border-width
2814
2837
  */
2815
2838
  "border-w-x": [{
2816
- "border-x": B()
2839
+ "border-x": W()
2817
2840
  }],
2818
2841
  /**
2819
2842
  * Border Width Y
2820
2843
  * @see https://tailwindcss.com/docs/border-width
2821
2844
  */
2822
2845
  "border-w-y": [{
2823
- "border-y": B()
2846
+ "border-y": W()
2824
2847
  }],
2825
2848
  /**
2826
2849
  * Border Width Start
2827
2850
  * @see https://tailwindcss.com/docs/border-width
2828
2851
  */
2829
2852
  "border-w-s": [{
2830
- "border-s": B()
2853
+ "border-s": W()
2831
2854
  }],
2832
2855
  /**
2833
2856
  * Border Width End
2834
2857
  * @see https://tailwindcss.com/docs/border-width
2835
2858
  */
2836
2859
  "border-w-e": [{
2837
- "border-e": B()
2860
+ "border-e": W()
2838
2861
  }],
2839
2862
  /**
2840
2863
  * Border Width Top
2841
2864
  * @see https://tailwindcss.com/docs/border-width
2842
2865
  */
2843
2866
  "border-w-t": [{
2844
- "border-t": B()
2867
+ "border-t": W()
2845
2868
  }],
2846
2869
  /**
2847
2870
  * Border Width Right
2848
2871
  * @see https://tailwindcss.com/docs/border-width
2849
2872
  */
2850
2873
  "border-w-r": [{
2851
- "border-r": B()
2874
+ "border-r": W()
2852
2875
  }],
2853
2876
  /**
2854
2877
  * Border Width Bottom
2855
2878
  * @see https://tailwindcss.com/docs/border-width
2856
2879
  */
2857
2880
  "border-w-b": [{
2858
- "border-b": B()
2881
+ "border-b": W()
2859
2882
  }],
2860
2883
  /**
2861
2884
  * Border Width Left
2862
2885
  * @see https://tailwindcss.com/docs/border-width
2863
2886
  */
2864
2887
  "border-w-l": [{
2865
- "border-l": B()
2888
+ "border-l": W()
2866
2889
  }],
2867
2890
  /**
2868
2891
  * Divide Width X
2869
2892
  * @see https://tailwindcss.com/docs/border-width#between-children
2870
2893
  */
2871
2894
  "divide-x": [{
2872
- "divide-x": B()
2895
+ "divide-x": W()
2873
2896
  }],
2874
2897
  /**
2875
2898
  * Divide Width X Reverse
@@ -2881,7 +2904,7 @@ const Nr = (r, e) => {
2881
2904
  * @see https://tailwindcss.com/docs/border-width#between-children
2882
2905
  */
2883
2906
  "divide-y": [{
2884
- "divide-y": B()
2907
+ "divide-y": W()
2885
2908
  }],
2886
2909
  /**
2887
2910
  * Divide Width Y Reverse
@@ -3043,7 +3066,7 @@ const Nr = (r, e) => {
3043
3066
  * @see https://tailwindcss.com/docs/box-shadow#adding-a-ring
3044
3067
  */
3045
3068
  "ring-w": [{
3046
- ring: B()
3069
+ ring: W()
3047
3070
  }],
3048
3071
  /**
3049
3072
  * Ring Width Inset
@@ -3082,7 +3105,7 @@ const Nr = (r, e) => {
3082
3105
  * @see https://tailwindcss.com/docs/box-shadow#adding-an-inset-ring
3083
3106
  */
3084
3107
  "inset-ring-w": [{
3085
- "inset-ring": B()
3108
+ "inset-ring": W()
3086
3109
  }],
3087
3110
  /**
3088
3111
  * Inset Ring Color
@@ -3096,7 +3119,7 @@ const Nr = (r, e) => {
3096
3119
  * @see https://tailwindcss.com/docs/text-shadow
3097
3120
  */
3098
3121
  "text-shadow": [{
3099
- "text-shadow": ["none", N, Se, ke]
3122
+ "text-shadow": ["none", R, Se, ke]
3100
3123
  }],
3101
3124
  /**
3102
3125
  * Text Shadow Color
@@ -3596,7 +3619,7 @@ const Nr = (r, e) => {
3596
3619
  * @see https://tailwindcss.com/docs/perspective
3597
3620
  */
3598
3621
  perspective: [{
3599
- perspective: [H, h, g]
3622
+ perspective: [B, h, g]
3600
3623
  }],
3601
3624
  /**
3602
3625
  * Perspective Origin
@@ -4100,7 +4123,7 @@ const Te = "
4100
4123
  triggerLabel: e,
4101
4124
  container: t
4102
4125
  }) => {
4103
- const [o, i] = I(!1), [l, a] = I(!1), [b, d] = I(!1), [m, f] = I(!1), [A, N] = I([]), [z, D] = I(""), [H, P] = I(!1), [G, K] = I(!1), [Q, M] = I(null), [, L] = I("user"), [_, q] = I("bottom-right"), [y, W] = I({
4126
+ const [o, a] = I(!1), [l, i] = I(!1), [b, d] = I(!1), [m, f] = I(!1), [A, R] = I([]), [z, j] = I(""), [B, P] = I(!1), [G, K] = I(!1), [Q, M] = I(null), [, L] = I("user"), [_, q] = I("bottom-right"), [y, D] = I({
4104
4127
  isActive: !1,
4105
4128
  toolName: null,
4106
4129
  toolData: null
@@ -4112,10 +4135,10 @@ const Te = "
4112
4135
  lastError: null,
4113
4136
  isPreloaded: !1,
4114
4137
  isRefreshing: !1
4115
- }), [Y, re] = I("idle"), [, J] = I(!1), w = me(null), p = me(null), V = j((u) => {
4138
+ }), [Y, re] = I("idle"), [, J] = I(!1), w = me(null), p = me(null), H = V((u) => {
4116
4139
  const { newStatus: k } = u.data;
4117
4140
  re(k), k === "preloading" || k === "connecting" ? o && f(!0) : k === "ready" ? (f(!1), d(!0)) : k === "error" && f(!1);
4118
- }, [o]), v = j((u) => {
4141
+ }, [o]), v = V((u) => {
4119
4142
  const k = u.data;
4120
4143
  if (console.log("[AriaStandaloneUI] Session ready event:", k), w.current) {
4121
4144
  const F = w.current.getSessionState();
@@ -4123,43 +4146,43 @@ const Te = "
4123
4146
  const ne = k?.lazyInit === !0;
4124
4147
  k?.streamReady === !0 ? (p.current && (console.log("[AriaStandaloneUI] Attaching video stream after full session ready (streamReady=true)"), w.current.attachToVideoElement(p.current)), d(!0), f(!1), M(null)) : ne ? console.log("[AriaStandaloneUI] Token ready (lazy init), button enabled") : (p.current && (console.log("[AriaStandaloneUI] Attaching video stream (legacy event)"), w.current.attachToVideoElement(p.current)), d(!0), f(!1), M(null));
4125
4148
  }
4126
- }, []), le = j((u) => {
4149
+ }, []), le = V((u) => {
4127
4150
  const k = u.error?.message || "Session error";
4128
4151
  if (console.error("[AriaStandaloneUI] Session error:", k), M(k), f(!1), w.current) {
4129
4152
  const F = w.current.getSessionState();
4130
4153
  O(F);
4131
4154
  }
4132
- }, []), ce = j((u) => {
4155
+ }, []), ce = V((u) => {
4133
4156
  const { connected: k } = u.data;
4134
4157
  if (d(k), !k && w.current) {
4135
4158
  const F = w.current.getSessionState();
4136
4159
  O(F);
4137
4160
  }
4138
- }, []), de = j((u) => {
4161
+ }, []), de = V((u) => {
4139
4162
  const { messages: k } = u.data;
4140
- k && N(k);
4141
- }, []), oe = j((u) => {
4163
+ k && R(k);
4164
+ }, []), oe = V((u) => {
4142
4165
  const { liveTranscript: k } = u.data;
4143
- k !== void 0 && D(k);
4144
- }, []), R = j((u) => {
4166
+ k !== void 0 && j(k);
4167
+ }, []), N = V((u) => {
4145
4168
  const k = u.data;
4146
- W({
4169
+ D({
4147
4170
  isActive: k.isActive,
4148
4171
  toolName: k.toolName,
4149
4172
  toolData: k.toolData
4150
4173
  });
4151
- }, []), B = j((u) => {
4174
+ }, []), W = V((u) => {
4152
4175
  const k = p.current;
4153
4176
  p.current = u, u && w.current ? w.current.getVideoStream() !== null ? (console.log("[AriaStandaloneUI] Attaching video stream to element"), w.current.attachToVideoElement(u)) : console.log("[AriaStandaloneUI] Video element registered, waiting for stream to be ready") : !u && k && w.current && (console.log("[AriaStandaloneUI] Detaching video stream from element"), w.current.detachFromVideoElement(k));
4154
- }, []), X = j((u = "user") => {
4155
- if (L(u), q(u === "websocket" ? "center" : "bottom-right"), i(!0), a(!1), M(null), !w.current) return;
4177
+ }, []), X = V((u = "user") => {
4178
+ if (L(u), q(u === "websocket" ? "center" : "bottom-right"), a(!0), i(!1), M(null), !w.current) return;
4156
4179
  const k = w.current.isSessionPaused();
4157
4180
  if (console.log("[AriaStandaloneUI] openAssistant called, isPaused:", k), k) {
4158
4181
  f(!0), w.current.resumeSession().then((Z) => {
4159
4182
  if (J(!1), Z) {
4160
4183
  f(!1), d(!0);
4161
4184
  const Pe = w.current.getSessionState();
4162
- O(Pe), N(w.current.getChatMessages()), p.current && w.current && (console.log("[AriaStandaloneUI] Attaching video stream after resume"), w.current.attachToVideoElement(p.current));
4185
+ O(Pe), R(w.current.getChatMessages()), p.current && w.current && (console.log("[AriaStandaloneUI] Attaching video stream after resume"), w.current.attachToVideoElement(p.current));
4163
4186
  } else
4164
4187
  w.current.hasSessionToken() ? w.current.initializeSessionOnDemand().then(() => {
4165
4188
  f(!1), d(!0);
@@ -4181,13 +4204,13 @@ const Te = "
4181
4204
  }).catch((Z) => {
4182
4205
  f(!1), M(Z instanceof Error ? Z.message : "Failed to initialize session");
4183
4206
  })) : (console.warn("[AriaStandaloneUI] No token available, button should have been disabled"), M("Session not ready. Please wait and try again."));
4184
- }, []), ae = j(() => {
4185
- a(!0);
4186
- }, []), C = j(() => {
4187
- a(!1);
4188
- }, []), ge = j(() => {
4189
- i(!1), a(!1), w.current && (p.current && w.current.detachFromVideoElement(p.current), D(""), console.log("[AriaStandaloneUI] Pausing session (widget closed)"), w.current.pauseSession(), J(!0));
4190
- }, []), ie = j(() => {
4207
+ }, []), ae = V(() => {
4208
+ i(!0);
4209
+ }, []), C = V(() => {
4210
+ i(!1);
4211
+ }, []), ge = V(() => {
4212
+ a(!1), i(!1), w.current && (p.current && w.current.detachFromVideoElement(p.current), j(""), console.log("[AriaStandaloneUI] Pausing session (widget closed)"), w.current.pauseSession(), J(!0));
4213
+ }, []), ie = V(() => {
4191
4214
  console.log("[AriaStandaloneUI] WebSocket trigger event"), X("websocket");
4192
4215
  }, [X]);
4193
4216
  ee(() => {
@@ -4196,21 +4219,21 @@ const Te = "
4196
4219
  return;
4197
4220
  }
4198
4221
  const u = U.getInstance({});
4199
- return w.current = u, u.addEventListener("status_change", V), u.addEventListener("session_ready", v), u.addEventListener("session_error", le), u.addEventListener("connection_change", ce), u.addEventListener("message_history", de), u.addEventListener("message_stream", oe), u.addEventListener("tool_call", R), u.setWebSocketTriggerCallback(ie), queueMicrotask(() => {
4200
- O(u.getSessionState()), re(u.getStatus()), d(u.isConnected()), N(u.getChatMessages()), D(u.getLiveTranscript()), K(u.isMuted()), J(u.isSessionPaused());
4222
+ return w.current = u, u.addEventListener("status_change", H), u.addEventListener("session_ready", v), u.addEventListener("session_error", le), u.addEventListener("connection_change", ce), u.addEventListener("message_history", de), u.addEventListener("message_stream", oe), u.addEventListener("tool_call", N), u.setWebSocketTriggerCallback(ie), queueMicrotask(() => {
4223
+ O(u.getSessionState()), re(u.getStatus()), d(u.isConnected()), R(u.getChatMessages()), j(u.getLiveTranscript()), K(u.isMuted()), J(u.isSessionPaused());
4201
4224
  const F = u.getToolCallState();
4202
- W(F);
4225
+ D(F);
4203
4226
  }), () => {
4204
- u.removeEventListener("status_change", V), u.removeEventListener("session_ready", v), u.removeEventListener("session_error", le), u.removeEventListener("connection_change", ce), u.removeEventListener("message_history", de), u.removeEventListener("message_stream", oe), u.removeEventListener("tool_call", R), u.setWebSocketTriggerCallback(null);
4227
+ u.removeEventListener("status_change", H), u.removeEventListener("session_ready", v), u.removeEventListener("session_error", le), u.removeEventListener("connection_change", ce), u.removeEventListener("message_history", de), u.removeEventListener("message_stream", oe), u.removeEventListener("tool_call", N), u.setWebSocketTriggerCallback(null);
4205
4228
  };
4206
4229
  }, [
4207
- V,
4230
+ H,
4208
4231
  v,
4209
4232
  le,
4210
4233
  ce,
4211
4234
  de,
4212
4235
  oe,
4213
- R,
4236
+ N,
4214
4237
  ie
4215
4238
  ]), ee(() => {
4216
4239
  const u = (ve) => {
@@ -4228,22 +4251,22 @@ const Te = "
4228
4251
  }, [X, ge, ae, C]), ee(() => {
4229
4252
  t.setAttribute("data-aria-open", String(o));
4230
4253
  }, [o, t]);
4231
- const he = j(() => {
4254
+ const he = V(() => {
4232
4255
  P((u) => !u);
4233
- }, []), be = j(async (u) => {
4256
+ }, []), be = V(async (u) => {
4234
4257
  if (!w.current || !b)
4235
4258
  throw new Error("Not connected to Aria");
4236
4259
  await w.current.sendMessage(u);
4237
- }, [b]), ue = j(() => {
4260
+ }, [b]), ue = V(() => {
4238
4261
  if (!w.current) return;
4239
4262
  const u = w.current.toggleMute();
4240
4263
  K(u);
4241
- }, []), cr = j(() => {
4264
+ }, []), cr = V(() => {
4242
4265
  w.current && (f(!0), M(null), w.current.refreshSession().catch((u) => {
4243
4266
  M(u instanceof Error ? u.message : "Failed to refresh session"), f(!1);
4244
4267
  }));
4245
4268
  }, []);
4246
- return /* @__PURE__ */ E(Ve, { children: [
4269
+ return /* @__PURE__ */ E(He, { children: [
4247
4270
  !o && /* @__PURE__ */ n(
4248
4271
  wt,
4249
4272
  {
@@ -4254,7 +4277,7 @@ const Te = "
4254
4277
  onClick: () => X("user")
4255
4278
  }
4256
4279
  ),
4257
- o && /* @__PURE__ */ E(Ve, { children: [
4280
+ o && /* @__PURE__ */ E(He, { children: [
4258
4281
  !l && /* @__PURE__ */ n(
4259
4282
  "div",
4260
4283
  {
@@ -4296,12 +4319,12 @@ const Te = "
4296
4319
  isLoading: m,
4297
4320
  chatMessages: A,
4298
4321
  liveTranscript: z,
4299
- isChatVisible: H,
4322
+ isChatVisible: B,
4300
4323
  isMuted: G,
4301
4324
  error: Q,
4302
4325
  toolCallState: y,
4303
4326
  sessionState: s,
4304
- setVideoElement: B,
4327
+ setVideoElement: W,
4305
4328
  toggleChat: he,
4306
4329
  sendMessage: be,
4307
4330
  toggleMute: ue,
@@ -4317,9 +4340,9 @@ const Te = "
4317
4340
  label: e,
4318
4341
  theme: t,
4319
4342
  isReady: o = !1,
4320
- onClick: i
4343
+ onClick: a
4321
4344
  }) => {
4322
- const l = t === "dark", a = e || "Talk to Aria";
4345
+ const l = t === "dark", i = e || "Talk to Aria";
4323
4346
  return /* @__PURE__ */ n(
4324
4347
  Ke,
4325
4348
  {
@@ -4334,7 +4357,7 @@ const Te = "
4334
4357
  "button",
4335
4358
  {
4336
4359
  onClick: (b) => {
4337
- b.preventDefault(), o && i();
4360
+ b.preventDefault(), o && a();
4338
4361
  },
4339
4362
  disabled: !o,
4340
4363
  className: c(
@@ -4367,7 +4390,7 @@ const Te = "
4367
4390
  "img",
4368
4391
  {
4369
4392
  src: Te,
4370
- alt: a,
4393
+ alt: i,
4371
4394
  className: "w-full h-full object-cover",
4372
4395
  onError: (b) => {
4373
4396
  b.currentTarget.style.display = "none";
@@ -4380,7 +4403,7 @@ const Te = "
4380
4403
  "div",
4381
4404
  {
4382
4405
  className: "hidden w-full h-full items-center justify-center aria-gradient-bg text-white",
4383
- children: /* @__PURE__ */ n(Ne, { className: "w-4 h-4" })
4406
+ children: /* @__PURE__ */ n(Re, { className: "w-4 h-4" })
4384
4407
  }
4385
4408
  ),
4386
4409
  /* @__PURE__ */ n("span", { className: c(
@@ -4394,12 +4417,12 @@ const Te = "
4394
4417
  "transition-transform duration-200",
4395
4418
  o && "group-hover:scale-105",
4396
4419
  !o && "grayscale"
4397
- ), children: /* @__PURE__ */ n(Ne, { className: "w-4 h-4" }) }),
4420
+ ), children: /* @__PURE__ */ n(Re, { className: "w-4 h-4" }) }),
4398
4421
  /* @__PURE__ */ E("div", { className: "relative flex flex-col items-start min-w-0 text-left", children: [
4399
4422
  /* @__PURE__ */ n("span", { className: c(
4400
4423
  "font-bold text-[13px] tracking-tight leading-none",
4401
4424
  l ? "text-white" : "text-gray-900"
4402
- ), children: a }),
4425
+ ), children: i }),
4403
4426
  /* @__PURE__ */ n("span", { className: c(
4404
4427
  "text-[10px] font-medium mt-1 leading-none",
4405
4428
  l ? "text-gray-400" : "text-gray-500",
@@ -4416,38 +4439,38 @@ const Te = "
4416
4439
  isMinimized: e,
4417
4440
  onMinimize: t,
4418
4441
  onMaximize: o,
4419
- theme: i,
4442
+ theme: a,
4420
4443
  displayMode: l,
4421
- isConnected: a,
4444
+ isConnected: i,
4422
4445
  isLoading: b,
4423
4446
  chatMessages: d,
4424
4447
  liveTranscript: m,
4425
4448
  isChatVisible: f,
4426
4449
  isMuted: A,
4427
- error: N,
4450
+ error: R,
4428
4451
  toolCallState: z,
4429
- setVideoElement: D,
4430
- toggleChat: H,
4452
+ setVideoElement: j,
4453
+ toggleChat: B,
4431
4454
  sendMessage: P,
4432
4455
  toggleMute: G,
4433
4456
  refreshSession: K
4434
4457
  }) => {
4435
- const Q = me(null), M = me(null), [L, _] = I(""), [q, y] = I(!1), W = me(null), s = i === "dark", O = l === "bottom-right", Y = l === "center";
4458
+ const Q = me(null), M = me(null), [L, _] = I(""), [q, y] = I(!1), D = me(null), s = a === "dark", O = l === "bottom-right", Y = l === "center";
4436
4459
  ee(() => {
4437
4460
  M.current && (M.current.scrollTop = M.current.scrollHeight);
4438
- }, [m]), ee(() => (Q.current && (console.log("[AriaWidgetStandalone] Registering video element, minimized:", e), D(Q.current)), () => {
4439
- D(null);
4440
- }), [D, e]), ee(() => {
4441
- W.current?.scrollIntoView({ behavior: "smooth" });
4461
+ }, [m]), ee(() => (Q.current && (console.log("[AriaWidgetStandalone] Registering video element, minimized:", e), j(Q.current)), () => {
4462
+ j(null);
4463
+ }), [j, e]), ee(() => {
4464
+ D.current?.scrollIntoView({ behavior: "smooth" });
4442
4465
  }, [d]);
4443
4466
  const re = async () => {
4444
- if (!L.trim() || !a || q) return;
4467
+ if (!L.trim() || !i || q) return;
4445
4468
  const p = L.trim();
4446
4469
  _(""), y(!0);
4447
4470
  try {
4448
4471
  await P(p);
4449
- } catch (V) {
4450
- console.error("Failed to send message:", V), _(p);
4472
+ } catch (H) {
4473
+ console.error("Failed to send message:", H), _(p);
4451
4474
  } finally {
4452
4475
  y(!1);
4453
4476
  }
@@ -4487,7 +4510,7 @@ const Te = "
4487
4510
  className: "w-full h-full object-cover"
4488
4511
  }
4489
4512
  ),
4490
- z.isActive && a && /* @__PURE__ */ E(
4513
+ z.isActive && i && /* @__PURE__ */ E(
4491
4514
  "div",
4492
4515
  {
4493
4516
  className: c(
@@ -4501,7 +4524,7 @@ const Te = "
4501
4524
  /* @__PURE__ */ n("div", { className: c(
4502
4525
  "w-5 h-5 rounded-full flex items-center justify-center",
4503
4526
  s ? "bg-amber-800/50" : "bg-amber-100"
4504
- ), children: /* @__PURE__ */ n(je, { className: c(
4527
+ ), children: /* @__PURE__ */ n(Ve, { className: c(
4505
4528
  "w-3 h-3 animate-pulse",
4506
4529
  s ? "text-amber-400" : "text-amber-600"
4507
4530
  ) }) }),
@@ -4512,7 +4535,7 @@ const Te = "
4512
4535
  ]
4513
4536
  }
4514
4537
  ),
4515
- a && !N && /* @__PURE__ */ E(
4538
+ i && !R && /* @__PURE__ */ E(
4516
4539
  "div",
4517
4540
  {
4518
4541
  className: c(
@@ -4533,7 +4556,7 @@ const Te = "
4533
4556
  A ? "bg-red-500 hover:bg-red-600 text-white" : s ? "bg-gray-800/80 hover:bg-gray-700 text-gray-300" : "bg-gray-100/80 hover:bg-gray-200 text-gray-600"
4534
4557
  ),
4535
4558
  title: A ? "Unmute" : "Mute",
4536
- children: A ? /* @__PURE__ */ n(De, { className: "h-3.5 w-3.5" }) : /* @__PURE__ */ n(He, { className: "h-3.5 w-3.5" })
4559
+ children: A ? /* @__PURE__ */ n(je, { className: "h-3.5 w-3.5" }) : /* @__PURE__ */ n(Be, { className: "h-3.5 w-3.5" })
4537
4560
  }
4538
4561
  ),
4539
4562
  /* @__PURE__ */ n(
@@ -4555,7 +4578,7 @@ const Te = "
4555
4578
  onClick: r,
4556
4579
  className: "w-8 h-8 rounded-full bg-red-500 hover:bg-red-600 flex items-center justify-center transition-all duration-200 text-white border-0 outline-none focus:outline-none shadow-sm",
4557
4580
  title: "End Call",
4558
- children: /* @__PURE__ */ n(We, { className: "h-3.5 w-3.5 rotate-[135deg]" })
4581
+ children: /* @__PURE__ */ n(De, { className: "h-3.5 w-3.5 rotate-[135deg]" })
4559
4582
  }
4560
4583
  )
4561
4584
  ]
@@ -4593,7 +4616,7 @@ const Te = "
4593
4616
  s ? "text-gray-400" : "text-gray-600"
4594
4617
  ), children: "Connecting..." })
4595
4618
  ] }),
4596
- N && /* @__PURE__ */ E("div", { className: c(
4619
+ R && /* @__PURE__ */ E("div", { className: c(
4597
4620
  "absolute inset-0 flex flex-col items-center justify-center z-10 p-4",
4598
4621
  s ? "bg-gray-950/90" : "bg-white/90"
4599
4622
  ), children: [
@@ -4612,7 +4635,7 @@ const Te = "
4612
4635
  s ? "bg-indigo-600 hover:bg-indigo-700 text-white" : "bg-indigo-500 hover:bg-indigo-600 text-white"
4613
4636
  ),
4614
4637
  children: [
4615
- /* @__PURE__ */ n(Be, { className: "w-3 h-3" }),
4638
+ /* @__PURE__ */ n(We, { className: "w-3 h-3" }),
4616
4639
  "Retry"
4617
4640
  ]
4618
4641
  }
@@ -4715,7 +4738,7 @@ const Te = "
4715
4738
  ), children: "Get ready to chat" })
4716
4739
  ] })
4717
4740
  ] }),
4718
- N && /* @__PURE__ */ n(
4741
+ R && /* @__PURE__ */ n(
4719
4742
  "div",
4720
4743
  {
4721
4744
  className: c(
@@ -4736,7 +4759,7 @@ const Te = "
4736
4759
  /* @__PURE__ */ n("p", { className: c(
4737
4760
  "text-sm leading-relaxed mb-4",
4738
4761
  s ? "text-red-400" : "text-red-600"
4739
- ), children: N }),
4762
+ ), children: R }),
4740
4763
  /* @__PURE__ */ E(
4741
4764
  "button",
4742
4765
  {
@@ -4747,7 +4770,7 @@ const Te = "
4747
4770
  s ? "bg-indigo-600 hover:bg-indigo-700 text-white" : "bg-indigo-500 hover:bg-indigo-600 text-white"
4748
4771
  ),
4749
4772
  children: [
4750
- /* @__PURE__ */ n(Be, { className: "w-4 h-4" }),
4773
+ /* @__PURE__ */ n(We, { className: "w-4 h-4" }),
4751
4774
  "Try Again"
4752
4775
  ]
4753
4776
  }
@@ -4765,7 +4788,7 @@ const Te = "
4765
4788
  className: "w-full h-full object-contain"
4766
4789
  }
4767
4790
  ),
4768
- z.isActive && a && /* @__PURE__ */ E(
4791
+ z.isActive && i && /* @__PURE__ */ E(
4769
4792
  "div",
4770
4793
  {
4771
4794
  className: c(
@@ -4779,7 +4802,7 @@ const Te = "
4779
4802
  /* @__PURE__ */ n("div", { className: c(
4780
4803
  "w-6 h-6 rounded-full flex items-center justify-center",
4781
4804
  s ? "bg-amber-800/50" : "bg-amber-100"
4782
- ), children: /* @__PURE__ */ n(je, { className: c(
4805
+ ), children: /* @__PURE__ */ n(Ve, { className: c(
4783
4806
  "w-3.5 h-3.5 animate-pulse",
4784
4807
  s ? "text-amber-400" : "text-amber-600"
4785
4808
  ) }) }),
@@ -4810,7 +4833,7 @@ const Te = "
4810
4833
  ]
4811
4834
  }
4812
4835
  ),
4813
- m && a && !z.isActive && /* @__PURE__ */ n(
4836
+ m && i && !z.isActive && /* @__PURE__ */ n(
4814
4837
  "div",
4815
4838
  {
4816
4839
  className: c(
@@ -4825,7 +4848,7 @@ const Te = "
4825
4848
  ] })
4826
4849
  }
4827
4850
  ),
4828
- a && !N && /* @__PURE__ */ E(
4851
+ i && !R && /* @__PURE__ */ E(
4829
4852
  "div",
4830
4853
  {
4831
4854
  className: c(
@@ -4839,7 +4862,7 @@ const Te = "
4839
4862
  /* @__PURE__ */ n(
4840
4863
  "button",
4841
4864
  {
4842
- onClick: H,
4865
+ onClick: B,
4843
4866
  className: c(
4844
4867
  "w-9 h-9 rounded-full flex items-center justify-center transition-all duration-200",
4845
4868
  "border-0 outline-none focus:outline-none shadow-sm",
@@ -4859,7 +4882,7 @@ const Te = "
4859
4882
  A ? "bg-red-500 hover:bg-red-600 text-white" : s ? "bg-gray-800/80 hover:bg-gray-700 text-gray-300" : "bg-gray-100/80 hover:bg-gray-200 text-gray-600"
4860
4883
  ),
4861
4884
  title: A ? "Unmute" : "Mute",
4862
- children: A ? /* @__PURE__ */ n(De, { className: "h-4 w-4" }) : /* @__PURE__ */ n(He, { className: "h-4 w-4" })
4885
+ children: A ? /* @__PURE__ */ n(je, { className: "h-4 w-4" }) : /* @__PURE__ */ n(Be, { className: "h-4 w-4" })
4863
4886
  }
4864
4887
  ),
4865
4888
  /* @__PURE__ */ n(
@@ -4881,7 +4904,7 @@ const Te = "
4881
4904
  onClick: r,
4882
4905
  className: "w-10 h-9 rounded-full bg-red-500 hover:bg-red-600 flex items-center justify-center transition-all duration-200 text-white border-0 outline-none focus:outline-none shadow-sm",
4883
4906
  title: "End Call",
4884
- children: /* @__PURE__ */ n(We, { className: "h-4 w-4 rotate-[135deg]" })
4907
+ children: /* @__PURE__ */ n(De, { className: "h-4 w-4 rotate-[135deg]" })
4885
4908
  }
4886
4909
  )
4887
4910
  ]
@@ -4917,7 +4940,7 @@ const Te = "
4917
4940
  /* @__PURE__ */ n("div", { className: c(
4918
4941
  "rounded-2xl p-6 mb-4",
4919
4942
  s ? "bg-gradient-to-br from-indigo-900/20 to-purple-900/20" : "bg-gradient-to-br from-indigo-50 to-purple-50"
4920
- ), children: /* @__PURE__ */ n(Ne, { className: c(
4943
+ ), children: /* @__PURE__ */ n(Re, { className: c(
4921
4944
  "h-8 w-8",
4922
4945
  s ? "text-indigo-400" : "text-indigo-500"
4923
4946
  ) }) }),
@@ -4929,14 +4952,14 @@ const Te = "
4929
4952
  "text-xs",
4930
4953
  s ? "text-gray-400" : "text-gray-500"
4931
4954
  ), children: "Aria is here to chat with you" })
4932
- ] }) : d.filter((p) => p.content && p.content.trim() !== "").map((p, V) => /* @__PURE__ */ E(
4955
+ ] }) : d.filter((p) => p.content && p.content.trim() !== "").map((p, H) => /* @__PURE__ */ E(
4933
4956
  "div",
4934
4957
  {
4935
4958
  className: c(
4936
4959
  "flex gap-2 aria-animate-fade-in",
4937
4960
  p.role === "user" ? "flex-row-reverse" : "flex-row"
4938
4961
  ),
4939
- style: { animationDelay: `${V * 50}ms` },
4962
+ style: { animationDelay: `${H * 50}ms` },
4940
4963
  children: [
4941
4964
  /* @__PURE__ */ n(
4942
4965
  "div",
@@ -4978,9 +5001,9 @@ const Te = "
4978
5001
  )
4979
5002
  ]
4980
5003
  },
4981
- V
5004
+ H
4982
5005
  )),
4983
- /* @__PURE__ */ n("div", { ref: W })
5006
+ /* @__PURE__ */ n("div", { ref: D })
4984
5007
  ] }),
4985
5008
  /* @__PURE__ */ n("div", { className: c(
4986
5009
  "p-3 border-t",
@@ -4995,8 +5018,8 @@ const Te = "
4995
5018
  value: L,
4996
5019
  onChange: (p) => _(p.target.value),
4997
5020
  onKeyDown: J,
4998
- placeholder: a ? "Message Aria..." : "Connecting...",
4999
- disabled: !a || q,
5021
+ placeholder: i ? "Message Aria..." : "Connecting...",
5022
+ disabled: !i || q,
5000
5023
  className: c(
5001
5024
  "flex-1 border-0 bg-transparent shadow-none focus:outline-none px-2 h-8 text-xs",
5002
5025
  s ? "placeholder:text-gray-500 text-white" : "placeholder:text-gray-400 text-gray-900"
@@ -5007,7 +5030,7 @@ const Te = "
5007
5030
  "button",
5008
5031
  {
5009
5032
  onClick: re,
5010
- disabled: !a || !L.trim() || q,
5033
+ disabled: !i || !L.trim() || q,
5011
5034
  className: c(
5012
5035
  "h-7 w-7 rounded-md shrink-0 transition-all duration-200 flex items-center justify-center",
5013
5036
  "bg-indigo-500 hover:bg-indigo-600 disabled:opacity-40 text-white"