deep-chat-dev 9.0.190 → 9.0.191

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/deepChat.js CHANGED
@@ -387,7 +387,7 @@ const dt = class dt {
387
387
  }
388
388
  };
389
389
  dt.BUBBLE_CLASS = "deep-chat-loading-message-bubble", dt.DOTS_CONTAINER_CLASS = "deep-chat-loading-message-dots-container";
390
- let Te = dt;
390
+ let ke = dt;
391
391
  const Sn = "data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='iso-8859-1'?%3e%3csvg%20fill='%23000000'%20version='1.1'%20id='Layer_1'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%20viewBox='0%200%2032%2032'%20xml:space='preserve'%3e%3cpath%20d='M23,30.36H9c-2.404,0-4.36-1.956-4.36-4.36V15c0-2.404,1.956-4.36,4.36-4.36h3.659%20c0.167-1.566,1.415-2.813,2.981-2.981V5.333c-1.131-0.174-2-1.154-2-2.333c0-1.301,1.059-2.36,2.36-2.36%20c1.302,0,2.36,1.059,2.36,2.36c0,1.179-0.869,2.159-2,2.333V7.66c1.566,0.167,2.814,1.415,2.981,2.981H23%20c2.404,0,4.36,1.956,4.36,4.36v11C27.36,28.404,25.404,30.36,23,30.36z%20M9,11.36c-2.007,0-3.64,1.633-3.64,3.64v11%20c0,2.007,1.633,3.64,3.64,3.64h14c2.007,0,3.64-1.633,3.64-3.64V15c0-2.007-1.633-3.64-3.64-3.64H9z%20M13.384,10.64h5.231%20C18.439,9.354,17.334,8.36,16,8.36C14.667,8.36,13.561,9.354,13.384,10.64z%20M16,1.36c-0.904,0-1.64,0.736-1.64,1.64%20S15.096,4.64,16,4.64c0.904,0,1.64-0.736,1.64-1.64S16.904,1.36,16,1.36z%20M20,27.36h-8c-1.301,0-2.36-1.059-2.36-2.36%20s1.059-2.36,2.36-2.36h8c1.302,0,2.36,1.059,2.36,2.36S21.302,27.36,20,27.36z%20M12,23.36c-0.904,0-1.64,0.735-1.64,1.64%20s0.736,1.64,1.64,1.64h8c0.904,0,1.64-0.735,1.64-1.64s-0.735-1.64-1.64-1.64H12z%20M31,23.86h-2c-0.199,0-0.36-0.161-0.36-0.36V15%20c0-0.199,0.161-0.36,0.36-0.36h2c0.199,0,0.36,0.161,0.36,0.36v8.5C31.36,23.699,31.199,23.86,31,23.86z%20M29.36,23.14h1.279v-7.78%20H29.36V23.14z%20M3,23.86H1c-0.199,0-0.36-0.161-0.36-0.36V15c0-0.199,0.161-0.36,0.36-0.36h2c0.199,0,0.36,0.161,0.36,0.36v8.5%20C3.36,23.699,3.199,23.86,3,23.86z%20M1.36,23.14h1.28v-7.78H1.36V23.14z%20M20,20.36c-1.302,0-2.36-1.059-2.36-2.36%20s1.059-2.36,2.36-2.36s2.36,1.059,2.36,2.36C22.36,19.302,21.302,20.36,20,20.36z%20M20,16.36c-0.904,0-1.64,0.736-1.64,1.64%20s0.735,1.64,1.64,1.64s1.64-0.735,1.64-1.64S20.904,16.36,20,16.36z%20M12,20.36c-1.301,0-2.36-1.059-2.36-2.36s1.059-2.36,2.36-2.36%20s2.36,1.059,2.36,2.36C14.36,19.302,13.301,20.36,12,20.36z%20M12,16.36c-0.904,0-1.64,0.736-1.64,1.64s0.736,1.64,1.64,1.64%20s1.64-0.735,1.64-1.64S12.904,16.36,12,16.36z'/%3e%3crect%20style='fill:none;'%20width='32'%20height='32'/%3e%3c/svg%3e", wn = "", Y = class Y {
392
392
  static hide(e) {
393
393
  var t;
@@ -491,7 +491,7 @@ const ce = class ce {
491
491
  const a = ce.getLastElementsByClass(
492
492
  t,
493
493
  [ce.getRoleClass(s), o],
494
- [Te.BUBBLE_CLASS]
494
+ [ke.BUBBLE_CLASS]
495
495
  ), l = ce.getLastMessage(e, s, r);
496
496
  return l && (l[r] = i), a;
497
497
  }
@@ -566,7 +566,7 @@ const Cn = "deep-chat-temporary-message", Tn = "deep-chat-suggestion-button", Qi
566
566
  }
567
567
  }
568
568
  }, As = Object.keys(Qi);
