@ronak27/superwise-chatbot-package 1.0.4 → 1.0.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +7 -3
- package/dist/react-chatbot.es.js +428 -232
- package/dist/react-chatbot.umd.js +194 -4
- package/package.json +1 -1
package/dist/react-chatbot.es.js
CHANGED
|
@@ -1,46 +1,46 @@
|
|
|
1
|
-
import
|
|
2
|
-
var Z = { exports: {} },
|
|
1
|
+
import le, { memo as ae, useState as C, useEffect as T, useRef as ee, useMemo as ce, useCallback as J } from "react";
|
|
2
|
+
var Z = { exports: {} }, z = {};
|
|
3
3
|
var te;
|
|
4
|
-
function
|
|
5
|
-
if (te) return
|
|
4
|
+
function de() {
|
|
5
|
+
if (te) return z;
|
|
6
6
|
te = 1;
|
|
7
|
-
var
|
|
8
|
-
function w(x,
|
|
7
|
+
var o = /* @__PURE__ */ Symbol.for("react.transitional.element"), i = /* @__PURE__ */ Symbol.for("react.fragment");
|
|
8
|
+
function w(x, a, g) {
|
|
9
9
|
var p = null;
|
|
10
|
-
if (
|
|
11
|
-
|
|
12
|
-
for (var l in
|
|
13
|
-
l !== "key" && (
|
|
14
|
-
} else
|
|
15
|
-
return
|
|
16
|
-
$$typeof:
|
|
10
|
+
if (g !== void 0 && (p = "" + g), a.key !== void 0 && (p = "" + a.key), "key" in a) {
|
|
11
|
+
g = {};
|
|
12
|
+
for (var l in a)
|
|
13
|
+
l !== "key" && (g[l] = a[l]);
|
|
14
|
+
} else g = a;
|
|
15
|
+
return a = g.ref, {
|
|
16
|
+
$$typeof: o,
|
|
17
17
|
type: x,
|
|
18
18
|
key: p,
|
|
19
|
-
ref:
|
|
20
|
-
props:
|
|
19
|
+
ref: a !== void 0 ? a : null,
|
|
20
|
+
props: g
|
|
21
21
|
};
|
|
22
22
|
}
|
|
23
|
-
return
|
|
23
|
+
return z.Fragment = i, z.jsx = w, z.jsxs = w, z;
|
|
24
24
|
}
|
|
25
|
-
var
|
|
25
|
+
var F = {};
|
|
26
26
|
var re;
|
|
27
|
-
function
|
|
27
|
+
function pe() {
|
|
28
28
|
return re || (re = 1, process.env.NODE_ENV !== "production" && (function() {
|
|
29
|
-
function
|
|
29
|
+
function o(e) {
|
|
30
30
|
if (e == null) return null;
|
|
31
31
|
if (typeof e == "function")
|
|
32
32
|
return e.$$typeof === q ? null : e.displayName || e.name || null;
|
|
33
33
|
if (typeof e == "string") return e;
|
|
34
34
|
switch (e) {
|
|
35
|
-
case
|
|
35
|
+
case I:
|
|
36
36
|
return "Fragment";
|
|
37
37
|
case X:
|
|
38
38
|
return "Profiler";
|
|
39
|
-
case
|
|
39
|
+
case P:
|
|
40
40
|
return "StrictMode";
|
|
41
41
|
case _:
|
|
42
42
|
return "Suspense";
|
|
43
|
-
case
|
|
43
|
+
case U:
|
|
44
44
|
return "SuspenseList";
|
|
45
45
|
case $:
|
|
46
46
|
return "Activity";
|
|
@@ -49,21 +49,21 @@ function de() {
|
|
|
49
49
|
switch (typeof e.tag == "number" && console.error(
|
|
50
50
|
"Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."
|
|
51
51
|
), e.$$typeof) {
|
|
52
|
-
case
|
|
52
|
+
case B:
|
|
53
53
|
return "Portal";
|
|
54
|
-
case
|
|
54
|
+
case O:
|
|
55
55
|
return e.displayName || "Context";
|
|
56
|
-
case
|
|
56
|
+
case S:
|
|
57
57
|
return (e._context.displayName || "Context") + ".Consumer";
|
|
58
|
-
case
|
|
58
|
+
case V:
|
|
59
59
|
var r = e.render;
|
|
60
60
|
return e = e.displayName, e || (e = r.displayName || r.name || "", e = e !== "" ? "ForwardRef(" + e + ")" : "ForwardRef"), e;
|
|
61
|
-
case
|
|
62
|
-
return r = e.displayName || null, r !== null ? r :
|
|
63
|
-
case
|
|
61
|
+
case N:
|
|
62
|
+
return r = e.displayName || null, r !== null ? r : o(e.type) || "Memo";
|
|
63
|
+
case A:
|
|
64
64
|
r = e._payload, e = e._init;
|
|
65
65
|
try {
|
|
66
|
-
return
|
|
66
|
+
return o(e(r));
|
|
67
67
|
} catch {
|
|
68
68
|
}
|
|
69
69
|
}
|
|
@@ -81,30 +81,30 @@ function de() {
|
|
|
81
81
|
}
|
|
82
82
|
if (r) {
|
|
83
83
|
r = console;
|
|
84
|
-
var d = r.error,
|
|
84
|
+
var d = r.error, h = typeof Symbol == "function" && Symbol.toStringTag && e[Symbol.toStringTag] || e.constructor.name || "Object";
|
|
85
85
|
return d.call(
|
|
86
86
|
r,
|
|
87
87
|
"The provided key is an unsupported type %s. This value must be coerced to a string before using it here.",
|
|
88
|
-
|
|
88
|
+
h
|
|
89
89
|
), i(e);
|
|
90
90
|
}
|
|
91
91
|
}
|
|
92
92
|
function x(e) {
|
|
93
|
-
if (e ===
|
|
94
|
-
if (typeof e == "object" && e !== null && e.$$typeof ===
|
|
93
|
+
if (e === I) return "<>";
|
|
94
|
+
if (typeof e == "object" && e !== null && e.$$typeof === A)
|
|
95
95
|
return "<...>";
|
|
96
96
|
try {
|
|
97
|
-
var r =
|
|
97
|
+
var r = o(e);
|
|
98
98
|
return r ? "<" + r + ">" : "<...>";
|
|
99
99
|
} catch {
|
|
100
100
|
return "<...>";
|
|
101
101
|
}
|
|
102
102
|
}
|
|
103
|
-
function
|
|
103
|
+
function a() {
|
|
104
104
|
var e = H.A;
|
|
105
105
|
return e === null ? null : e.getOwner();
|
|
106
106
|
}
|
|
107
|
-
function
|
|
107
|
+
function g() {
|
|
108
108
|
return Error("react-stack-top-frame");
|
|
109
109
|
}
|
|
110
110
|
function p(e) {
|
|
@@ -127,20 +127,20 @@ function de() {
|
|
|
127
127
|
});
|
|
128
128
|
}
|
|
129
129
|
function c() {
|
|
130
|
-
var e =
|
|
130
|
+
var e = o(this.type);
|
|
131
131
|
return G[e] || (G[e] = !0, console.error(
|
|
132
132
|
"Accessing element.ref was removed in React 19. ref is now a regular prop. It will be removed from the JSX Element type in a future release."
|
|
133
133
|
)), e = this.props.ref, e !== void 0 ? e : null;
|
|
134
134
|
}
|
|
135
|
-
function
|
|
136
|
-
var
|
|
135
|
+
function m(e, r, d, h, v, M) {
|
|
136
|
+
var f = d.ref;
|
|
137
137
|
return e = {
|
|
138
|
-
$$typeof:
|
|
138
|
+
$$typeof: k,
|
|
139
139
|
type: e,
|
|
140
140
|
key: r,
|
|
141
141
|
props: d,
|
|
142
|
-
_owner:
|
|
143
|
-
}, (
|
|
142
|
+
_owner: h
|
|
143
|
+
}, (f !== void 0 ? f : null) !== null ? Object.defineProperty(e, "ref", {
|
|
144
144
|
enumerable: !1,
|
|
145
145
|
get: c
|
|
146
146
|
}) : Object.defineProperty(e, "ref", { enumerable: !1, value: null }), e._store = {}, Object.defineProperty(e._store, "validated", {
|
|
@@ -165,116 +165,116 @@ function de() {
|
|
|
165
165
|
value: M
|
|
166
166
|
}), Object.freeze && (Object.freeze(e.props), Object.freeze(e)), e;
|
|
167
167
|
}
|
|
168
|
-
function
|
|
169
|
-
var
|
|
170
|
-
if (
|
|
171
|
-
if (
|
|
172
|
-
if (Q(
|
|
173
|
-
for (
|
|
174
|
-
y(h
|
|
175
|
-
Object.freeze && Object.freeze(
|
|
168
|
+
function u(e, r, d, h, v, M) {
|
|
169
|
+
var f = r.children;
|
|
170
|
+
if (f !== void 0)
|
|
171
|
+
if (h)
|
|
172
|
+
if (Q(f)) {
|
|
173
|
+
for (h = 0; h < f.length; h++)
|
|
174
|
+
y(f[h]);
|
|
175
|
+
Object.freeze && Object.freeze(f);
|
|
176
176
|
} else
|
|
177
177
|
console.error(
|
|
178
178
|
"React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead."
|
|
179
179
|
);
|
|
180
|
-
else y(
|
|
180
|
+
else y(f);
|
|
181
181
|
if (D.call(r, "key")) {
|
|
182
|
-
|
|
183
|
-
var
|
|
184
|
-
return
|
|
182
|
+
f = o(e);
|
|
183
|
+
var b = Object.keys(r).filter(function(ie) {
|
|
184
|
+
return ie !== "key";
|
|
185
185
|
});
|
|
186
|
-
|
|
186
|
+
h = 0 < b.length ? "{key: someKey, " + b.join(": ..., ") + ": ...}" : "{key: someKey}", n[f + h] || (b = 0 < b.length ? "{" + b.join(": ..., ") + ": ...}" : "{}", console.error(
|
|
187
187
|
`A props object containing a "key" prop is being spread into JSX:
|
|
188
188
|
let props = %s;
|
|
189
189
|
<%s {...props} />
|
|
190
190
|
React keys must be passed directly to JSX without using spread:
|
|
191
191
|
let props = %s;
|
|
192
192
|
<%s key={someKey} {...props} />`,
|
|
193
|
-
g,
|
|
194
193
|
h,
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
194
|
+
f,
|
|
195
|
+
b,
|
|
196
|
+
f
|
|
197
|
+
), n[f + h] = !0);
|
|
198
198
|
}
|
|
199
|
-
if (
|
|
199
|
+
if (f = null, d !== void 0 && (w(d), f = "" + d), p(r) && (w(r.key), f = "" + r.key), "key" in r) {
|
|
200
200
|
d = {};
|
|
201
201
|
for (var L in r)
|
|
202
202
|
L !== "key" && (d[L] = r[L]);
|
|
203
203
|
} else d = r;
|
|
204
|
-
return
|
|
204
|
+
return f && l(
|
|
205
205
|
d,
|
|
206
206
|
typeof e == "function" ? e.displayName || e.name || "Unknown" : e
|
|
207
|
-
),
|
|
207
|
+
), m(
|
|
208
208
|
e,
|
|
209
|
-
|
|
209
|
+
f,
|
|
210
210
|
d,
|
|
211
|
-
|
|
211
|
+
a(),
|
|
212
212
|
v,
|
|
213
213
|
M
|
|
214
214
|
);
|
|
215
215
|
}
|
|
216
216
|
function y(e) {
|
|
217
|
-
|
|
217
|
+
j(e) ? e._store && (e._store.validated = 1) : typeof e == "object" && e !== null && e.$$typeof === A && (e._payload.status === "fulfilled" ? j(e._payload.value) && e._payload.value._store && (e._payload.value._store.validated = 1) : e._store && (e._store.validated = 1));
|
|
218
218
|
}
|
|
219
|
-
function
|
|
220
|
-
return typeof e == "object" && e !== null && e.$$typeof ===
|
|
219
|
+
function j(e) {
|
|
220
|
+
return typeof e == "object" && e !== null && e.$$typeof === k;
|
|
221
221
|
}
|
|
222
|
-
var
|
|
222
|
+
var R = le, k = /* @__PURE__ */ Symbol.for("react.transitional.element"), B = /* @__PURE__ */ Symbol.for("react.portal"), I = /* @__PURE__ */ Symbol.for("react.fragment"), P = /* @__PURE__ */ Symbol.for("react.strict_mode"), X = /* @__PURE__ */ Symbol.for("react.profiler"), S = /* @__PURE__ */ Symbol.for("react.consumer"), O = /* @__PURE__ */ Symbol.for("react.context"), V = /* @__PURE__ */ Symbol.for("react.forward_ref"), _ = /* @__PURE__ */ Symbol.for("react.suspense"), U = /* @__PURE__ */ Symbol.for("react.suspense_list"), N = /* @__PURE__ */ Symbol.for("react.memo"), A = /* @__PURE__ */ Symbol.for("react.lazy"), $ = /* @__PURE__ */ Symbol.for("react.activity"), q = /* @__PURE__ */ Symbol.for("react.client.reference"), H = R.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE, D = Object.prototype.hasOwnProperty, Q = Array.isArray, E = console.createTask ? console.createTask : function() {
|
|
223
223
|
return null;
|
|
224
224
|
};
|
|
225
|
-
|
|
225
|
+
R = {
|
|
226
226
|
react_stack_bottom_frame: function(e) {
|
|
227
227
|
return e();
|
|
228
228
|
}
|
|
229
229
|
};
|
|
230
|
-
var K, G = {}, W =
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
)(), Y =
|
|
234
|
-
|
|
235
|
-
var
|
|
236
|
-
return
|
|
230
|
+
var K, G = {}, W = R.react_stack_bottom_frame.bind(
|
|
231
|
+
R,
|
|
232
|
+
g
|
|
233
|
+
)(), Y = E(x(g)), n = {};
|
|
234
|
+
F.Fragment = I, F.jsx = function(e, r, d) {
|
|
235
|
+
var h = 1e4 > H.recentlyCreatedOwnerStacks++;
|
|
236
|
+
return u(
|
|
237
237
|
e,
|
|
238
238
|
r,
|
|
239
239
|
d,
|
|
240
240
|
!1,
|
|
241
|
-
|
|
242
|
-
|
|
241
|
+
h ? Error("react-stack-top-frame") : W,
|
|
242
|
+
h ? E(x(e)) : Y
|
|
243
243
|
);
|
|
244
|
-
},
|
|
245
|
-
var
|
|
246
|
-
return
|
|
244
|
+
}, F.jsxs = function(e, r, d) {
|
|
245
|
+
var h = 1e4 > H.recentlyCreatedOwnerStacks++;
|
|
246
|
+
return u(
|
|
247
247
|
e,
|
|
248
248
|
r,
|
|
249
249
|
d,
|
|
250
250
|
!0,
|
|
251
|
-
|
|
252
|
-
|
|
251
|
+
h ? Error("react-stack-top-frame") : W,
|
|
252
|
+
h ? E(x(e)) : Y
|
|
253
253
|
);
|
|
254
254
|
};
|
|
255
|
-
})()),
|
|
255
|
+
})()), F;
|
|
256
256
|
}
|
|
257
|
-
var
|
|
258
|
-
function
|
|
259
|
-
return
|
|
257
|
+
var ne;
|
|
258
|
+
function me() {
|
|
259
|
+
return ne || (ne = 1, process.env.NODE_ENV === "production" ? Z.exports = de() : Z.exports = pe()), Z.exports;
|
|
260
260
|
}
|
|
261
|
-
var t =
|
|
262
|
-
async function ue(
|
|
263
|
-
const
|
|
261
|
+
var t = me();
|
|
262
|
+
async function ue(o, i = [], w = [], x = "", a = "") {
|
|
263
|
+
const g = "https://sage-api-ttyw-stage.superwise.ai/api/v1/chat", p = Array.isArray(i) ? i.map((c) => ({
|
|
264
264
|
role: c.role,
|
|
265
265
|
message: c.content != null ? c.content : ""
|
|
266
266
|
})) : [], l = {
|
|
267
|
-
user_input:
|
|
267
|
+
user_input: o,
|
|
268
268
|
chat_history: p,
|
|
269
269
|
mql_df: Array.isArray(w) ? w : [],
|
|
270
270
|
agent_id: x,
|
|
271
|
-
discovery_agent_id:
|
|
271
|
+
discovery_agent_id: a,
|
|
272
272
|
utm_source: "Web",
|
|
273
273
|
utm_medium: "chatbot"
|
|
274
274
|
};
|
|
275
275
|
console.log("Sending payload:", l);
|
|
276
276
|
try {
|
|
277
|
-
const c = await fetch(
|
|
277
|
+
const c = await fetch(g, {
|
|
278
278
|
method: "POST",
|
|
279
279
|
headers: {
|
|
280
280
|
"Content-Type": "application/json",
|
|
@@ -283,28 +283,28 @@ async function ue(s, i = [], w = [], x = "", n = "") {
|
|
|
283
283
|
body: JSON.stringify(l)
|
|
284
284
|
});
|
|
285
285
|
if (console.log("Response status:", c.status), console.log("Response headers:", c.headers), !c.ok) {
|
|
286
|
-
const
|
|
287
|
-
return console.error("API Error Response:",
|
|
286
|
+
const j = await c.text();
|
|
287
|
+
return console.error("API Error Response:", j), { reply: `❌ API Error ${c.status}: ${j}`, mqlDf: [] };
|
|
288
288
|
}
|
|
289
|
-
const
|
|
290
|
-
console.log("API Response Data:",
|
|
291
|
-
let
|
|
292
|
-
return
|
|
289
|
+
const m = await c.json();
|
|
290
|
+
console.log("API Response Data:", m);
|
|
291
|
+
let u = "⚠️ No reply from server.", y = [];
|
|
292
|
+
return m.chat_response ? u = m.chat_response : m.success && m.data?.chat_response ? u = m.data.chat_response : m.message && (u = m.message), m.mql_df ? y = m.mql_df : m.data?.mql_df && (y = m.data.mql_df), u.includes("Parameters:") && (u = u.split("Parameters:")[0].trim()), { reply: u, mqlDf: y };
|
|
293
293
|
} catch (c) {
|
|
294
294
|
return console.error("API call failed:", c), c.name === "TypeError" && c.message.includes("fetch") ? { reply: "⚠️ Network error. Please check your connection.", mqlDf: [] } : { reply: `⚠️ API request failed: ${c.message}`, mqlDf: [] };
|
|
295
295
|
}
|
|
296
296
|
}
|
|
297
|
-
async function
|
|
298
|
-
const x = "https://sage-api-ttyw-stage.superwise.ai/pdf",
|
|
297
|
+
async function ge(o, i = null, w = []) {
|
|
298
|
+
const x = "https://sage-api-ttyw-stage.superwise.ai/pdf", a = Array.isArray(o) && o.length > 0 ? o[0] : i || {
|
|
299
299
|
name: "User",
|
|
300
300
|
email: "user@example.com",
|
|
301
301
|
summary: "Chat conversation summary"
|
|
302
|
-
},
|
|
302
|
+
}, g = Array.isArray(w) ? w.map((l) => ({
|
|
303
303
|
role: l.role,
|
|
304
304
|
message: l.content != null ? l.content : ""
|
|
305
305
|
})) : [], p = {
|
|
306
|
-
lead_row:
|
|
307
|
-
chat_history:
|
|
306
|
+
lead_row: a,
|
|
307
|
+
chat_history: g
|
|
308
308
|
};
|
|
309
309
|
console.log("Downloading PDF with payload:", p);
|
|
310
310
|
try {
|
|
@@ -320,13 +320,13 @@ async function me(s, i = null, w = []) {
|
|
|
320
320
|
const y = await l.text();
|
|
321
321
|
throw console.error("PDF API Error Response:", y), new Error(`PDF API Error ${l.status}: ${y}`);
|
|
322
322
|
}
|
|
323
|
-
const c = await l.blob(),
|
|
324
|
-
return
|
|
323
|
+
const c = await l.blob(), m = window.URL.createObjectURL(c), u = document.createElement("a");
|
|
324
|
+
return u.href = m, u.download = `chatbot-report-${(/* @__PURE__ */ new Date()).toISOString().split("T")[0]}.pdf`, document.body.appendChild(u), u.click(), document.body.removeChild(u), window.URL.revokeObjectURL(m), !0;
|
|
325
325
|
} catch (l) {
|
|
326
326
|
throw console.error("PDF download failed:", l), l;
|
|
327
327
|
}
|
|
328
328
|
}
|
|
329
|
-
const
|
|
329
|
+
const s = {
|
|
330
330
|
container: {
|
|
331
331
|
position: "fixed",
|
|
332
332
|
bottom: "0px",
|
|
@@ -574,22 +574,218 @@ const a = {
|
|
|
574
574
|
fontWeight: "500",
|
|
575
575
|
margin: 0
|
|
576
576
|
}
|
|
577
|
-
}, se = "", fe = "";
|
|
578
|
-
|
|
579
|
-
|
|
577
|
+
}, fe = `@import url('https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap');\r
|
|
578
|
+
\r
|
|
579
|
+
.sw-ttyw-chatbot {\r
|
|
580
|
+
--swttyw-primary-color: #000;\r
|
|
581
|
+
--swttyw-avatar-image: url('');\r
|
|
582
|
+
--swttyw-user-avatar-image: url('');\r
|
|
583
|
+
--swttyw-background-color: #F7F7F7;\r
|
|
584
|
+
--swttyw-header-font-size: 16px;\r
|
|
585
|
+
--swttyw-body-font-size: 15px;\r
|
|
586
|
+
--swttyw-footer-font-size: 16px;\r
|
|
587
|
+
--swttyw-user-background-image: url('');\r
|
|
588
|
+
}\r
|
|
589
|
+
\r
|
|
590
|
+
.sw-ttyw-chatbot ::-webkit-scrollbar {\r
|
|
591
|
+
width: 3px;\r
|
|
592
|
+
}\r
|
|
593
|
+
\r
|
|
594
|
+
.sw-ttyw-chatbot ::-webkit-scrollbar-track {\r
|
|
595
|
+
background: transparent;\r
|
|
596
|
+
}\r
|
|
597
|
+
\r
|
|
598
|
+
.sw-ttyw-chatbot ::-webkit-scrollbar-thumb {\r
|
|
599
|
+
background: var(--swttyw-primary-color);\r
|
|
600
|
+
}\r
|
|
601
|
+
\r
|
|
602
|
+
.sw-ttyw-chatbot ::-webkit-scrollbar-thumb:hover {\r
|
|
603
|
+
background: var(--swttyw-primary-color);\r
|
|
604
|
+
}\r
|
|
605
|
+
\r
|
|
606
|
+
.typing {\r
|
|
607
|
+
display: inline-block !important;\r
|
|
608
|
+
width: 0.8rem !important;\r
|
|
609
|
+
height: 0.8rem !important;\r
|
|
610
|
+
min-width: 0.8rem !important;\r
|
|
611
|
+
min-height: 0.8rem !important;\r
|
|
612
|
+
max-width: 0.8rem !important;\r
|
|
613
|
+
max-height: 0.8rem !important;\r
|
|
614
|
+
margin-right: 0.5rem !important;\r
|
|
615
|
+
box-sizing: border-box !important;\r
|
|
616
|
+
background: #ccc !important;\r
|
|
617
|
+
border-radius: 50% !important;\r
|
|
618
|
+
}\r
|
|
619
|
+
\r
|
|
620
|
+
.typing.typing-1 {\r
|
|
621
|
+
-webkit-animation: typingAlt 1.4s infinite !important;\r
|
|
622
|
+
animation: typingAlt 1.4s infinite !important;\r
|
|
623
|
+
}\r
|
|
624
|
+
\r
|
|
625
|
+
.typing.typing-2 {\r
|
|
626
|
+
-webkit-animation: typingAlt 1.4s 0.2s infinite !important;\r
|
|
627
|
+
animation: typingAlt 1.4s 0.2s infinite !important;\r
|
|
628
|
+
}\r
|
|
629
|
+
\r
|
|
630
|
+
.typing.typing-3 {\r
|
|
631
|
+
-webkit-animation: typingAlt 1.4s 0.4s infinite !important;\r
|
|
632
|
+
animation: typingAlt 1.4s 0.4s infinite !important;\r
|
|
633
|
+
}\r
|
|
634
|
+
\r
|
|
635
|
+
.typing-cursor {\r
|
|
636
|
+
animation: blink 1s infinite;\r
|
|
637
|
+
color: var(--swttyw-primary-color);\r
|
|
638
|
+
font-weight: bold;\r
|
|
639
|
+
}\r
|
|
640
|
+
\r
|
|
641
|
+
@keyframes blink {\r
|
|
642
|
+
0%, 50% { opacity: 1; }\r
|
|
643
|
+
51%, 100% { opacity: 0; }\r
|
|
644
|
+
}\r
|
|
645
|
+
\r
|
|
646
|
+
/* Error message styling */\r
|
|
647
|
+
.swttyw-input-error {\r
|
|
648
|
+
background-color: #FEE8E8;\r
|
|
649
|
+
border: 1px solid #FDC2C2;\r
|
|
650
|
+
border-radius: 8px;\r
|
|
651
|
+
padding: 12px 16px;\r
|
|
652
|
+
margin: 8px 0;\r
|
|
653
|
+
display: flex;\r
|
|
654
|
+
align-items: center;\r
|
|
655
|
+
gap: 8px;\r
|
|
656
|
+
color: #E04F4F;\r
|
|
657
|
+
font-size: 14px;\r
|
|
658
|
+
line-height: 1.4;\r
|
|
659
|
+
}\r
|
|
660
|
+
\r
|
|
661
|
+
.swttyw-input-error .error-icon {\r
|
|
662
|
+
color: #F59E0B;\r
|
|
663
|
+
font-size: 16px;\r
|
|
664
|
+
flex-shrink: 0;\r
|
|
665
|
+
}\r
|
|
666
|
+
\r
|
|
667
|
+
/* Validation message in messages area */\r
|
|
668
|
+
.sw-ttyw-validation-message {\r
|
|
669
|
+
background-color: #FEE8E8;\r
|
|
670
|
+
border: 1px solid #FDC2C2;\r
|
|
671
|
+
border-radius: 8px;\r
|
|
672
|
+
padding: 12px 16px;\r
|
|
673
|
+
margin: 8px 16px;\r
|
|
674
|
+
display: flex;\r
|
|
675
|
+
align-items: center;\r
|
|
676
|
+
gap: 8px;\r
|
|
677
|
+
color: #E04F4F;\r
|
|
678
|
+
font-size: 14px;\r
|
|
679
|
+
line-height: 1.4;\r
|
|
680
|
+
animation: slideIn 0.3s ease-out;\r
|
|
681
|
+
}\r
|
|
682
|
+
\r
|
|
683
|
+
.sw-ttyw-validation-message .error-icon {\r
|
|
684
|
+
color: #F59E0B;\r
|
|
685
|
+
font-size: 16px;\r
|
|
686
|
+
flex-shrink: 0;\r
|
|
687
|
+
}\r
|
|
688
|
+
\r
|
|
689
|
+
@keyframes slideIn {\r
|
|
690
|
+
from {\r
|
|
691
|
+
opacity: 0;\r
|
|
692
|
+
transform: translateY(-10px);\r
|
|
693
|
+
}\r
|
|
694
|
+
to {\r
|
|
695
|
+
opacity: 1;\r
|
|
696
|
+
transform: translateY(0);\r
|
|
697
|
+
}\r
|
|
698
|
+
}\r
|
|
699
|
+
\r
|
|
700
|
+
@-webkit-keyframes typingAlt {\r
|
|
701
|
+
0%, 60%, 100% {\r
|
|
702
|
+
transform: translateY(0) scale(1);\r
|
|
703
|
+
opacity: 0.4;\r
|
|
704
|
+
}\r
|
|
705
|
+
30% {\r
|
|
706
|
+
transform: translateY(-10px) scale(1.2);\r
|
|
707
|
+
opacity: 1;\r
|
|
708
|
+
}\r
|
|
709
|
+
}\r
|
|
710
|
+
\r
|
|
711
|
+
@keyframes typingAlt {\r
|
|
712
|
+
0%, 60%, 100% {\r
|
|
713
|
+
transform: translateY(0) scale(1);\r
|
|
714
|
+
opacity: 0.4;\r
|
|
715
|
+
}\r
|
|
716
|
+
30% {\r
|
|
717
|
+
transform: translateY(-10px) scale(1.2);\r
|
|
718
|
+
opacity: 1;\r
|
|
719
|
+
}\r
|
|
720
|
+
}\r
|
|
721
|
+
\r
|
|
722
|
+
/* Ensure user messages have black background */\r
|
|
723
|
+
.sw-ttyw-message.self {\r
|
|
724
|
+
background: #000000 !important;\r
|
|
725
|
+
color: white !important;\r
|
|
726
|
+
margin: 1rem 1rem 1rem auto !important;\r
|
|
727
|
+
border-radius: 1.125rem 1.125rem 0 1.125rem !important;\r
|
|
728
|
+
max-width: 80% !important;\r
|
|
729
|
+
display: table;\r
|
|
730
|
+
}\r
|
|
731
|
+
\r
|
|
732
|
+
/* Avatar positioning for user messages */\r
|
|
733
|
+
.sw-ttyw-message.self .message-avatar {\r
|
|
734
|
+
right: -28px !important;\r
|
|
735
|
+
left: auto !important;\r
|
|
736
|
+
}\r
|
|
737
|
+
\r
|
|
738
|
+
/* Avatar positioning for AI messages */\r
|
|
739
|
+
.sw-ttyw-message.other .message-avatar {\r
|
|
740
|
+
left: -28px !important;\r
|
|
741
|
+
right: auto !important;\r
|
|
742
|
+
display: table;\r
|
|
743
|
+
}\r
|
|
744
|
+
\r
|
|
745
|
+
/* Ensure proper spacing for message content */\r
|
|
746
|
+
.sw-ttyw-message .message-content {\r
|
|
747
|
+
margin-left: 0 !important;\r
|
|
748
|
+
margin-right: 0 !important;\r
|
|
749
|
+
padding-left: 0 !important;\r
|
|
750
|
+
padding-right: 0 !important;\r
|
|
751
|
+
}\r
|
|
752
|
+
\r
|
|
753
|
+
/* Empty state styling */\r
|
|
754
|
+
.sw-ttyw-empty-state {\r
|
|
755
|
+
background-color: var(--swttyw-background-color) !important;\r
|
|
756
|
+
transition: opacity 0.3s ease-in-out !important;\r
|
|
757
|
+
}\r
|
|
758
|
+
\r
|
|
759
|
+
.sw-ttyw-empty-state:hover {\r
|
|
760
|
+
opacity: 0.5 !important;\r
|
|
761
|
+
}\r
|
|
762
|
+
\r
|
|
763
|
+
/* Ensure empty state doesn't interfere with scrolling */\r
|
|
764
|
+
.sw-ttyw-messages:has(.sw-ttyw-empty-state) {\r
|
|
765
|
+
overflow: hidden !important;\r
|
|
766
|
+
}\r
|
|
767
|
+
`, se = "", he = "", oe = "superwise-chatbot-package-css";
|
|
768
|
+
function xe() {
|
|
769
|
+
if (typeof document > "u" || document.getElementById(oe)) return;
|
|
770
|
+
const o = document.createElement("style");
|
|
771
|
+
o.id = oe, o.textContent = fe, document.head.appendChild(o);
|
|
772
|
+
}
|
|
773
|
+
xe();
|
|
774
|
+
function ye(o) {
|
|
775
|
+
return o === "human" ? { ...s.message, ...s.messageSelf } : { ...s.message, ...s.messageOther };
|
|
580
776
|
}
|
|
581
|
-
const
|
|
582
|
-
const [
|
|
583
|
-
|
|
777
|
+
const Ce = ae(function({ text: i, speed: w = 10, onComplete: x }) {
|
|
778
|
+
const [a, g] = C(""), [p, l] = C(!1);
|
|
779
|
+
T(() => {
|
|
584
780
|
if (!i) return;
|
|
585
|
-
|
|
586
|
-
let
|
|
587
|
-
const
|
|
588
|
-
|
|
781
|
+
g(""), l(!1);
|
|
782
|
+
let m = 0;
|
|
783
|
+
const u = setInterval(() => {
|
|
784
|
+
m < i.length ? (g(i.slice(0, m + 1)), m++) : (l(!0), clearInterval(u), x && x());
|
|
589
785
|
}, w);
|
|
590
|
-
return () => clearInterval(
|
|
786
|
+
return () => clearInterval(u);
|
|
591
787
|
}, [i, w, x]);
|
|
592
|
-
const c = (
|
|
788
|
+
const c = (m) => m.replace(/\[bold\](.*?)\[\/bold\]/g, "<strong>$1</strong>").replace(/\*\*(.*?)\*\*/g, "<strong>$1</strong>").replace(/\*(.*?)\*/g, "<em>$1</em>").replace(/(?:^|\n)-\s+/g, `
|
|
593
789
|
• `).replace(/\n/g, "<br/>").replace(/(\d+\.\s)/g, "<br/>$1").replace(/(\*\s)/g, "<br/>$1");
|
|
594
790
|
return /* @__PURE__ */ t.jsx(
|
|
595
791
|
"div",
|
|
@@ -600,14 +796,14 @@ const we = ne(function({ text: i, speed: w = 10, onComplete: x }) {
|
|
|
600
796
|
wordBreak: "break-word"
|
|
601
797
|
},
|
|
602
798
|
dangerouslySetInnerHTML: {
|
|
603
|
-
__html: c(
|
|
799
|
+
__html: c(a) + (p ? "" : '<span class="typing-cursor">|</span>')
|
|
604
800
|
}
|
|
605
801
|
}
|
|
606
802
|
);
|
|
607
|
-
}),
|
|
608
|
-
const
|
|
609
|
-
return /* @__PURE__ */ t.jsxs("div", { className:
|
|
610
|
-
/* @__PURE__ */ t.jsx("div", { className: "message-avatar", style:
|
|
803
|
+
}), be = ae(function({ msg: i, isTyping: w = !1, onTypingComplete: x }) {
|
|
804
|
+
const a = i.from === "human" ? "sw-ttyw-message self" : "sw-ttyw-message other";
|
|
805
|
+
return /* @__PURE__ */ t.jsxs("div", { className: a, style: ye(i.from), children: [
|
|
806
|
+
/* @__PURE__ */ t.jsx("div", { className: "message-avatar", style: s.messageAvatar, children: i.from === "human" ? /* @__PURE__ */ t.jsxs("svg", { width: "20", height: "20", viewBox: "0 0 24 24", fill: "black", xmlns: "http://www.w3.org/2000/svg", children: [
|
|
611
807
|
/* @__PURE__ */ t.jsx("path", { d: "M20 21V19C20 17.9391 19.5786 16.9217 18.8284 16.1716C18.0783 15.4214 17.0609 15 16 15H8C6.93913 15 5.92172 15.4214 5.17157 16.1716C4.42143 16.9217 4 17.9391 4 19V21", fill: "black" }),
|
|
612
808
|
/* @__PURE__ */ t.jsx("circle", { cx: "12", cy: "7", r: "4", fill: "black" })
|
|
613
809
|
] }) : /* @__PURE__ */ t.jsx(
|
|
@@ -623,7 +819,7 @@ const we = ne(function({ text: i, speed: w = 10, onComplete: x }) {
|
|
|
623
819
|
}
|
|
624
820
|
}
|
|
625
821
|
) }),
|
|
626
|
-
/* @__PURE__ */ t.jsx("div", { className: "message-content", style:
|
|
822
|
+
/* @__PURE__ */ t.jsx("div", { className: "message-content", style: s.messageContent, children: i.from === "ai" && w ? /* @__PURE__ */ t.jsx(Ce, { text: i.text, speed: 20, onComplete: x }) : /* @__PURE__ */ t.jsx(
|
|
627
823
|
"div",
|
|
628
824
|
{
|
|
629
825
|
style: {
|
|
@@ -639,25 +835,25 @@ const we = ne(function({ text: i, speed: w = 10, onComplete: x }) {
|
|
|
639
835
|
}
|
|
640
836
|
) })
|
|
641
837
|
] });
|
|
642
|
-
}),
|
|
643
|
-
const
|
|
644
|
-
return
|
|
645
|
-
},
|
|
646
|
-
const
|
|
647
|
-
`👋 ${
|
|
648
|
-
`👋 ${
|
|
649
|
-
`👋 ${
|
|
650
|
-
`👋 ${
|
|
651
|
-
`👋 ${
|
|
838
|
+
}), ke = () => {
|
|
839
|
+
const o = (/* @__PURE__ */ new Date()).getHours();
|
|
840
|
+
return o >= 5 && o < 12 ? "Good morning" : o >= 12 && o < 17 ? "Good afternoon" : (o >= 17 && o < 21, "Good evening");
|
|
841
|
+
}, ve = () => {
|
|
842
|
+
const o = ke(), i = [
|
|
843
|
+
`👋 ${o}! Looking to explore Superwise?`,
|
|
844
|
+
`👋 ${o}! Ready to discover what Superwise can do for you?`,
|
|
845
|
+
`👋 ${o}! How can I help you with Superwise today?`,
|
|
846
|
+
`👋 ${o}! What brings you to Superwise?`,
|
|
847
|
+
`👋 ${o}! Let's explore Superwise together!`
|
|
652
848
|
];
|
|
653
849
|
return i[Math.floor(Math.random() * i.length)];
|
|
654
850
|
};
|
|
655
|
-
function
|
|
656
|
-
const [
|
|
851
|
+
function Re({ title: o = "", agentId: i = "", discoveryAgentId: w = "", primaryColor: x = "" }) {
|
|
852
|
+
const [a, g] = C(() => {
|
|
657
853
|
try {
|
|
658
854
|
if (typeof window < "u" && window.localStorage) {
|
|
659
|
-
const
|
|
660
|
-
return
|
|
855
|
+
const n = window.localStorage.getItem("chatbot-messages");
|
|
856
|
+
return n ? JSON.parse(n) : [];
|
|
661
857
|
}
|
|
662
858
|
} catch {
|
|
663
859
|
}
|
|
@@ -665,78 +861,78 @@ function be({ title: s = "", agentId: i = "", discoveryAgentId: w = "", primaryC
|
|
|
665
861
|
}), [p, l] = C(() => {
|
|
666
862
|
try {
|
|
667
863
|
if (typeof window < "u" && window.localStorage) {
|
|
668
|
-
const
|
|
669
|
-
return
|
|
864
|
+
const n = window.localStorage.getItem("chatbot-mql_df");
|
|
865
|
+
return n ? JSON.parse(n) : [];
|
|
670
866
|
}
|
|
671
867
|
} catch {
|
|
672
868
|
}
|
|
673
869
|
return [];
|
|
674
|
-
}), [c,
|
|
870
|
+
}), [c, m] = C(""), [u, y] = C(!1), [j, R] = C(!1), [k, B] = C(!1), [I, P] = C(!1), [X, S] = C(/* @__PURE__ */ new Set()), [O, V] = C(!1), [_, U] = C(""), [N, A] = C(""), q = (() => {
|
|
675
871
|
if (x) return x;
|
|
676
872
|
if (typeof document < "u" && typeof window < "u") {
|
|
677
|
-
const
|
|
678
|
-
if (
|
|
679
|
-
return
|
|
873
|
+
const n = document.querySelector("[data-chatbot-color]");
|
|
874
|
+
if (n)
|
|
875
|
+
return n.getAttribute("data-chatbot-color") || "#000";
|
|
680
876
|
const r = getComputedStyle(document.documentElement).getPropertyValue("--swttyw-primary-color").trim();
|
|
681
877
|
if (r) return r;
|
|
682
878
|
}
|
|
683
879
|
return "#000";
|
|
684
|
-
})(), H = ee(null), D = ee(
|
|
685
|
-
|
|
686
|
-
|
|
880
|
+
})(), H = ee(null), D = ee(a), Q = ce(() => a.map((n) => ({ role: n.from, content: n.text })), [a]), E = (n) => {
|
|
881
|
+
A(n), setTimeout(() => {
|
|
882
|
+
A("");
|
|
687
883
|
}, 4e3);
|
|
688
|
-
}, K = (
|
|
689
|
-
const e =
|
|
690
|
-
return
|
|
884
|
+
}, K = (n) => {
|
|
885
|
+
const e = n.length, r = n.trim();
|
|
886
|
+
return U(""), A(""), !r || e === 0 ? (E("Please enter a message before sending."), !1) : new RegExp(/(<([^>]+)>)/gi).test(r) ? (E("Please avoid using HTML tags or scripts in your message."), !1) : r.length < 2 ? (E("Please enter a meaningful question (at least 2 characters)."), !1) : r.length > 1e3 ? (E("Message is too long. Please keep it under 1000 characters."), !1) : (U(""), A(""), !0);
|
|
691
887
|
};
|
|
692
|
-
|
|
888
|
+
T(() => {
|
|
693
889
|
H.current?.scrollIntoView({ behavior: "smooth" });
|
|
694
|
-
}, [
|
|
890
|
+
}, [a, u]), T(() => {
|
|
695
891
|
try {
|
|
696
|
-
typeof window < "u" && window.localStorage && window.localStorage.setItem("chatbot-messages", JSON.stringify(
|
|
892
|
+
typeof window < "u" && window.localStorage && window.localStorage.setItem("chatbot-messages", JSON.stringify(a));
|
|
697
893
|
} catch {
|
|
698
894
|
}
|
|
699
|
-
}, [
|
|
895
|
+
}, [a]), T(() => {
|
|
700
896
|
try {
|
|
701
897
|
typeof window < "u" && window.localStorage && window.localStorage.setItem("chatbot-mql_df", JSON.stringify(p));
|
|
702
898
|
} catch {
|
|
703
899
|
}
|
|
704
|
-
}, [p]),
|
|
705
|
-
D.current =
|
|
706
|
-
}, [
|
|
707
|
-
if (
|
|
708
|
-
const e = { from: "ai", text:
|
|
709
|
-
|
|
900
|
+
}, [p]), T(() => {
|
|
901
|
+
D.current = a;
|
|
902
|
+
}, [a]), T(() => {
|
|
903
|
+
if (a.length === 0 && !O) {
|
|
904
|
+
const e = { from: "ai", text: ve() };
|
|
905
|
+
g([e]), V(!0), S(/* @__PURE__ */ new Set([0]));
|
|
710
906
|
}
|
|
711
|
-
}, [
|
|
907
|
+
}, [a.length, O]);
|
|
712
908
|
const G = J(async () => {
|
|
713
|
-
const
|
|
714
|
-
if (!
|
|
909
|
+
const n = c.trim();
|
|
910
|
+
if (!n || !K(c))
|
|
715
911
|
return;
|
|
716
|
-
const e = { from: "human", text:
|
|
717
|
-
|
|
718
|
-
const
|
|
912
|
+
const e = { from: "human", text: n }, d = [...D.current, e];
|
|
913
|
+
g(d), m(""), y(!0);
|
|
914
|
+
const h = [...Q, { role: "human", content: n }], v = await ue(n, h, p, i, w);
|
|
719
915
|
if (typeof v == "string") {
|
|
720
916
|
const M = { from: "ai", text: v };
|
|
721
|
-
|
|
722
|
-
const
|
|
723
|
-
return
|
|
917
|
+
g((f) => {
|
|
918
|
+
const b = [...f, M];
|
|
919
|
+
return S((L) => /* @__PURE__ */ new Set([...L, b.length - 1])), b;
|
|
724
920
|
});
|
|
725
921
|
} else {
|
|
726
922
|
const M = { from: "ai", text: v.reply };
|
|
727
|
-
|
|
728
|
-
const
|
|
729
|
-
return
|
|
923
|
+
g((f) => {
|
|
924
|
+
const b = [...f, M];
|
|
925
|
+
return S((L) => /* @__PURE__ */ new Set([...L, b.length - 1])), b;
|
|
730
926
|
}), v.mqlDf && Array.isArray(v.mqlDf) && l(v.mqlDf);
|
|
731
927
|
}
|
|
732
928
|
y(!1);
|
|
733
929
|
}, [c, i, w, p]), W = J(() => {
|
|
734
|
-
|
|
930
|
+
g([]), l([]), S(/* @__PURE__ */ new Set()), V(!1);
|
|
735
931
|
try {
|
|
736
932
|
typeof window < "u" && window.localStorage && (window.localStorage.removeItem("chatbot-messages"), window.localStorage.removeItem("chatbot-mql_df"));
|
|
737
933
|
} catch {
|
|
738
934
|
}
|
|
739
|
-
|
|
935
|
+
R(!1);
|
|
740
936
|
}, []), Y = J(async () => {
|
|
741
937
|
if (!p || p.length === 0) {
|
|
742
938
|
console.warn("No mql_df data available for PDF download");
|
|
@@ -744,24 +940,24 @@ function be({ title: s = "", agentId: i = "", discoveryAgentId: w = "", primaryC
|
|
|
744
940
|
}
|
|
745
941
|
try {
|
|
746
942
|
y(!0), console.log("mql_df data for lead extraction:", p);
|
|
747
|
-
const
|
|
943
|
+
const n = {
|
|
748
944
|
name: p.find((e) => e.name)?.name || "Chat User",
|
|
749
945
|
email: p.find((e) => e.email)?.email || "user@example.com",
|
|
750
|
-
summary: `Chat conversation with ${
|
|
946
|
+
summary: `Chat conversation with ${a.length} messages. User asked: "${a.find((e) => e.from === "human")?.text || "No user messages"}"`
|
|
751
947
|
};
|
|
752
|
-
console.log("Extracted lead row:",
|
|
753
|
-
} catch (
|
|
754
|
-
console.error("Failed to download PDF:",
|
|
948
|
+
console.log("Extracted lead row:", n), await ge(p, n, Q), console.log("PDF downloaded successfully");
|
|
949
|
+
} catch (n) {
|
|
950
|
+
console.error("Failed to download PDF:", n);
|
|
755
951
|
} finally {
|
|
756
952
|
y(!1);
|
|
757
953
|
}
|
|
758
|
-
}, [p,
|
|
954
|
+
}, [p, a]);
|
|
759
955
|
return /* @__PURE__ */ t.jsx(t.Fragment, { children: /* @__PURE__ */ t.jsxs(
|
|
760
956
|
"div",
|
|
761
957
|
{
|
|
762
958
|
className: "sw-ttyw-chatbot",
|
|
763
959
|
style: {
|
|
764
|
-
...
|
|
960
|
+
...k ? s.containerMinimized : I ? s.containerExpanded : s.container,
|
|
765
961
|
"--swttyw-primary-color": q,
|
|
766
962
|
"--swttyw-avatar-image": "url('')",
|
|
767
963
|
"--swttyw-user-avatar-image": "url('')",
|
|
@@ -771,30 +967,30 @@ function be({ title: s = "", agentId: i = "", discoveryAgentId: w = "", primaryC
|
|
|
771
967
|
"--swttyw-footer-font-size": "16px",
|
|
772
968
|
"--swttyw-user-background-image": "url('')"
|
|
773
969
|
},
|
|
774
|
-
onClick:
|
|
970
|
+
onClick: k ? () => B(!1) : void 0,
|
|
775
971
|
children: [
|
|
776
|
-
|
|
972
|
+
k ? (
|
|
777
973
|
/* Minimized State - Horizontal Button */
|
|
778
|
-
/* @__PURE__ */ t.jsxs("div", { style:
|
|
779
|
-
/* @__PURE__ */ t.jsxs("svg", { style:
|
|
974
|
+
/* @__PURE__ */ t.jsxs("div", { style: s.minimizedContent, children: [
|
|
975
|
+
/* @__PURE__ */ t.jsxs("svg", { style: s.chatIcon, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: [
|
|
780
976
|
/* @__PURE__ */ t.jsx("path", { d: "M21 15C21 15.5304 20.7893 16.0391 20.4142 16.4142C20.0391 16.7893 19.5304 17 19 17H7L3 21V5C3 4.46957 3.21071 3.96086 3.58579 3.58579C3.96086 3.21071 4.46957 3 5 3H19C19.5304 3 20.0391 3.21071 20.4142 3.58579C20.7893 3.96086 21 4.46957 21 5V15Z", stroke: "white", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round" }),
|
|
781
977
|
/* @__PURE__ */ t.jsx("path", { d: "M8 9H16", stroke: "white", strokeWidth: "2", strokeLinecap: "round" }),
|
|
782
978
|
/* @__PURE__ */ t.jsx("path", { d: "M8 13H12", stroke: "white", strokeWidth: "2", strokeLinecap: "round" })
|
|
783
979
|
] }),
|
|
784
|
-
/* @__PURE__ */ t.jsx("div", { style:
|
|
980
|
+
/* @__PURE__ */ t.jsx("div", { style: s.minimizedTitle, children: o })
|
|
785
981
|
] })
|
|
786
982
|
) : (
|
|
787
983
|
/* Full State - Header with Controls */
|
|
788
|
-
/* @__PURE__ */ t.jsxs("div", { className: "sw-ttyw-chat-header", style:
|
|
789
|
-
/* @__PURE__ */ t.jsx("div", { className: "sw-ttyw-name", style:
|
|
790
|
-
/* @__PURE__ */ t.jsxs("div", { style:
|
|
984
|
+
/* @__PURE__ */ t.jsxs("div", { className: "sw-ttyw-chat-header", style: s.header, children: [
|
|
985
|
+
/* @__PURE__ */ t.jsx("div", { className: "sw-ttyw-name", style: s.name, children: o }),
|
|
986
|
+
/* @__PURE__ */ t.jsxs("div", { style: s.headerActions, children: [
|
|
791
987
|
/* @__PURE__ */ t.jsx(
|
|
792
988
|
"button",
|
|
793
989
|
{
|
|
794
|
-
onClick: () =>
|
|
795
|
-
style:
|
|
796
|
-
title:
|
|
797
|
-
children:
|
|
990
|
+
onClick: () => P((n) => !n),
|
|
991
|
+
style: s.headerButton,
|
|
992
|
+
title: I ? "Shrink chat" : "Expand chat",
|
|
993
|
+
children: I ? /* @__PURE__ */ t.jsxs("svg", { width: "16", height: "16", viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: [
|
|
798
994
|
/* @__PURE__ */ t.jsx("path", { d: "M9 4V9H4", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round" }),
|
|
799
995
|
/* @__PURE__ */ t.jsx("path", { d: "M15 4V9H20", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round" }),
|
|
800
996
|
/* @__PURE__ */ t.jsx("path", { d: "M9 20V15H4", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round" }),
|
|
@@ -811,10 +1007,10 @@ function be({ title: s = "", agentId: i = "", discoveryAgentId: w = "", primaryC
|
|
|
811
1007
|
"button",
|
|
812
1008
|
{
|
|
813
1009
|
onClick: () => {
|
|
814
|
-
|
|
1010
|
+
k || P(!1), B(!k);
|
|
815
1011
|
},
|
|
816
|
-
style:
|
|
817
|
-
title:
|
|
1012
|
+
style: s.headerButton,
|
|
1013
|
+
title: k ? "Maximize chat" : "Minimize chat",
|
|
818
1014
|
children: /* @__PURE__ */ t.jsx("svg", { width: "16", height: "16", viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: /* @__PURE__ */ t.jsx("path", { d: "M6 9H18", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round" }) })
|
|
819
1015
|
}
|
|
820
1016
|
),
|
|
@@ -822,9 +1018,9 @@ function be({ title: s = "", agentId: i = "", discoveryAgentId: w = "", primaryC
|
|
|
822
1018
|
"button",
|
|
823
1019
|
{
|
|
824
1020
|
onClick: Y,
|
|
825
|
-
style:
|
|
1021
|
+
style: s.headerButton,
|
|
826
1022
|
title: "Download PDF Report",
|
|
827
|
-
disabled:
|
|
1023
|
+
disabled: u,
|
|
828
1024
|
children: /* @__PURE__ */ t.jsxs("svg", { width: "16", height: "16", viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: [
|
|
829
1025
|
/* @__PURE__ */ t.jsx("path", { d: "M21 15V19C21 19.5304 20.7893 20.0391 20.4142 20.4142C20.0391 20.7893 19.5304 21 19 21H5C4.46957 21 3.96086 20.7893 3.58579 20.4142C3.21071 20.0391 3 19.5304 3 19V15", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round" }),
|
|
830
1026
|
/* @__PURE__ */ t.jsx("path", { d: "M7 10L12 15L17 10", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round" }),
|
|
@@ -835,8 +1031,8 @@ function be({ title: s = "", agentId: i = "", discoveryAgentId: w = "", primaryC
|
|
|
835
1031
|
/* @__PURE__ */ t.jsx(
|
|
836
1032
|
"button",
|
|
837
1033
|
{
|
|
838
|
-
onClick: () =>
|
|
839
|
-
style:
|
|
1034
|
+
onClick: () => R(!0),
|
|
1035
|
+
style: s.headerButton,
|
|
840
1036
|
title: "Clear chat",
|
|
841
1037
|
children: /* @__PURE__ */ t.jsxs("svg", { width: "16", height: "16", viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: [
|
|
842
1038
|
/* @__PURE__ */ t.jsx("path", { d: "M3 6H5H21", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round" }),
|
|
@@ -849,9 +1045,9 @@ function be({ title: s = "", agentId: i = "", discoveryAgentId: w = "", primaryC
|
|
|
849
1045
|
] })
|
|
850
1046
|
] })
|
|
851
1047
|
),
|
|
852
|
-
!
|
|
853
|
-
/* @__PURE__ */ t.jsxs("div", { className: "sw-ttyw-messages", style:
|
|
854
|
-
|
|
1048
|
+
!k && /* @__PURE__ */ t.jsxs("div", { className: "sw-ttyw-chat-section", style: { flexGrow: 1, display: "flex", flexDirection: "column" }, children: [
|
|
1049
|
+
/* @__PURE__ */ t.jsxs("div", { className: "sw-ttyw-messages", style: s.chatSection, children: [
|
|
1050
|
+
a.length === 0 && !u && /* @__PURE__ */ t.jsx("div", { className: "sw-ttyw-empty-state", style: {
|
|
855
1051
|
display: "flex",
|
|
856
1052
|
flexDirection: "column",
|
|
857
1053
|
alignItems: "center",
|
|
@@ -861,7 +1057,7 @@ function be({ title: s = "", agentId: i = "", discoveryAgentId: w = "", primaryC
|
|
|
861
1057
|
}, children: /* @__PURE__ */ t.jsx(
|
|
862
1058
|
"img",
|
|
863
1059
|
{
|
|
864
|
-
src:
|
|
1060
|
+
src: he,
|
|
865
1061
|
alt: "Superwise Logo",
|
|
866
1062
|
style: {
|
|
867
1063
|
width: "350px",
|
|
@@ -869,18 +1065,18 @@ function be({ title: s = "", agentId: i = "", discoveryAgentId: w = "", primaryC
|
|
|
869
1065
|
opacity: 0.8,
|
|
870
1066
|
objectFit: "contain"
|
|
871
1067
|
},
|
|
872
|
-
onError: (
|
|
873
|
-
console.log("Logo failed to load, using fallback"),
|
|
1068
|
+
onError: (n) => {
|
|
1069
|
+
console.log("Logo failed to load, using fallback"), n.target.style.display = "none";
|
|
874
1070
|
}
|
|
875
1071
|
}
|
|
876
1072
|
) }),
|
|
877
|
-
|
|
878
|
-
|
|
1073
|
+
a.map((n, e) => /* @__PURE__ */ t.jsx(
|
|
1074
|
+
be,
|
|
879
1075
|
{
|
|
880
|
-
msg:
|
|
1076
|
+
msg: n,
|
|
881
1077
|
isTyping: X.has(e),
|
|
882
1078
|
onTypingComplete: () => {
|
|
883
|
-
|
|
1079
|
+
S((r) => {
|
|
884
1080
|
const d = new Set(r);
|
|
885
1081
|
return d.delete(e), d;
|
|
886
1082
|
});
|
|
@@ -888,12 +1084,12 @@ function be({ title: s = "", agentId: i = "", discoveryAgentId: w = "", primaryC
|
|
|
888
1084
|
},
|
|
889
1085
|
e
|
|
890
1086
|
)),
|
|
891
|
-
|
|
1087
|
+
N && /* @__PURE__ */ t.jsxs("div", { className: "sw-ttyw-validation-message", children: [
|
|
892
1088
|
/* @__PURE__ */ t.jsx("span", { className: "error-icon", children: "⚠️" }),
|
|
893
|
-
/* @__PURE__ */ t.jsx("span", { children:
|
|
1089
|
+
/* @__PURE__ */ t.jsx("span", { children: N })
|
|
894
1090
|
] }),
|
|
895
|
-
|
|
896
|
-
/* @__PURE__ */ t.jsx("div", { className: "message-avatar", style:
|
|
1091
|
+
u && /* @__PURE__ */ t.jsxs("div", { className: "sw-ttyw-message other message-loading", style: { ...s.message, ...s.messageOther }, children: [
|
|
1092
|
+
/* @__PURE__ */ t.jsx("div", { className: "message-avatar", style: s.messageAvatar, children: /* @__PURE__ */ t.jsx(
|
|
897
1093
|
"img",
|
|
898
1094
|
{
|
|
899
1095
|
src: se,
|
|
@@ -906,7 +1102,7 @@ function be({ title: s = "", agentId: i = "", discoveryAgentId: w = "", primaryC
|
|
|
906
1102
|
}
|
|
907
1103
|
}
|
|
908
1104
|
) }),
|
|
909
|
-
/* @__PURE__ */ t.jsxs("div", { className: "message-content", style:
|
|
1105
|
+
/* @__PURE__ */ t.jsxs("div", { className: "message-content", style: s.messageContent, children: [
|
|
910
1106
|
/* @__PURE__ */ t.jsx("div", { className: "typing typing-1" }),
|
|
911
1107
|
/* @__PURE__ */ t.jsx("div", { className: "typing typing-2" }),
|
|
912
1108
|
/* @__PURE__ */ t.jsx("div", { className: "typing typing-3" })
|
|
@@ -914,23 +1110,23 @@ function be({ title: s = "", agentId: i = "", discoveryAgentId: w = "", primaryC
|
|
|
914
1110
|
] }),
|
|
915
1111
|
/* @__PURE__ */ t.jsx("div", { ref: H })
|
|
916
1112
|
] }),
|
|
917
|
-
/* @__PURE__ */ t.jsxs("div", { className: "sw-ttyw-chat-input-section", style:
|
|
1113
|
+
/* @__PURE__ */ t.jsxs("div", { className: "sw-ttyw-chat-input-section", style: s.inputSection, children: [
|
|
918
1114
|
/* @__PURE__ */ t.jsx(
|
|
919
1115
|
"textarea",
|
|
920
1116
|
{
|
|
921
1117
|
className: "sw-ttyw-input",
|
|
922
1118
|
placeholder: "Please ask question here",
|
|
923
1119
|
value: c,
|
|
924
|
-
onChange: (
|
|
925
|
-
|
|
1120
|
+
onChange: (n) => {
|
|
1121
|
+
m(n.target.value), N && A("");
|
|
926
1122
|
},
|
|
927
1123
|
maxLength: 1e3,
|
|
928
|
-
style:
|
|
929
|
-
onKeyDown: (
|
|
1124
|
+
style: s.textarea,
|
|
1125
|
+
onKeyDown: (n) => n.key === "Enter" && !n.shiftKey && (n.preventDefault(), G())
|
|
930
1126
|
}
|
|
931
1127
|
),
|
|
932
|
-
/* @__PURE__ */ t.jsxs("div", { className: "sw-ttyw-chat-input-content", style:
|
|
933
|
-
/* @__PURE__ */ t.jsxs("small", { id: "sw-ttyw-chat-textbox-status", style:
|
|
1128
|
+
/* @__PURE__ */ t.jsxs("div", { className: "sw-ttyw-chat-input-content", style: s.inputFooter, children: [
|
|
1129
|
+
/* @__PURE__ */ t.jsxs("small", { id: "sw-ttyw-chat-textbox-status", style: s.characterCount, children: [
|
|
934
1130
|
/* @__PURE__ */ t.jsx("span", { children: c.length }),
|
|
935
1131
|
"/1000"
|
|
936
1132
|
] }),
|
|
@@ -940,7 +1136,7 @@ function be({ title: s = "", agentId: i = "", discoveryAgentId: w = "", primaryC
|
|
|
940
1136
|
id: "sw-ttyw-chat-send-message",
|
|
941
1137
|
onClick: G,
|
|
942
1138
|
"aria-label": "Send message",
|
|
943
|
-
style:
|
|
1139
|
+
style: s.sendButton,
|
|
944
1140
|
children: /* @__PURE__ */ t.jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", height: "24px", viewBox: "0 0 24 24", width: "24px", fill: "#000000", className: "cwv replaced-svg", children: [
|
|
945
1141
|
/* @__PURE__ */ t.jsx("path", { d: "M0 0h24v24H0z", fill: "none" }),
|
|
946
1142
|
/* @__PURE__ */ t.jsx("path", { d: "M2.01 21L23 12 2.01 3 2 10l15 2-15 2z" })
|
|
@@ -950,11 +1146,11 @@ function be({ title: s = "", agentId: i = "", discoveryAgentId: w = "", primaryC
|
|
|
950
1146
|
] })
|
|
951
1147
|
] })
|
|
952
1148
|
] }),
|
|
953
|
-
|
|
1149
|
+
j && /* @__PURE__ */ t.jsxs("div", { className: "swttyw-modal swttyw-modal-clear-history", style: s.modalOverlay, children: [
|
|
954
1150
|
/* @__PURE__ */ t.jsx("div", { className: "swtty-modal-header" }),
|
|
955
|
-
/* @__PURE__ */ t.jsxs("div", { className: "swtty-modal-body", style:
|
|
1151
|
+
/* @__PURE__ */ t.jsxs("div", { className: "swtty-modal-body", style: s.modalBody, children: [
|
|
956
1152
|
/* @__PURE__ */ t.jsx("div", { className: "swtty-content", children: "Are you sure you want to delete the chat history?" }),
|
|
957
|
-
/* @__PURE__ */ t.jsxs("div", { className: "swtty-action", style:
|
|
1153
|
+
/* @__PURE__ */ t.jsxs("div", { className: "swtty-action", style: s.modalActions, children: [
|
|
958
1154
|
/* @__PURE__ */ t.jsx(
|
|
959
1155
|
"input",
|
|
960
1156
|
{
|
|
@@ -980,7 +1176,7 @@ function be({ title: s = "", agentId: i = "", discoveryAgentId: w = "", primaryC
|
|
|
980
1176
|
type: "button",
|
|
981
1177
|
className: "swttyw-btn swttyw-btn-primary-inverse",
|
|
982
1178
|
id: "swttyw-btn-clear-history-no",
|
|
983
|
-
onClick: () =>
|
|
1179
|
+
onClick: () => R(!1),
|
|
984
1180
|
value: "No",
|
|
985
1181
|
style: {
|
|
986
1182
|
background: "transparent",
|
|
@@ -997,14 +1193,14 @@ function be({ title: s = "", agentId: i = "", discoveryAgentId: w = "", primaryC
|
|
|
997
1193
|
] }),
|
|
998
1194
|
/* @__PURE__ */ t.jsx("div", { className: "swtty-modal-footer" })
|
|
999
1195
|
] }),
|
|
1000
|
-
!
|
|
1196
|
+
!k && /* @__PURE__ */ t.jsxs("div", { className: "sw-ttyw-chat-footer", style: s.footer, children: [
|
|
1001
1197
|
"Powered by ",
|
|
1002
|
-
/* @__PURE__ */ t.jsx("a", { href: "https://superwise.ai/", className: "ml-1", target: "_new", style: { marginLeft: "0.25rem", lineHeight: 0 }, children: /* @__PURE__ */ t.jsx("img", { src:
|
|
1198
|
+
/* @__PURE__ */ t.jsx("a", { href: "https://superwise.ai/", className: "ml-1", target: "_new", style: { marginLeft: "0.25rem", lineHeight: 0 }, children: /* @__PURE__ */ t.jsx("img", { src: we, alt: "SUPERWISE®", height: "20" }) })
|
|
1003
1199
|
] })
|
|
1004
1200
|
]
|
|
1005
1201
|
}
|
|
1006
1202
|
) });
|
|
1007
1203
|
}
|
|
1008
1204
|
export {
|
|
1009
|
-
|
|
1205
|
+
Re as Chatbot
|
|
1010
1206
|
};
|