569
- class Ae {
569
+ class Me {
570
570
  static applySuggestionEvent(e, t) {
571
571
  setTimeout(() => {
572
572
  t.addEventListener("click", () => {
@@ -605,12 +605,12 @@ class Ae {
605
605
  As.forEach((r) => {
606
606
  const o = i.getElementsByClassName(r);
607
607
  Array.from(o || []).forEach((a) => {
608
- const l = Ae.getProcessedStyles(t, a, r);
609
- te.applyStylesToElement(a, l), Ae.applyEvents(a, r);
608
+ const l = Me.getProcessedStyles(t, a, r);
609
+ te.applyStylesToElement(a, l), Me.applyEvents(a, r);
610
610
  });
611
611
  });
612
612
  const s = i.getElementsByClassName(Tn);
613
- Array.from(s).forEach((r) => Ae.applySuggestionEvent(e, r));
613
+ Array.from(s).forEach((r) => Me.applySuggestionEvent(e, r));
614
614
  }
615
615
  }
616
616
  class te {
@@ -626,7 +626,7 @@ class te {
626
626
  }
627
627
  static applyClassUtilitiesToElement(e, t) {
628
628
  const { events: i, styles: s } = t;
629
- i && te.applyEventsToElement(e, i), s && !Ae.doesElementContainDeepChatClass(e) && te.applyStylesToElement(e, s);
629
+ i && te.applyEventsToElement(e, i), s && !Me.doesElementContainDeepChatClass(e) && te.applyStylesToElement(e, s);
630
630
  }
631
631
  static applyCustomClassUtilities(e, t) {
632
632
  Object.keys(e).forEach((i) => {
@@ -637,7 +637,7 @@ class te {
637
637
  });
638
638
  }
639
639
  static apply(e, t) {
640
- Ae.applyDeepChatUtilities(e, e.htmlClassUtilities, t), te.applyCustomClassUtilities(e.htmlClassUtilities, t);
640
+ Me.applyDeepChatUtilities(e, e.htmlClassUtilities, t), te.applyCustomClassUtilities(e.htmlClassUtilities, t);
641
641
  }
642
642
  static traverseNodes(e, t) {
643
643
  e.nodeType === Node.ELEMENT_NODE && t.push(e.outerHTML), e.childNodes.forEach((i) => {
@@ -651,7 +651,7 @@ class te {
651
651
  }), s;
652
652
  }
653
653
  }
654
- class Ne {
654
+ class De {
655
655
  static addElement(e, t) {
656
656
  e.elementRef.appendChild(t), e.elementRef.scrollTop = e.elementRef.scrollHeight;
657
657
  }
@@ -671,8 +671,8 @@ class Ne {
671
671
  if (c) return c;
672
672
  r.status = !1;
673
673
  }
674
- const a = Ne.createElements(e, t, i, o);
675
- return b.fillEmptyMessageElement(a.bubbleElement, t), te.apply(e, a.outerContainer), ae.flagHTMLUpdateClass(a.bubbleElement), e.applyCustomStyles(a, i, !1, (l = e.messageStyles) == null ? void 0 : l.html), o || Ne.addElement(e, a.outerContainer), a;
674
+ const a = De.createElements(e, t, i, o);
675
+ return b.fillEmptyMessageElement(a.bubbleElement, t), te.apply(e, a.outerContainer), ae.flagHTMLUpdateClass(a.bubbleElement), e.applyCustomStyles(a, i, !1, (l = e.messageStyles) == null ? void 0 : l.html), o || De.addElement(e, a.outerContainer), a;
676
676
  }
677
677
  }
678
678
  var Qt;
@@ -1538,7 +1538,7 @@ function sr(n, e) {
1538
1538
  n.tokens[t].level === s && n.tokens[t].type === "paragraph_open" && (n.tokens[t + 2].tight = !0, n.tokens[t].tight = !0, t += 2);
1539
1539
  }
1540
1540
  function nr(n, e, t, i) {
1541
- var s, r, o, a, l, c, d, h, u, f, m, p, y, x, j, V, Re, R, X = !0, Z, D, Fe, yt;
1541
+ var s, r, o, a, l, c, d, h, u, f, m, p, y, x, j, V, Le, R, X = !0, Z, D, Be, yt;
1542
1542
  if ((h = Ps(n, e)) >= 0)
1543
1543
  y = !0;
1544
1544
  else if ((h = Ls(n, e)) >= 0)
@@ -1552,11 +1552,11 @@ function nr(n, e, t, i) {
1552
1552
  for (j = n.tokens.length, y ? (d = n.bMarks[e] + n.tShift[e], m = Number(n.src.substr(d, h - d - 1)), n.tokens.push({
1553
1553
  type: "ordered_list_open",
1554
1554
  order: m,
1555
- lines: Re = [e, 0],
1555
+ lines: Le = [e, 0],
1556
1556
  level: n.level++
1557
1557
  })) : n.tokens.push({
1558
1558
  type: "bullet_list_open",
1559
- lines: Re = [e, 0],
1559
+ lines: Le = [e, 0],
1560
1560
  level: n.level++
1561
1561
  }), s = e, V = !1, Z = n.parser.ruler.getRules("list"); s < t && (x = n.skipSpaces(h), u = n.eMarks[s], x >= u ? f = 1 : f = x - h, f > 4 && (f = 1), f < 1 && (f = 1), r = h - n.bMarks[s] + f, n.tokens.push({
1562
1562
  type: "list_item_open",
@@ -1566,7 +1566,7 @@ function nr(n, e, t, i) {
1566
1566
  type: "list_item_close",
1567
1567
  level: --n.level
1568
1568
  }), s = e = n.line, R[1] = s, x = n.bMarks[e], !(s >= t || n.isEmpty(s) || n.tShift[s] < n.blkIndent)); ) {
1569
- for (yt = !1, D = 0, Fe = Z.length; D < Fe; D++)
1569
+ for (yt = !1, D = 0, Be = Z.length; D < Be; D++)
1570
1570
  if (Z[D](n, s, t, !0)) {
1571
1571
  yt = !0;
1572
1572
  break;
@@ -1584,7 +1584,7 @@ function nr(n, e, t, i) {
1584
1584
  return n.tokens.push({
1585
1585
  type: y ? "ordered_list_close" : "bullet_list_close",
1586
1586
  level: --n.level
1587
- }), Re[1] = s, n.line = s, X && sr(n, j), !0;
1587
+ }), Le[1] = s, n.line = s, X && sr(n, j), !0;
1588
1588
  }
1589
1589
  function rr(n, e, t, i) {
1590
1590
  var s, r, o, a, l, c = n.bMarks[e] + n.tShift[e], d = n.eMarks[e];
@@ -2685,7 +2685,7 @@ var no = {
2685
2685
  function fn(n, e, t) {
2686
2686
  this.src = e, this.env = t, this.options = n.options, this.tokens = [], this.inlineMode = !1, this.inline = n.inline, this.block = n.block, this.renderer = n.renderer, this.typographer = n.typographer;
2687
2687
  }
2688
- function ke(n, e) {
2688
+ function Re(n, e) {
2689
2689
  typeof n != "string" && (e = n, n = "default"), e && e.linkify != null && console.warn(
2690
2690
  `linkify option is removed. Use linkify plugin instead:
2691
2691
 
@@ -2695,10 +2695,10 @@ new Remarkable().use(linkify)
2695
2695
  `
2696
2696
  ), this.inline = new ki(), this.block = new gs(), this.core = new hn(), this.renderer = new ms(), this.ruler = new se(), this.options = {}, this.configure(ao[n]), this.set(e || {});
2697
2697
  }
2698
- ke.prototype.set = function(n) {
2698
+ Re.prototype.set = function(n) {
2699
2699
  rn(this.options, n);
2700
2700
  };
2701
- ke.prototype.configure = function(n) {
2701
+ Re.prototype.configure = function(n) {
2702
2702
  var e = this;
2703
2703
  if (!n)
2704
2704
  throw new Error("Wrong `remarkable` preset, check name/content");
@@ -2706,27 +2706,27 @@ ke.prototype.configure = function(n) {
2706
2706
  n.components[t].rules && e[t].ruler.enable(n.components[t].rules, !0);
2707
2707
  });
2708
2708
  };
2709
- ke.prototype.use = function(n, e) {
2709
+ Re.prototype.use = function(n, e) {
2710
2710
  return n(this, e), this;
2711
2711
  };
2712
- ke.prototype.parse = function(n, e) {
2712
+ Re.prototype.parse = function(n, e) {
2713
2713
  var t = new fn(this, n, e);
2714
2714
  return this.core.process(t), t.tokens;
2715
2715
  };
2716
- ke.prototype.render = function(n, e) {
2716
+ Re.prototype.render = function(n, e) {
2717
2717
  return e = e || {}, this.renderer.render(this.parse(n, e), this.options, e);
2718
2718
  };
2719
- ke.prototype.parseInline = function(n, e) {
2719
+ Re.prototype.parseInline = function(n, e) {
2720
2720
  var t = new fn(this, n, e);
2721
2721
  return t.inlineMode = !0, this.core.process(t), t.tokens;
2722
2722
  };
2723
- ke.prototype.renderInline = function(n, e) {
2723
+ Re.prototype.renderInline = function(n, e) {
2724
2724
  return e = e || {}, this.renderer.render(this.parseInline(n, e), this.options, e);
2725
2725
  };
2726
2726
  class Dt {
2727
2727
  static instantiate() {
2728
2728
  const e = window.hljs;
2729
- return e ? new ke({
2729
+ return e ? new Re({
2730
2730
  highlight: function(t, i) {
2731
2731
  if (i && e.getLanguage(i))
2732
2732
  try {
@@ -2753,7 +2753,7 @@ class Dt {
2753
2753
  // set target to open in a new tab
2754
2754
  typographer: !0
2755
2755
  // Enable smartypants and other sweet transforms
2756
- }) : new ke({
2756
+ }) : new Re({
2757
2757
  breaks: !0,
2758
2758
  linkTarget: "_blank"
2759
2759
  // set target to open in a new tab
@@ -2764,7 +2764,7 @@ class Dt {
2764
2764
  return e.inline.validateLink = () => !0, e;
2765
2765
  }
2766
2766
  }
2767
- const Ee = class Ee {
2767
+ const xe = class xe {
2768
2768
  // prettier-ignore
2769
2769
  static addMessage(e, t, i, s, r) {
2770
2770
  var o;
@@ -2772,13 +2772,13 @@ const Ee = class Ee {
2772
2772
  }
2773
2773
  static wrapInLink(e, t, i) {
2774
2774
  const s = document.createElement("a");
2775
- return s.href = t, s.download = i || Ee.DEFAULT_FILE_NAME, s.target = "_blank", s.appendChild(e), s;
2775
+ return s.href = t, s.download = i || xe.DEFAULT_FILE_NAME, s.target = "_blank", s.appendChild(e), s;
2776
2776
  }
2777
2777
  static isNonLinkableDataUrl(e, t) {
2778
2778
  return !t.startsWith("data") || e === "image" ? !1 : e === "any" && t.startsWith("data:text/javascript") || !t.startsWith("data:image") && !t.startsWith("data:application");
2779
2779
  }
2780
2780
  static processContent(e, t, i, s) {
2781
- return !i || Ee.isNonLinkableDataUrl(e, i) ? t : Ee.wrapInLink(t, i, s);
2781
+ return !i || xe.isNonLinkableDataUrl(e, i) ? t : xe.wrapInLink(t, i, s);
2782
2782
  }
2783
2783
  static waitToLoadThenScroll(e) {
2784
2784
  setTimeout(() => {
@@ -2787,12 +2787,12 @@ const Ee = class Ee {
2787
2787
  }
2788
2788
  static scrollDownOnImageLoad(e, t) {
2789
2789
  if (e.startsWith("data"))
2790
- Ee.waitToLoadThenScroll(t);
2790
+ xe.waitToLoadThenScroll(t);
2791
2791
  else
2792
2792
  try {
2793
2793
  fetch(e, { mode: "no-cors" }).catch(() => {
2794
2794
  }).finally(() => {
2795
- Ee.waitToLoadThenScroll(t);
2795
+ xe.waitToLoadThenScroll(t);
2796
2796
  });
2797
2797
  } catch {
2798
2798
  t.scrollTop = t.scrollHeight;
@@ -2819,14 +2819,14 @@ const Ee = class Ee {
2819
2819
  }
2820
2820
  static isImageFile(e) {
2821
2821
  const { type: t, src: i } = e;
2822
- return t === "image" || (i == null ? void 0 : i.startsWith("data:image")) || i && Ee.isImageFileExtension(i);
2822
+ return t === "image" || (i == null ? void 0 : i.startsWith("data:image")) || i && xe.isImageFileExtension(i);
2823
2823
  }
2824
2824
  static isImageFileExtension(e) {
2825
2825
  return /\.(jpg|jpeg|png|gif|bmp)$/i.test(e);
2826
2826
  }
2827
2827
  };
2828
- Ee.DEFAULT_FILE_NAME = "file";
2829
- let B = Ee;
2828
+ xe.DEFAULT_FILE_NAME = "file";
2829
+ let B = xe;
2830
2830
  class ai {
2831
2831
  static onMessage(e, t, i) {
2832
2832
  var r;
@@ -2852,7 +2852,7 @@ const F = class F {
2852
2852
  return e.classList.add("loading-history"), e.appendChild(document.createElement("div")), e.appendChild(document.createElement("div")), e.appendChild(document.createElement("div")), e.appendChild(document.createElement("div")), e;
2853
2853
  }
2854
2854
  static apply(e, t, i) {
2855
- Te.setRing(t.bubbleElement, i == null ? void 0 : i.bubble), i != null && i.bubble && (i = JSON.parse(JSON.stringify(i)), delete i.bubble), e.applyCustomStyles(t, "history", !1, i);
2855
+ ke.setRing(t.bubbleElement, i == null ? void 0 : i.bubble), i != null && i.bubble && (i = JSON.parse(JSON.stringify(i)), delete i.bubble), e.applyCustomStyles(t, "history", !1, i);
2856
2856
  }
2857
2857
  static addLoadHistoryMessage(e, t, i = !0) {
2858
2858
  var o, a, l, c, d, h, u, f;
@@ -2868,7 +2868,7 @@ const F = class F {
2868
2868
  }
2869
2869
  static addMessage(e, t = !0) {
2870
2870
  var r, o, a, l;
2871
- const i = (l = (a = (o = (r = e.messageStyles) == null ? void 0 : r.loading) == null ? void 0 : o.history) == null ? void 0 : a.full) == null ? void 0 : l.html, s = i ? Ne.createElements(e, i, b.AI_ROLE, !0) : F.createDefaultElements(e);
2871
+ const i = (l = (a = (o = (r = e.messageStyles) == null ? void 0 : r.loading) == null ? void 0 : o.history) == null ? void 0 : a.full) == null ? void 0 : l.html, s = i ? De.createElements(e, i, b.AI_ROLE, !0) : F.createDefaultElements(e);
2872
2872
  return F.addLoadHistoryMessage(s, e, t), s;
2873
2873
  }
2874
2874
  static changeFullViewToSmall(e, t) {
@@ -2917,9 +2917,9 @@ class q {
2917
2917
  }), s;
2918
2918
  }
2919
2919
  }
2920
- class Oe {
2920
+ class Ne {
2921
2921
  constructor(e) {
2922
- this.messageElementRefs = [], this.messages = [], this.htmlClassUtilities = {}, this.textElementsToText = [], this.elementRef = Oe.createContainerElement(), this.messageStyles = e.messageStyles, this._remarkable = Dt.createNew(), this._avatars = e.avatars, this._names = e.names, this._onMessage = ai.onMessage.bind(this, e), e.htmlClassUtilities && (this.htmlClassUtilities = e.htmlClassUtilities), setTimeout(() => {
2922
+ this.messageElementRefs = [], this.messages = [], this.htmlClassUtilities = {}, this.textElementsToText = [], this.elementRef = Ne.createContainerElement(), this.messageStyles = e.messageStyles, this._remarkable = Dt.createNew(), this._avatars = e.avatars, this._names = e.names, this._onMessage = ai.onMessage.bind(this, e), e.htmlClassUtilities && (this.htmlClassUtilities = e.htmlClassUtilities), setTimeout(() => {
2923
2923
  this.submitUserMessage = e.submitUserMessage;
2924
2924
  });
2925
2925
  }
@@ -2969,22 +2969,22 @@ class Oe {
2969
2969
  var r;
2970
2970
  (r = this._introPanel) == null || r.hide();
2971
2971
  const s = this.messageElementRefs[this.messageElementRefs.length - 1];
2972
- return Xe.changeFullViewToSmall(this, s), Oe.isTemporaryElement(s) && (this.revealRoleElementsIfTempRemoved(s, t), s.outerContainer.remove(), this.messageElementRefs.pop()), this.createMessageElements(e, t, i);
2972
+ return Xe.changeFullViewToSmall(this, s), Ne.isTemporaryElement(s) && (this.revealRoleElementsIfTempRemoved(s, t), s.outerContainer.remove(), this.messageElementRefs.pop()), this.createMessageElements(e, t, i);
2973
2973
  }
2974
2974
  // this can be tested by having an ai message, then a temp ai message with html that submits new user message:
2975
2975
  // https://github.com/OvidijusParsiunas/deep-chat/issues/258
2976
2976
  // prettier-ignore
2977
2977
  revealRoleElementsIfTempRemoved(e, t) {
2978
- if ((this._avatars || this._names) && Ae.isElementTemporary(e)) {
2978
+ if ((this._avatars || this._names) && Me.isElementTemporary(e)) {
2979
2979
  const i = this.messageElementRefs[this.messageElementRefs.length - 2];
2980
2980
  i && this.messages[this.messages.length - 1] && !e.bubbleElement.classList.contains(b.getRoleClass(t)) && b.revealRoleElements(i.innerContainer, this._avatars, this._names);
2981
2981
  }
2982
2982
  }
2983
2983
  static isTemporaryElement(e) {
2984
- return Oe.isLoadingMessage(e) || Ae.isElementTemporary(e);
2984
+ return Ne.isLoadingMessage(e) || Me.isElementTemporary(e);
2985
2985
  }
2986
2986
  createMessageElements(e, t, i = !1) {
2987
- const s = Oe.createBaseElements(), { outerContainer: r, innerContainer: o, bubbleElement: a } = s;
2987
+ const s = Ne.createBaseElements(), { outerContainer: r, innerContainer: o, bubbleElement: a } = s;
2988
2988
  return r.appendChild(o), this.addInnerContainerElements(a, e, t), b.updateRefArr(this.messageElementRefs, s, i), s;
2989
2989
  }
2990
2990
  static createBaseElements() {
@@ -3023,7 +3023,7 @@ class Oe {
3023
3023
  return (e = b.getLastMessageBubbleElement(this.elementRef)) == null ? void 0 : e.classList.contains("error-message-text");
3024
3024
  }
3025
3025
  static isLoadingMessage(e) {
3026
- return e == null ? void 0 : e.bubbleElement.classList.contains(Te.BUBBLE_CLASS);
3026
+ return e == null ? void 0 : e.bubbleElement.classList.contains(ke.BUBBLE_CLASS);
3027
3027
  }
3028
3028
  sendClientUpdate(e, t = !1) {
3029
3029
  var i;
@@ -3039,7 +3039,7 @@ class Oe {
3039
3039
  });
3040
3040
  }
3041
3041
  }
3042
- const Le = class Le {
3042
+ const _e = class _e {
3043
3043
  // used for extracting at end and for isStreaming
3044
3044
  constructor(e) {
3045
3045
  this._fileAdded = !1, this._streamedContent = "", this._streamType = "", this._hasStreamEnded = !1, this._messages = e;
@@ -3060,7 +3060,7 @@ const Le = class Le {
3060
3060
  i && J.scrollToBottom(this._messages.elementRef);
3061
3061
  }
3062
3062
  setInitialState(e, t, i) {
3063
- this._streamType = e, i ?? (i = b.AI_ROLE), this._elements = e === "text" ? this._messages.addNewTextMessage(t, i) : Ne.add(this._messages, t, i, this._messages.messageElementRefs), this._elements.bubbleElement.classList.add(Le.MESSAGE_CLASS), this._streamedContent = t, this._activeMessageRole = i, this._message = { role: this._activeMessageRole, [e]: this._streamedContent }, this._messages.messages.push(this._message);
3063
+ this._streamType = e, i ?? (i = b.AI_ROLE), this._elements = e === "text" ? this._messages.addNewTextMessage(t, i) : De.add(this._messages, t, i, this._messages.messageElementRefs), this._elements.bubbleElement.classList.add(_e.MESSAGE_CLASS), this._streamedContent = t, this._activeMessageRole = i, this._message = { role: this._activeMessageRole, [e]: this._streamedContent }, this._messages.messages.push(this._message);
3064
3064
  }
3065
3065
  updateBasedOnType(e, t, i, s = !1) {
3066
3066
  b.unfillEmptyMessageElement(i, e), (t === "text" ? this.updateText : this.updateHTML).bind(this)(e, i, s);
@@ -3073,7 +3073,7 @@ const Le = class Le {
3073
3073
  this._streamedContent = e, t.innerHTML = e;
3074
3074
  else {
3075
3075
  const s = document.createElement("span");
3076
- s.innerHTML = e, t.appendChild(s), this._streamedContent = Le.HTML_CONTENT_PLACEHOLDER;
3076
+ s.innerHTML = e, t.appendChild(s), this._streamedContent = _e.HTML_CONTENT_PLACEHOLDER;
3077
3077
  }
3078
3078
  }
3079
3079
  finaliseStreamedMessage() {
@@ -3081,7 +3081,7 @@ const Le = class Le {
3081
3081
  const { textElementsToText: e } = this._messages;
3082
3082
  if (!this._endStreamAfterOperation && !(this._fileAdded && !this._elements)) {
3083
3083
  if (!this._elements) throw Error(k.NO_VALID_STREAM_EVENTS_SENT);
3084
- (t = this._elements.bubbleElement) != null && t.classList.contains(Le.MESSAGE_CLASS) && (this._streamType === "text" ? (e[e.length - 1][1] = this._streamedContent, this._message && (this._message.text = this._streamedContent), this._messages.textToSpeech && ft.speak(this._streamedContent, this._messages.textToSpeech)) : this._streamType === "html" && (this._streamedContent === Le.HTML_CONTENT_PLACEHOLDER && (this._streamedContent = ((i = this._elements.bubbleElement) == null ? void 0 : i.innerHTML) || ""), this._elements && te.apply(this._messages, this._elements.outerContainer), this._message && (this._message.html = this._streamedContent)), this._message && this._messages.sendClientUpdate(Oe.createMessageContent(this._message), !1), this._hasStreamEnded = !0);
3084
+ (t = this._elements.bubbleElement) != null && t.classList.contains(_e.MESSAGE_CLASS) && (this._streamType === "text" ? (e[e.length - 1][1] = this._streamedContent, this._message && (this._message.text = this._streamedContent), this._messages.textToSpeech && ft.speak(this._streamedContent, this._messages.textToSpeech)) : this._streamType === "html" && (this._streamedContent === _e.HTML_CONTENT_PLACEHOLDER && (this._streamedContent = ((i = this._elements.bubbleElement) == null ? void 0 : i.innerHTML) || ""), this._elements && te.apply(this._messages, this._elements.outerContainer), this._message && (this._message.html = this._streamedContent)), this._elements.bubbleElement.classList.remove(_e.MESSAGE_CLASS), this._message && this._messages.sendClientUpdate(Ne.createMessageContent(this._message), !1), this._hasStreamEnded = !0);
3085
3085
  }
3086
3086
  }
3087
3087
  markFileAdded() {
@@ -3098,8 +3098,8 @@ const Le = class Le {
3098
3098
  i && this.updateBasedOnType(i, "text", (r = this._elements) == null ? void 0 : r.bubbleElement, !0), this._endStreamAfterOperation = !1, this.finaliseStreamedMessage(), s && e.addNewMessage({ files: s });
3099
3099
  }
3100
3100
  };
3101
- Le.MESSAGE_CLASS = "streamed-message", Le.HTML_CONTENT_PLACEHOLDER = "htmlplaceholder";
3102
- let ge = Le;
3101
+ _e.MESSAGE_CLASS = "streamed-message", _e.HTML_CONTENT_PLACEHOLDER = "htmlplaceholder";
3102
+ let ge = _e;
3103
3103
  const Ge = class Ge {
3104
3104
  // need to pass stringifyBody boolean separately as binding is throwing an error for some reason
3105
3105
  // prettier-ignore
@@ -3242,13 +3242,13 @@ function mo(n, e) {
3242
3242
  t == null || t.addEventListener("abort", () => {
3243
3243
  j(), h();
3244
3244
  });
3245
- const V = c ?? window.fetch, Re = s ?? go;
3245
+ const V = c ?? window.fetch, Le = s ?? go;
3246
3246
  async function R() {
3247
3247
  var X;
3248
3248
  m = new AbortController();
3249
3249
  try {
3250
3250
  const Z = await V(n, Object.assign(Object.assign({}, d), { headers: f, signal: m.signal }));
3251
- await Re(Z), await lo(Z.body, co(ho((D) => {
3251
+ await Le(Z), await lo(Z.body, co(ho((D) => {
3252
3252
  D ? f[Bs] = D : delete f[Bs];
3253
3253
  }, (D) => {
3254
3254
  y = D;
@@ -3274,16 +3274,16 @@ function go(n) {
3274
3274
  class T {
3275
3275
  // prettier-ignore
3276
3276
  static async request(e, t, i, s = !0, r = !1) {
3277
- var p, y, x, j, V, Re;
3277
+ var p, y, x, j, V, Le;
3278
3278
  const o = { body: t, headers: (p = e.connectSettings) == null ? void 0 : p.headers }, { body: a, headers: l, error: c } = await v.processRequestInterceptor(e.deepChat, o), { onOpen: d, onClose: h, abortStream: u } = e.streamHandlers;
3279
3279
  if (c) return v.onInterceptorError(i, c, h);
3280
- if ((y = e.connectSettings) != null && y.handler) return we.stream(e, a, i);
3280
+ if ((y = e.connectSettings) != null && y.handler) return Te.stream(e, a, i);
3281
3281
  if (((x = e.connectSettings) == null ? void 0 : x.url) === be.URL) return be.requestStream(i, e.streamHandlers);
3282
3282
  const f = new ge(i), m = v.fetch.bind(this, e, l, s);
3283
3283
  return mo(((j = e.connectSettings) == null ? void 0 : j.url) || e.url || "", {
3284
3284
  method: ((V = e.connectSettings) == null ? void 0 : V.method) || "POST",
3285
3285
  headers: l,
3286
- credentials: (Re = e.connectSettings) == null ? void 0 : Re.credentials,
3286
+ credentials: (Le = e.connectSettings) == null ? void 0 : Le.credentials,
3287
3287
  body: s ? JSON.stringify(a) : a,
3288
3288
  openWhenHidden: !0,
3289
3289
  // keep stream open when browser tab not open
@@ -3295,16 +3295,16 @@ class T {
3295
3295
  async onmessage(R) {
3296
3296
  var X, Z, D;
3297
3297
  if (JSON.stringify(R.data) !== JSON.stringify("[DONE]")) {
3298
- let Fe;
3298
+ let Be;
3299
3299
  try {
3300
- Fe = JSON.parse(R.data);
3300
+ Be = JSON.parse(R.data);
3301
3301
  } catch {
3302
- Fe = {};
3302
+ Be = {};
3303
3303
  }
3304
- const yt = await ((Z = (X = e.deepChat).responseInterceptor) == null ? void 0 : Z.call(X, Fe)) || Fe;
3305
- (D = e.extractResultData) == null || D.call(e, yt, m, a).then((Be) => {
3306
- e.asyncCallInProgress && Be && Be.text !== "" ? (T.simulate(i, e.streamHandlers, Be), h(), e.asyncCallInProgress = !1) : T.upsertWFiles(i, f.upsertStreamedMessage.bind(f), f, Be);
3307
- }).catch((Be) => v.displayError(i, Be));
3304
+ const yt = await ((Z = (X = e.deepChat).responseInterceptor) == null ? void 0 : Z.call(X, Be)) || Be;
3305
+ (D = e.extractResultData) == null || D.call(e, yt, m, a).then((Ue) => {
3306
+ e.asyncCallInProgress && Ue && Ue.text !== "" ? (T.simulate(i, e.streamHandlers, Ue), h(), e.asyncCallInProgress = !1) : T.upsertWFiles(i, f.upsertStreamedMessage.bind(f), f, Ue);
3307
+ }).catch((Ue) => v.displayError(i, Ue));
3308
3308
  }
3309
3309
  },
3310
3310
  onerror(R) {
@@ -3425,7 +3425,7 @@ class U {
3425
3425
  if (!U.isElementPresentInDOM(e.deepChat)) return;
3426
3426
  const i = e.connectSettings.websocket;
3427
3427
  if (i) {
3428
- if (e.connectSettings.handler) return we.websocket(e, t);
3428
+ if (e.connectSettings.handler) return Te.websocket(e, t);
3429
3429
  try {
3430
3430
  const s = typeof i != "boolean" ? i : void 0, r = new WebSocket(e.connectSettings.url || "", s);
3431
3431
  e.websocket = r, e.websocket.onopen = () => {
@@ -3495,7 +3495,7 @@ class U {
3495
3495
  T.simulate(t, e.streamHandlers, s);
3496
3496
  }
3497
3497
  }
3498
- class we {
3498
+ class Te {
3499
3499
  static async request(e, t, i) {
3500
3500
  var a, l;
3501
3501
  let s = !0;
@@ -3505,13 +3505,13 @@ class we {
3505
3505
  s = !1;
3506
3506
  const d = await ((u = (h = e.deepChat).responseInterceptor) == null ? void 0 : u.call(h, c)) || c;
3507
3507
  v.validateResponseFormat(d) ? typeof d.error == "string" ? (console.error(d.error), i.addNewErrorMessage("service", d.error), e.completionsHandlers.onFinish()) : T.isSimulatable(e.stream, d) ? T.simulate(i, e.streamHandlers, d) : (i.addNewMessage(d), e.completionsHandlers.onFinish()) : (console.error(k.INVALID_RESPONSE(c, "server", !!e.deepChat.responseInterceptor, d)), i.addNewErrorMessage("service", "Error in server message"), e.completionsHandlers.onFinish());
3508
- }, o = we.generateOptionalSignals();
3508
+ }, o = Te.generateOptionalSignals();
3509
3509
  (l = (a = e.connectSettings).handler) == null || l.call(a, t, { ...o, onResponse: r });
3510
3510
  }
3511
3511
  static attemptToFinaliseStream(e, t) {
3512
3512
  try {
3513
3513
  const i = t.messageElementRefs[t.messageElementRefs.length - 1];
3514
- Oe.isLoadingMessage(i) ? t.removeLastMessage() : e.finaliseStreamedMessage();
3514
+ Ne.isLoadingMessage(i) ? t.removeLastMessage() : e.finaliseStreamedMessage();
3515
3515
  } catch (i) {
3516
3516
  console.error(i), t.addNewErrorMessage("service", i);
3517
3517
  }
@@ -3523,7 +3523,7 @@ class we {
3523
3523
  const o = new ge(i), a = () => {
3524
3524
  r || !s || (e.streamHandlers.onOpen(), r = !0);
3525
3525
  }, l = () => {
3526
- s && (we.attemptToFinaliseStream(o, i), e.streamHandlers.onClose(), s = !1);
3526
+ s && (Te.attemptToFinaliseStream(o, i), e.streamHandlers.onClose(), s = !1);
3527
3527
  }, c = async (f) => {
3528
3528
  var p, y;
3529
3529
  if (!s) return;
@@ -3531,9 +3531,9 @@ class we {
3531
3531
  v.validateResponseFormat(m) ? m.error ? (console.error(m.error), o.finaliseStreamedMessage(), i.addNewErrorMessage("service", m.error), e.streamHandlers.onClose(), s = !1) : T.upsertWFiles(i, o.upsertStreamedMessage.bind(o), o, m) : console.error(k.INVALID_RESPONSE(f, "server", !!e.deepChat.responseInterceptor, m));
3532
3532
  };
3533
3533
  e.streamHandlers.abortStream.abort = () => {
3534
- we.attemptToFinaliseStream(o, i), e.streamHandlers.onClose(), s = !1;
3534
+ Te.attemptToFinaliseStream(o, i), e.streamHandlers.onClose(), s = !1;
3535
3535
  };
3536
- const d = we.generateOptionalSignals();
3536
+ const d = Te.generateOptionalSignals();
3537
3537
  (u = (h = e.connectSettings).handler) == null || u.call(
3538
3538
  h,
3539
3539
  t,
@@ -3563,7 +3563,7 @@ class we {
3563
3563
  T.upsertWFiles(t, m, p, d);
3564
3564
  } else
3565
3565
  t.addNewMessage(h);
3566
- }, a = we.generateOptionalSignals();
3566
+ }, a = Te.generateOptionalSignals();
3567
3567
  (c = (l = e.connectSettings).handler) == null || c.call(
3568
3568
  l,
3569
3569
  void 0,
@@ -3584,7 +3584,7 @@ class C {
3584
3584
  var u, f, m;
3585
3585
  const r = { body: t, headers: (u = e.connectSettings) == null ? void 0 : u.headers }, { body: o, headers: a, error: l } = await v.processRequestInterceptor(e.deepChat, r), { onFinish: c } = e.completionsHandlers;
3586
3586
  if (l) return v.onInterceptorError(i, l, c);
3587
- if ((f = e.connectSettings) != null && f.handler) return we.request(e, o, i);
3587
+ if ((f = e.connectSettings) != null && f.handler) return Te.request(e, o, i);
3588
3588
  if (((m = e.connectSettings) == null ? void 0 : m.url) === be.URL) return be.request(e, i);
3589
3589
  let d = !0;
3590
3590
  const h = v.fetch.bind(this, e, a, s);
@@ -3902,16 +3902,16 @@ class li {
3902
3902
  e._propUpdated_ = !0, e._waitingToRender_ || (e._waitingToRender_ = !0, li.waitForPropertiesToBeUpdatedBeforeRender(e));
3903
3903
  }
3904
3904
  }
3905
- const xe = class xe extends HTMLElement {
3905
+ const Se = class Se extends HTMLElement {
3906
3906
  // If this is not working, try using propertyName directly
3907
3907
  constructor() {
3908
- super(), this._waitingToRender_ = !1, this._propUpdated_ = !1, Object.keys(xe._attributeToProperty_).forEach((e) => {
3909
- const t = xe._attributeToProperty_[e];
3908
+ super(), this._waitingToRender_ = !1, this._propUpdated_ = !1, Object.keys(Se._attributeToProperty_).forEach((e) => {
3909
+ const t = Se._attributeToProperty_[e];
3910
3910
  this.constructPropertyAccessors(t), this.hasOwnProperty(e) || this.constructPropertyAccessors(t, e);
3911
3911
  });
3912
3912
  }
3913
3913
  static get observedAttributes() {
3914
- return Object.keys(xe._attributes_) || [];
3914
+ return Object.keys(Se._attributes_) || [];
3915
3915
  }
3916
3916
  // need to be called here as accessors need to be set for the class instance
3917
3917
  constructPropertyAccessors(e, t) {
@@ -3927,14 +3927,14 @@ const xe = class xe extends HTMLElement {
3927
3927
  }
3928
3928
  attributeChangedCallback(e, t, i) {
3929
3929
  if (t === i) return;
3930
- const s = xe._attributes_[e](i), r = xe._attributeToProperty_[e];
3930
+ const s = Se._attributes_[e](i), r = Se._attributeToProperty_[e];
3931
3931
  this[r] = s;
3932
3932
  }
3933
3933
  onRender() {
3934
3934
  }
3935
3935
  };
3936
- xe._attributes_ = {}, xe._attributeToProperty_ = {};
3937
- let ss = xe;
3936
+ Se._attributes_ = {}, Se._attributeToProperty_ = {};
3937
+ let ss = Se;
3938
3938
  const bo = `<?xml version="1.0" standalone="no"?>
3939
3939
  <svg version="1.1"
3940
3940
  xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
@@ -3977,10 +3977,10 @@ class ie {
3977
3977
  return new DOMParser().parseFromString(e, "image/svg+xml").documentElement;
3978
3978
  }
3979
3979
  }
3980
- const Pe = class Pe {
3980
+ const Oe = class Oe {
3981
3981
  // prettier-ignore
3982
3982
  static changeVisibility(e, t, i, s) {
3983
- s.target.id === Pe.VISIBLE_ICON_ID ? (t.style.display = "none", i.style.display = "block", e.type = "password") : (t.style.display = "block", i.style.display = "none", e.type = "text");
3983
+ s.target.id === Oe.VISIBLE_ICON_ID ? (t.style.display = "none", i.style.display = "block", e.type = "password") : (t.style.display = "block", i.style.display = "none", e.type = "text");
3984
3984
  }
3985
3985
  static createIconElement(e, t) {
3986
3986
  const i = ie.createSVGElement(e);
@@ -3990,10 +3990,10 @@ const Pe = class Pe {
3990
3990
  static create(e) {
3991
3991
  const t = document.createElement("div");
3992
3992
  t.id = "visibility-icon-container";
3993
- const i = Pe.createIconElement(vo, Pe.VISIBLE_ICON_ID);
3993
+ const i = Oe.createIconElement(vo, Oe.VISIBLE_ICON_ID);
3994
3994
  i.style.display = "none", t.appendChild(i);
3995
- const s = Pe.createIconElement(bo, "not-visible-icon");
3996
- return t.appendChild(s), t.onclick = Pe.changeVisibility.bind(
3995
+ const s = Oe.createIconElement(bo, "not-visible-icon");
3996
+ return t.appendChild(s), t.onclick = Oe.changeVisibility.bind(
3997
3997
  this,
3998
3998
  e,
3999
3999
  i,
@@ -4001,8 +4001,8 @@ const Pe = class Pe {
4001
4001
  ), t;
4002
4002
  }
4003
4003
  };
4004
- Pe.VISIBLE_ICON_ID = "visible-icon";
4005
- let ns = Pe;
4004
+ Oe.VISIBLE_ICON_ID = "visible-icon";
4005
+ let ns = Oe;
4006
4006
  class H {
4007
4007
  static createCautionText() {
4008
4008
  const e = document.createElement("a");
@@ -4527,8 +4527,8 @@ const Rt = class Rt extends z {
4527
4527
  }
4528
4528
  };
4529
4529
  Rt.URL_PREFIX = "https://api-inference.huggingface.co/models/";
4530
- let Me = Rt;
4531
- class Gt extends Me {
4530
+ let Ie = Rt;
4531
+ class Gt extends Ie {
4532
4532
  // prettier-ignore
4533
4533
  constructor(e, t, i, s, r, o) {
4534
4534
  super(e, t, i, s, r, o), this.isTextInputDisabled = !0, this.canSendMessage = Gt.canSendFile;
@@ -4699,7 +4699,7 @@ class xo extends Gt {
4699
4699
  return { text: e.text || "" };
4700
4700
  }
4701
4701
  }
4702
- class _o extends Me {
4702
+ class _o extends Ie {
4703
4703
  constructor(e) {
4704
4704
  var s, r, o;
4705
4705
  const t = (r = (s = e.directConnection) == null ? void 0 : s.huggingFace) == null ? void 0 : r.textGeneration, i = (o = e.directConnection) == null ? void 0 : o.huggingFace;
@@ -4711,7 +4711,7 @@ class _o extends Me {
4711
4711
  return { text: ((t = e[0]) == null ? void 0 : t.generated_text) || "" };
4712
4712
  }
4713
4713
  }
4714
- class So extends Me {
4714
+ class So extends Ie {
4715
4715
  constructor(e) {
4716
4716
  var s, r, o;
4717
4717
  const t = (r = (s = e.directConnection) == null ? void 0 : s.huggingFace) == null ? void 0 : r.questionAnswer, i = (o = e.directConnection) == null ? void 0 : o.huggingFace;
@@ -4729,7 +4729,7 @@ class So extends Me {
4729
4729
  return { text: e.answer || "" };
4730
4730
  }
4731
4731
  }
4732
- class wo extends Me {
4732
+ class wo extends Ie {
4733
4733
  constructor(e) {
4734
4734
  var s, r, o;
4735
4735
  const t = (r = (s = e.directConnection) == null ? void 0 : s.huggingFace) == null ? void 0 : r.summarization, i = (o = e.directConnection) == null ? void 0 : o.huggingFace;
@@ -4741,7 +4741,7 @@ class wo extends Me {
4741
4741
  return { text: ((t = e[0]) == null ? void 0 : t.summary_text) || "" };
4742
4742
  }
4743
4743
  }
4744
- class Co extends Me {
4744
+ class Co extends Ie {
4745
4745
  constructor(e) {
4746
4746
  var s, r, o;
4747
4747
  const t = (r = (s = e.directConnection) == null ? void 0 : s.huggingFace) == null ? void 0 : r.conversation, i = (o = e.directConnection) == null ? void 0 : o.huggingFace;
@@ -4812,7 +4812,7 @@ class fi extends Mi {
4812
4812
  return { files: e.artifacts.map((i) => ({ src: `${Wt}${i.base64}`, type: "image" })) };
4813
4813
  }
4814
4814
  }
4815
- class To extends Me {
4815
+ class To extends Ie {
4816
4816
  constructor(e) {
4817
4817
  var s, r, o;
4818
4818
  const t = (r = (s = e.directConnection) == null ? void 0 : s.huggingFace) == null ? void 0 : r.translation, i = (o = e.directConnection) == null ? void 0 : o.huggingFace;
@@ -4855,7 +4855,7 @@ class pi extends Mi {
4855
4855
  return { files: e.artifacts.map((i) => ({ src: `${Wt}${i.base64}`, type: "image" })) };
4856
4856
  }
4857
4857
  }
4858
- class Ao extends Me {
4858
+ class Ao extends Ie {
4859
4859
  constructor(e) {
4860
4860
  var s, r, o;
4861
4861
  const t = (r = (s = e.directConnection) == null ? void 0 : s.huggingFace) == null ? void 0 : r.fillMask, i = (o = e.directConnection) == null ? void 0 : o.huggingFace;
@@ -6052,14 +6052,14 @@ const Fo = `<?xml version="1.0" encoding="iso-8859-1"?>
6052
6052
  </g>
6053
6053
  </g>
6054
6054
  </svg>`;
6055
- class Ie {
6055
+ class Pe {
6056
6056
  static createImage(e, t, i) {
6057
6057
  const s = new Image();
6058
6058
  return s.src = e.src, i || B.scrollDownOnImageLoad(s.src, t), B.processContent("image", s, s.src, e.name);
6059
6059
  }
6060
6060
  // WORK - image still does not scroll down when loaded
6061
6061
  static async addNewImageMessage(e, t, i, s) {
6062
- const r = Ie.createImage(t, e.elementRef, s), o = e.createNewMessageElement("", i);
6062
+ const r = Pe.createImage(t, e.elementRef, s), o = e.createNewMessageElement("", i);
6063
6063
  o.bubbleElement.appendChild(r), o.bubbleElement.classList.add("image-message"), B.addMessage(e, o, "image", i, s);
6064
6064
  }
6065
6065
  static createAudioElement(e, t) {
@@ -6069,7 +6069,7 @@ class Ie {
6069
6069
  )), i;
6070
6070
  }
6071
6071
  static addNewAudioMessage(e, t, i, s) {
6072
- const r = Ie.createAudioElement(t, i), o = e.createMessageElementsOnOrientation("", i, s);
6072
+ const r = Pe.createAudioElement(t, i), o = e.createMessageElementsOnOrientation("", i, s);
6073
6073
  o.bubbleElement.appendChild(r), o.bubbleElement.classList.add("audio-message"), B.addMessage(e, o, "audio", i, s);
6074
6074
  }
6075
6075
  static createAnyFile(e) {
@@ -6083,22 +6083,22 @@ class Ie {
6083
6083
  return r.classList.add("any-file-message-text"), r.textContent = e.name || B.DEFAULT_FILE_NAME, t.appendChild(i), t.appendChild(r), B.processContent("any", t, e.src, r.textContent);
6084
6084
  }
6085
6085
  static addNewAnyFileMessage(e, t, i, s) {
6086
- const r = e.createMessageElementsOnOrientation("", i, s), o = Ie.createAnyFile(t);
6086
+ const r = e.createMessageElementsOnOrientation("", i, s), o = Pe.createAnyFile(t);
6087
6087
  r.bubbleElement.classList.add("any-file-message-bubble"), r.bubbleElement.appendChild(o), B.addMessage(e, r, "file", i, s);
6088
6088
  }
6089
6089
  // no overwrite previous message logic as it is complex to track which files are to be overwritten
6090
6090
  static addMessages(e, t, i, s) {
6091
6091
  t.forEach((r) => {
6092
- r.ref && (r = B.removeFileRef(r)), B.isAudioFile(r) ? Ie.addNewAudioMessage(e, r, i, s) : B.isImageFile(r) ? Ie.addNewImageMessage(e, r, i, s) : Ie.addNewAnyFileMessage(e, r, i, s);
6092
+ r.ref && (r = B.removeFileRef(r)), B.isAudioFile(r) ? Pe.addNewAudioMessage(e, r, i, s) : B.isImageFile(r) ? Pe.addNewImageMessage(e, r, i, s) : Pe.addNewAnyFileMessage(e, r, i, s);
6093
6093
  });
6094
6094
  }
6095
6095
  }
6096
- class Ue extends Oe {
6096
+ class Ee extends Ne {
6097
6097
  constructor(e, t, i) {
6098
6098
  var a, l;
6099
6099
  super(e);
6100
6100
  const { permittedErrorPrefixes: s, introPanelMarkUp: r, demo: o } = t;
6101
- this._errorMessageOverrides = (a = e.errorMessages) == null ? void 0 : a.overrides, this._onClearMessages = ai.onClearMessages.bind(this, e), this._onError = ai.onError.bind(this, e), this._displayLoadingMessage = Ue.getDisplayLoadingMessage(e, t), this._permittedErrorPrefixes = s, this.addSetupMessageIfNeeded(e, t) || this.populateIntroPanel(i, r, e.introPanelStyle), this.addIntroductoryMessages(e, t), new Ft(e, this, t), this._displayServiceErrorMessages = (l = e.errorMessages) == null ? void 0 : l.displayServiceErrorMessages, e.getMessages = () => JSON.parse(JSON.stringify(this.messages)), e.clearMessages = this.clearMessages.bind(this, t), e.refreshMessages = this.refreshTextMessages.bind(this), e.scrollToBottom = J.scrollToBottom.bind(this, this.elementRef), e.addMessage = (c, d) => {
6101
+ this._errorMessageOverrides = (a = e.errorMessages) == null ? void 0 : a.overrides, this._onClearMessages = ai.onClearMessages.bind(this, e), this._onError = ai.onError.bind(this, e), this._displayLoadingMessage = Ee.getDisplayLoadingMessage(e, t), this._permittedErrorPrefixes = s, this.addSetupMessageIfNeeded(e, t) || this.populateIntroPanel(i, r, e.introPanelStyle), this.addIntroductoryMessages(e, t), new Ft(e, this, t), this._displayServiceErrorMessages = (l = e.errorMessages) == null ? void 0 : l.displayServiceErrorMessages, e.getMessages = () => JSON.parse(JSON.stringify(this.messages)), e.clearMessages = this.clearMessages.bind(this, t), e.refreshMessages = this.refreshTextMessages.bind(this), e.scrollToBottom = J.scrollToBottom.bind(this, this.elementRef), e.addMessage = (c, d) => {
6102
6102
  this.addAnyMessage({ ...c, sendUpdate: !!d }, !d);
6103
6103
  }, t.isWebModel() && t.setUpMessages(this), o && this.prepareDemo(o), e.textToSpeech && ft.processConfig(e.textToSpeech, (c) => {
6104
6104
  this.textToSpeech = c;
@@ -6129,7 +6129,7 @@ class Ue extends Oe {
6129
6129
  addIntroductoryMessage(e) {
6130
6130
  var i;
6131
6131
  let t;
6132
- e != null && e.text ? t = this.createAndAppendNewMessageElement(e.text, b.AI_ROLE) : e != null && e.html && (t = Ne.add(this, e.html, b.AI_ROLE, this.messageElementRefs)), t && (this.applyCustomStyles(t, b.AI_ROLE, !1, (i = this.messageStyles) == null ? void 0 : i.intro), t.outerContainer.classList.add("deep-chat-intro"));
6132
+ e != null && e.text ? t = this.createAndAppendNewMessageElement(e.text, b.AI_ROLE) : e != null && e.html && (t = De.add(this, e.html, b.AI_ROLE, this.messageElementRefs)), t && (this.applyCustomStyles(t, b.AI_ROLE, !1, (i = this.messageStyles) == null ? void 0 : i.intro), t.outerContainer.classList.add("deep-chat-intro"));
6133
6133
  }
6134
6134
  removeIntroductoryMessage() {
6135
6135
  const e = this.messageElementRefs[0];
@@ -6140,10 +6140,10 @@ class Ue extends Oe {
6140
6140
  }
6141
6141
  // this should not be activated by streamed messages
6142
6142
  addNewMessage(e, t = !1, i = !1) {
6143
- const s = Ue.createMessageContent(e), r = { status: e.overwrite };
6144
- if (!e.ignoreText && s.text !== void 0 && e.text !== null && (this.addNewTextMessage(s.text, s.role, r, i), !t && this.textToSpeech && s.role !== b.USER_ROLE && ft.speak(s.text, this.textToSpeech)), s.files && Array.isArray(s.files) && Ie.addMessages(this, s.files, s.role, i), s.html !== void 0 && s.html !== null) {
6145
- const o = Ne.add(this, s.html, s.role, this.messageElementRefs, r, i);
6146
- Ae.isElementTemporary(o) && delete s.html;
6143
+ const s = Ee.createMessageContent(e), r = { status: e.overwrite };
6144
+ if (!e.ignoreText && s.text !== void 0 && e.text !== null && (this.addNewTextMessage(s.text, s.role, r, i), !t && this.textToSpeech && s.role !== b.USER_ROLE && ft.speak(s.text, this.textToSpeech)), s.files && Array.isArray(s.files) && Pe.addMessages(this, s.files, s.role, i), s.html !== void 0 && s.html !== null) {
6145
+ const o = De.add(this, s.html, s.role, this.messageElementRefs, r, i);
6146
+ Me.isElementTemporary(o) && delete s.html;
6147
6147
  }
6148
6148
  return this.isValidMessageContent(s) && !i && this.updateStateOnMessage(s, e.overwrite, e.sendUpdate, t), s;
6149
6149
  }
@@ -6156,7 +6156,7 @@ class Ue extends Oe {
6156
6156
  // prettier-ignore
6157
6157
  removeMessageOnError() {
6158
6158
  const e = this.messageElementRefs[this.messageElementRefs.length - 1], t = e == null ? void 0 : e.bubbleElement;
6159
- (t != null && t.classList.contains(ge.MESSAGE_CLASS) && t.textContent === "" || Ue.isTemporaryElement(e)) && this.removeLastMessage();
6159
+ (t != null && t.classList.contains(ge.MESSAGE_CLASS) && t.textContent === "" || Ee.isTemporaryElement(e)) && this.removeLastMessage();
6160
6160
  }
6161
6161
  // prettier-ignore
6162
6162
  addNewErrorMessage(e, t, i = !1) {
@@ -6179,13 +6179,13 @@ class Ue extends Oe {
6179
6179
  }
6180
6180
  getPermittedMessage(e) {
6181
6181
  if (e) {
6182
- const t = Ue.extractErrorMessages(e);
6182
+ const t = Ee.extractErrorMessages(e);
6183
6183
  for (let i = 0; i < t.length; i += 1) {
6184
6184
  const s = t[i];
6185
6185
  if (typeof s == "string") {
6186
6186
  if (this._displayServiceErrorMessages) return s;
6187
6187
  if (this._permittedErrorPrefixes) {
6188
- const r = Ue.checkPermittedErrorPrefixes(this._permittedErrorPrefixes, s);
6188
+ const r = Ee.checkPermittedErrorPrefixes(this._permittedErrorPrefixes, s);
6189
6189
  if (r) return r;
6190
6190
  }
6191
6191
  }
@@ -6197,15 +6197,15 @@ class Ue extends Oe {
6197
6197
  }
6198
6198
  addDefaultLoadingMessage() {
6199
6199
  const e = this.createMessageElements("", b.AI_ROLE), { bubbleElement: t } = e;
6200
- e.bubbleElement.classList.add(Te.DOTS_CONTAINER_CLASS);
6200
+ e.bubbleElement.classList.add(ke.DOTS_CONTAINER_CLASS);
6201
6201
  const i = document.createElement("div");
6202
- return i.classList.add("loading-message-dots"), t.appendChild(i), Te.setDots(t, this.messageStyles), e;
6202
+ return i.classList.add("loading-message-dots"), t.appendChild(i), ke.setDots(t, this.messageStyles), e;
6203
6203
  }
6204
6204
  addLoadingMessage() {
6205
6205
  var i, s, r, o, a, l;
6206
6206
  if (!this._displayLoadingMessage) return;
6207
- const e = (r = (s = (i = this.messageStyles) == null ? void 0 : i.loading) == null ? void 0 : s.message) == null ? void 0 : r.html, t = e ? Ne.createElements(this, e, b.AI_ROLE, !1) : this.addDefaultLoadingMessage();
6208
- this.elementRef.appendChild(t.outerContainer), t.bubbleElement.classList.add(Te.BUBBLE_CLASS), this.applyCustomStyles(t, b.AI_ROLE, !1, (l = (a = (o = this.messageStyles) == null ? void 0 : o.loading) == null ? void 0 : a.message) == null ? void 0 : l.styles), J.scrollToBottom(this.elementRef);
6207
+ const e = (r = (s = (i = this.messageStyles) == null ? void 0 : i.loading) == null ? void 0 : s.message) == null ? void 0 : r.html, t = e ? De.createElements(this, e, b.AI_ROLE, !1) : this.addDefaultLoadingMessage();
6208
+ this.elementRef.appendChild(t.outerContainer), t.bubbleElement.classList.add(ke.BUBBLE_CLASS), this.applyCustomStyles(t, b.AI_ROLE, !1, (l = (a = (o = this.messageStyles) == null ? void 0 : o.loading) == null ? void 0 : a.message) == null ? void 0 : l.styles), J.scrollToBottom(this.elementRef);
6209
6209
  }
6210
6210
  populateIntroPanel(e, t, i) {
6211
6211
  (e || t) && (this._introPanel = new bi(e, t, i), this._introPanel._elementRef && (te.apply(this, this._introPanel._elementRef), this.elementRef.appendChild(this._introPanel._elementRef)));
@@ -6225,18 +6225,24 @@ class Ue extends Oe {
6225
6225
  }))
6226
6226
  );
6227
6227
  }
6228
+ static isActiveElement(e) {
6229
+ return e.contains(ke.BUBBLE_CLASS) || e.contains(Xe.CLASS) || e.contains(ge.MESSAGE_CLASS);
6230
+ }
6228
6231
  // WORK - update all message classes to use deep-chat prefix
6229
6232
  clearMessages(e, t) {
6230
- var s, r;
6231
- const i = [];
6232
- this.messageElementRefs.forEach((o) => {
6233
- const a = o.bubbleElement.classList;
6234
- a.contains(Te.BUBBLE_CLASS) || a.contains(Xe.CLASS) || a.contains(ge.MESSAGE_CLASS) ? i.push(o) : o.outerContainer.remove();
6235
- }), Array.from(this.elementRef.children).forEach((o) => {
6236
- var l;
6237
- const a = (l = o.children[0]) == null ? void 0 : l.children[0];
6238
- a != null && a.classList.contains("error-message-text") && o.remove();
6239
- }), this.messageElementRefs = i, t !== !1 && ((s = this._introPanel) != null && s._elementRef && this._introPanel.display(), this.addIntroductoryMessages()), this.messages.splice(0, this.messages.length), this.textElementsToText.splice(0, this.textElementsToText.length), (r = this._onClearMessages) == null || r.call(this), delete e.sessionId;
6233
+ var r, o;
6234
+ const i = [], s = [];
6235
+ this.messageElementRefs.forEach((a) => {
6236
+ const l = a.bubbleElement.classList;
6237
+ Ee.isActiveElement(l) ? i.push(a) : a.outerContainer.remove();
6238
+ }), this.textElementsToText.forEach((a) => {
6239
+ const l = a[0].bubbleElement.classList;
6240
+ Ee.isActiveElement(l) && s.push(a);
6241
+ }), Array.from(this.elementRef.children).forEach((a) => {
6242
+ var c;
6243
+ const l = (c = a.children[0]) == null ? void 0 : c.children[0];
6244
+ l != null && l.classList.contains("error-message-text") && a.remove();
6245
+ }), this.messageElementRefs = i, t !== !1 && ((r = this._introPanel) != null && r._elementRef && this._introPanel.display(), this.addIntroductoryMessages()), this.messages.splice(0, this.messages.length), this.textElementsToText = s, (o = this._onClearMessages) == null || o.call(this), delete e.sessionId;
6240
6246
  }
6241
6247
  }
6242
6248
  const N = class N {
@@ -6677,12 +6683,12 @@ class jt extends $t {
6677
6683
  var mn = {}, Ri = {}, Ii = {}, Kt = {}, st = {};
6678
6684
  Object.defineProperty(st, "__esModule", { value: !0 });
6679
6685
  st.Text = void 0;
6680
- class De {
6686
+ class Fe {
6681
6687
  static capitalize(e) {
6682
- return e.replace(De.FIRST_CHAR_REGEX, (t) => t.toUpperCase());
6688
+ return e.replace(Fe.FIRST_CHAR_REGEX, (t) => t.toUpperCase());
6683
6689
  }
6684
6690
  static lineBreak(e) {
6685
- return e.replace(De.DOUBLE_LINE, "<p></p>").replace(De.ONE_LINE, "<br>");
6691
+ return e.replace(Fe.DOUBLE_LINE, "<p></p>").replace(Fe.ONE_LINE, "<br>");
6686
6692
  }
6687
6693
  static isCharDefined(e) {
6688
6694
  return e !== void 0 && e !== " " && e !== " " && e !== `
@@ -6693,10 +6699,10 @@ class De {
6693
6699
  return e.split(/(\W+)/);
6694
6700
  }
6695
6701
  }
6696
- st.Text = De;
6697
- De.FIRST_CHAR_REGEX = /\S/;
6698
- De.DOUBLE_LINE = /\n\n/g;
6699
- De.ONE_LINE = /\n/g;
6702
+ st.Text = Fe;
6703
+ Fe.FIRST_CHAR_REGEX = /\S/;
6704
+ Fe.DOUBLE_LINE = /\n\n/g;
6705
+ Fe.ONE_LINE = /\n/g;
6700
6706
  Object.defineProperty(Kt, "__esModule", { value: !0 });
6701
6707
  Kt.Translate = void 0;
6702
6708
  const Go = st;
@@ -7481,7 +7487,7 @@ const Lt = class Lt extends jt {
7481
7487
  };
7482
7488
  Lt.MICROPHONE_RESET_TIMEOUT_MS = 300;
7483
7489
  let qt = Lt;
7484
- class Ce {
7490
+ class Ae {
7485
7491
  // prettier-ignore
7486
7492
  constructor(e, t, i, s) {
7487
7493
  this._attachments = [], this._fileCountLimit = 99, this._acceptedFormat = "", t.maxNumberOfFiles && (this._fileCountLimit = t.maxNumberOfFiles), this._toggleContainerDisplay = i, this._fileAttachmentsContainerRef = s, t.acceptedFormats && (this._acceptedFormat = t.acceptedFormats), setTimeout(() => {
@@ -7489,7 +7495,7 @@ class Ce {
7489
7495
  });
7490
7496
  }
7491
7497
  attemptAddFile(e, t) {
7492
- return Ce.isFileTypeValid(e, this._acceptedFormat) ? (this.addAttachmentBasedOnType(e, t, !0), !0) : !1;
7498
+ return Ae.isFileTypeValid(e, this._acceptedFormat) ? (this.addAttachmentBasedOnType(e, t, !0), !0) : !1;
7493
7499
  }
7494
7500
  static isFileTypeValid(e, t) {
7495
7501
  if (t === "") return !0;
@@ -7516,15 +7522,15 @@ class Ce {
7516
7522
  return t.startsWith("image") ? "image" : t.startsWith("audio") ? "audio" : "any";
7517
7523
  }
7518
7524
  addAttachmentBasedOnType(e, t, i) {
7519
- const s = Ce.getTypeFromBlob(e);
7525
+ const s = Ae.getTypeFromBlob(e);
7520
7526
  if (s === "image") {
7521
- const r = Ce.createImageAttachment(t);
7527
+ const r = Ae.createImageAttachment(t);
7522
7528
  this.addFileAttachment(e, "image", r, i);
7523
7529
  } else if (s === "audio") {
7524
7530
  const r = zt.createAudioAttachment(t);
7525
7531
  this.addFileAttachment(e, "audio", r, i);
7526
7532
  } else {
7527
- const r = Ce.createAnyFileAttachment(e.name);
7533
+ const r = Ae.createAnyFileAttachment(e.name);
7528
7534
  this.addFileAttachment(e, "any", r, i);
7529
7535
  }
7530
7536
  }
@@ -7542,7 +7548,7 @@ class Ce {
7542
7548
  }
7543
7549
  addFileAttachment(e, t, i, s) {
7544
7550
  var a;
7545
- const r = Ce.createContainer(i);
7551
+ const r = Ae.createContainer(i);
7546
7552
  if (this._attachments.length >= this._fileCountLimit) {
7547
7553
  const l = this._attachments[this._attachments.length - 1].removeButton;
7548
7554
  l == null || l.click();
@@ -7588,7 +7594,7 @@ const da = `<?xml version="1.0" encoding="utf-8"?>
7588
7594
  <svg viewBox="0 0 32 32" version="1.1" xmlns="http://www.w3.org/2000/svg">
7589
7595
  <title>stop</title>
7590
7596
  <path d="M5.92 24.096q0 0.832 0.576 1.408t1.44 0.608h16.128q0.832 0 1.44-0.608t0.576-1.408v-16.16q0-0.832-0.576-1.44t-1.44-0.576h-16.128q-0.832 0-1.44 0.576t-0.576 1.44v16.16z"></path>
7591
- </svg>`, _e = class _e extends Ce {
7597
+ </svg>`, we = class we extends Ae {
7592
7598
  // prettier-ignore
7593
7599
  constructor(e, t, i, s) {
7594
7600
  super(e, t, i, s);
@@ -7614,12 +7620,12 @@ const da = `<?xml version="1.0" encoding="utf-8"?>
7614
7620
  };
7615
7621
  }
7616
7622
  static createAudioAttachment(e) {
7617
- const t = _e.createAudioContainer();
7618
- return _e.addAudioElements(t, e), t;
7623
+ const t = we.createAudioContainer();
7624
+ return we.addAudioElements(t, e), t;
7619
7625
  }
7620
7626
  createTimer(e, t) {
7621
7627
  let i = 0;
7622
- const s = t !== void 0 && t < _e.TIMER_LIMIT_S ? t : _e.TIMER_LIMIT_S;
7628
+ const s = t !== void 0 && t < we.TIMER_LIMIT_S ? t : we.TIMER_LIMIT_S;
7623
7629
  return setInterval(() => {
7624
7630
  var a;
7625
7631
  i += 1, i === s && ((a = this.stopPlaceholderCallback) == null || a.call(this), this.clearTimer()), i === 600 && e.classList.add("audio-placeholder-text-4-digits");
@@ -7628,7 +7634,7 @@ const da = `<?xml version="1.0" encoding="utf-8"?>
7628
7634
  }, 1e3);
7629
7635
  }
7630
7636
  createPlaceholderAudioAttachment(e) {
7631
- const t = _e.createAudioContainer(), i = document.createElement("div");
7637
+ const t = we.createAudioContainer(), i = document.createElement("div");
7632
7638
  i.classList.add("audio-placeholder-text-3-digits");
7633
7639
  const s = document.createElement("div");
7634
7640
  s.classList.add("file-attachment-text-container", "audio-placeholder-text-3-digits-container"), s.appendChild(i);
@@ -7653,7 +7659,7 @@ const da = `<?xml version="1.0" encoding="utf-8"?>
7653
7659
  // prettier-ignore
7654
7660
  completePlaceholderAttachment(e, t) {
7655
7661
  const i = this._activePlaceholderAttachment;
7656
- i && (i.file = e, _e.addAudioElements(
7662
+ i && (i.file = e, we.addAudioElements(
7657
7663
  i.attachmentContainerElement.children[0],
7658
7664
  t
7659
7665
  ), i.removeButton = this.createRemoveAttachmentButton(i), i.attachmentContainerElement.appendChild(i.removeButton), this._activePlaceholderAttachment = void 0, this.clearTimer());
@@ -7669,12 +7675,12 @@ const da = `<?xml version="1.0" encoding="utf-8"?>
7669
7675
  (s = (i = (t = e.children[0]) == null ? void 0 : t.children) == null ? void 0 : i[0]) != null && s.classList.contains("stop-icon") && e.children[0].click();
7670
7676
  }
7671
7677
  };
7672
- _e.TIMER_LIMIT_S = 5999;
7673
- let zt = _e;
7678
+ we.TIMER_LIMIT_S = 5999;
7679
+ let zt = we;
7674
7680
  class ha {
7675
7681
  // prettier-ignore
7676
7682
  static create(e, t, i, s, r) {
7677
- return r === "audio" ? new zt(e, t, i, s) : new Ce(e, t, i, s);
7683
+ return r === "audio" ? new zt(e, t, i, s) : new Ae(e, t, i, s);
7678
7684
  }
7679
7685
  }
7680
7686
  class Yt {
@@ -7847,10 +7853,10 @@ class kt extends $t {
7847
7853
  e && (this._openModalOnce === void 0 || this._openModalOnce === !0) ? (e(), this._openModalOnce === !0 && (this._openModalOnce = !1)) : this.triggerImportPrompt(this._inputElement);
7848
7854
  }
7849
7855
  }
7850
- class Se {
7856
+ class Ce {
7851
7857
  static create(e, t, i) {
7852
- const s = Se.createElement(i);
7853
- Se.addEvents(s, e, t), e.appendChild(s);
7858
+ const s = Ce.createElement(i);
7859
+ Ce.addEvents(s, e, t), e.appendChild(s);
7854
7860
  }
7855
7861
  static createElement(e) {
7856
7862
  const t = document.createElement("div");
@@ -7858,13 +7864,13 @@ class Se {
7858
7864
  }
7859
7865
  static addEvents(e, t, i) {
7860
7866
  t.ondragenter = (s) => {
7861
- s.preventDefault(), Se.display(e);
7867
+ s.preventDefault(), Ce.display(e);
7862
7868
  }, e.ondragleave = (s) => {
7863
- s.preventDefault(), Se.hide(e);
7869
+ s.preventDefault(), Ce.hide(e);
7864
7870
  }, e.ondragover = (s) => {
7865
7871
  s.preventDefault();
7866
7872
  }, e.ondrop = (s) => {
7867
- s.preventDefault(), Se.uploadFile(i, s), Se.hide(e);
7873
+ s.preventDefault(), Ce.uploadFile(i, s), Ce.hide(e);
7868
7874
  };
7869
7875
  }
7870
7876
  static uploadFile(e, t) {
@@ -8092,7 +8098,7 @@ const A = class A extends $t {
8092
8098
  async programmaticSubmit(e) {
8093
8099
  typeof e == "string" && (e = ae.processSubmitUserMessage(e));
8094
8100
  const t = { text: e.text };
8095
- e.files && (t.files = Array.from(e.files).map((i) => ({ file: i, type: Ce.getTypeFromBlob(i) }))), setTimeout(() => this.attemptSubmit(t, !0));
8101
+ e.files && (t.files = Array.from(e.files).map((i) => ({ file: i, type: Ae.getTypeFromBlob(i) }))), setTimeout(() => this.attemptSubmit(t, !0));
8096
8102
  }
8097
8103
  // TO-DO - should be disabled when loading history
8098
8104
  async attemptSubmit(e, t = !1) {
@@ -8290,7 +8296,7 @@ class Mt {
8290
8296
  const d = ((c = s.audio) == null ? void 0 : c.fileType) || r.addType(e, t.recordAudio.files, "audio");
8291
8297
  s.microphone = { button: new ua(d, t.recordAudio) };
8292
8298
  }
8293
- return Se.isEnabled(r, e.dragAndDrop) && Se.create(i, r, e.dragAndDrop), r;
8299
+ return Ce.isEnabled(r, e.dragAndDrop) && Ce.create(i, r, e.dragAndDrop), r;
8294
8300
  }
8295
8301
  // prettier-ignore
8296
8302
  static createUploadButtons(e, t, i, s, r) {
@@ -8313,7 +8319,7 @@ class Ss {
8313
8319
  static createElements(e, t, i) {
8314
8320
  const s = document.createElement("div");
8315
8321
  s.id = "chat-view";
8316
- const r = new Ue(e, t, i);
8322
+ const r = new Ee(e, t, i);
8317
8323
  t.websocket && U.createConnection(t, r);
8318
8324
  const o = new Mt(e, r, t, s);
8319
8325
  return J.addElements(s, r.elementRef, o.elementRef), s;