@cleartrip/talos-use-chat-controller 1.1.0-TEST.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,1025 @@
1
+ 'use strict';
2
+
3
+ var tslib = require('tslib');
4
+ var react = require('react');
5
+ var uuid = require('uuid');
6
+ var talosUseChat = require('@cleartrip/talos-use-chat');
7
+ var talosWidgetTypes = require('@cleartrip/talos-widget-types');
8
+ var jsxRuntime = require('react/jsx-runtime');
9
+
10
+ var useChatAction = function (props) {
11
+ var sendMessage = props.sendMessage, pushToChatStack = props.pushToChatStack, getPreviousChatById = props.getPreviousChatById, handleCreateNewChat = props.handleCreateNewChat;
12
+ var dispatch = react.useCallback(function (action) { return tslib.__awaiter(void 0, void 0, void 0, function () {
13
+ var type, payload, _a, message, id;
14
+ return tslib.__generator(this, function (_b) {
15
+ switch (_b.label) {
16
+ case 0:
17
+ type = action.type, payload = action.payload;
18
+ _a = type;
19
+ switch (_a) {
20
+ case talosWidgetTypes.ActionType.SEND_MESSAGE: return [3, 1];
21
+ case talosWidgetTypes.ActionType.GET_PREVIOUS_CHAT: return [3, 3];
22
+ case talosWidgetTypes.ActionType.CREATE_NEW_CHAT: return [3, 5];
23
+ }
24
+ return [3, 6];
25
+ case 1:
26
+ message = payload.message;
27
+ return [4, sendMessage(message)];
28
+ case 2:
29
+ _b.sent();
30
+ return [3, 7];
31
+ case 3:
32
+ id = payload.id;
33
+ return [4, getPreviousChatById(id)];
34
+ case 4:
35
+ _b.sent();
36
+ return [3, 7];
37
+ case 5:
38
+ {
39
+ handleCreateNewChat();
40
+ return [3, 7];
41
+ }
42
+ case 6:
43
+ {
44
+ console.warn("[useChatAction] Unhandled action type: ".concat(action.type));
45
+ }
46
+ _b.label = 7;
47
+ case 7: return [2];
48
+ }
49
+ });
50
+ }); }, [sendMessage, pushToChatStack]);
51
+ var dispatchAll = react.useCallback(function (actions) { return tslib.__awaiter(void 0, void 0, void 0, function () {
52
+ var _i, actions_1, action;
53
+ return tslib.__generator(this, function (_a) {
54
+ switch (_a.label) {
55
+ case 0:
56
+ _i = 0, actions_1 = actions;
57
+ _a.label = 1;
58
+ case 1:
59
+ if (!(_i < actions_1.length)) return [3, 4];
60
+ action = actions_1[_i];
61
+ return [4, dispatch(action)];
62
+ case 2:
63
+ _a.sent();
64
+ _a.label = 3;
65
+ case 3:
66
+ _i++;
67
+ return [3, 1];
68
+ case 4: return [2];
69
+ }
70
+ });
71
+ }); }, [dispatch]);
72
+ return { dispatch: dispatch, dispatchAll: dispatchAll };
73
+ };
74
+
75
+ var formUserMessageWidget = function (message) {
76
+ var widget = {
77
+ type: talosWidgetTypes.WidgetType.USER_MESSAGE,
78
+ data: {
79
+ text: message,
80
+ },
81
+ };
82
+ return widget;
83
+ };
84
+
85
+ exports.ChatStatus = void 0;
86
+ (function (ChatStatus) {
87
+ ChatStatus["ON_GOING"] = "ON_GOING";
88
+ ChatStatus["CLOSED"] = "CLOSED";
89
+ })(exports.ChatStatus || (exports.ChatStatus = {}));
90
+ exports.ChatPageType = void 0;
91
+ (function (ChatPageType) {
92
+ ChatPageType["CHAT"] = "CHAT";
93
+ ChatPageType["PREVIOUS_CHAT_LISTING"] = "PREVIOUS_CHAT_LISTING";
94
+ ChatPageType["PREVIOUS_CHAT"] = "PREVIOUS_CHAT";
95
+ })(exports.ChatPageType || (exports.ChatPageType = {}));
96
+
97
+ var PREVIOUS_CHAT_LISTING = {
98
+ response: {
99
+ previousChats: [
100
+ {
101
+ type: "PREVIOUS_CHAT_LISTING",
102
+ data: {
103
+ list: [
104
+ {
105
+ title: "Today",
106
+ chats: [
107
+ {
108
+ type: "PREVIOUS_CHAT_CARD",
109
+ data: {
110
+ title: "Cancel booking",
111
+ status: {
112
+ label: "closed",
113
+ variant: "CLOSED",
114
+ },
115
+ dateAndTime: "11 Mar, 1:12 PM",
116
+ id: "chat_id_1",
117
+ },
118
+ "events": {
119
+ "onClick": [
120
+ {
121
+ type: "GET_PREVIOUS_CHAT",
122
+ payload: {
123
+ id: "chat_id_1",
124
+ }
125
+ }
126
+ ]
127
+ },
128
+ }
129
+ ]
130
+ },
131
+ {
132
+ title: "Last 7 days",
133
+ chats: [
134
+ {
135
+ type: "PREVIOUS_CHAT_CARD",
136
+ data: {
137
+ title: "Bus is delayed",
138
+ status: {
139
+ label: "closed",
140
+ variant: "CLOSED",
141
+ },
142
+ dateAndTime: "11 Mar, 1:12 PM",
143
+ id: "chat_id_2",
144
+ },
145
+ "events": {
146
+ "onClick": [
147
+ {
148
+ type: "GET_PREVIOUS_CHAT",
149
+ payload: {
150
+ id: "chat_id_2",
151
+ }
152
+ }
153
+ ]
154
+ }
155
+ },
156
+ {
157
+ type: "PREVIOUS_CHAT_CARD",
158
+ data: {
159
+ title: "I want to cancel booking for 2 passengers",
160
+ status: {
161
+ label: "closed",
162
+ variant: "CLOSED",
163
+ },
164
+ dateAndTime: "11 Mar, 1:12 PM",
165
+ id: "chat_id_3",
166
+ },
167
+ "events": {
168
+ "onClick": [
169
+ {
170
+ type: "GET_PREVIOUS_CHAT",
171
+ payload: {
172
+ id: "chat_id_3",
173
+ }
174
+ }
175
+ ]
176
+ }
177
+ }
178
+ ]
179
+ }
180
+ ]
181
+ }
182
+ }
183
+ ],
184
+ pageData: {
185
+ isActiveChat: false,
186
+ }
187
+ }
188
+ };
189
+
190
+ var BOT_INTERACTION_WIDGET = {
191
+ "type": "BOT_INTERACTION_WIDGET",
192
+ "data": {
193
+ "heading": {
194
+ "type": "HEADING",
195
+ "data": {
196
+ "content": [
197
+ {
198
+ "text": "Your ticket has been successfully cancelled!",
199
+ "prefixIcon": "SUCCESS_TICK"
200
+ }
201
+ ]
202
+ }
203
+ },
204
+ "dynamicSlot": {
205
+ "type": "TRIP_CARD",
206
+ "data": {
207
+ "title": "Kaveri Kamaksi Travels",
208
+ "description": "TRIP ID: Q28742382719",
209
+ "icon": "BUS_ICON",
210
+ "status": {
211
+ "label": "completed",
212
+ "id": "COMPLETED",
213
+ },
214
+ "origin": {
215
+ "name": "Thiruvananthapuram",
216
+ "date": "Sat, 3 Sep",
217
+ "time": "03:30 PM"
218
+ },
219
+ "destination": {
220
+ "name": "Bangalore",
221
+ "date": "Sun, 4 Sep",
222
+ "time": "12:30 AM"
223
+ },
224
+ "duration": "10h 20m"
225
+ },
226
+ "tracking": {}
227
+ },
228
+ "highlight": {
229
+ "type": "HIGHLIGHT",
230
+ "data": {
231
+ "text": "Refund: ₹580.00",
232
+ "variant": "PHONE",
233
+ "color": "SUCCESS"
234
+ },
235
+ "events": {
236
+ "onClick": []
237
+ }
238
+ },
239
+ "bodyContent": {
240
+ "type": "BODY_CONTENT",
241
+ "data": {
242
+ "content": [
243
+ {
244
+ "text": "Please contact your bank for any details."
245
+ },
246
+ {
247
+ "text": "Is there anything else I can help you with?",
248
+ },
249
+ ]
250
+ }
251
+ },
252
+ "listSelection": {
253
+ "type": "LIST_SELECT_OPTIONS",
254
+ "data": {
255
+ "options": [
256
+ {
257
+ type: "LIST_SELECT_OPTION_ITEM",
258
+ data: {
259
+ "label": "Operator cancelled the Bus",
260
+ },
261
+ events: {
262
+ onClick: [
263
+ {
264
+ type: "SEND_MESSAGE",
265
+ payload: {}
266
+ }
267
+ ]
268
+ }
269
+ },
270
+ {
271
+ type: "LIST_SELECT_OPTION_ITEM",
272
+ data: {
273
+ "label": "Get driver’s contact",
274
+ },
275
+ events: {
276
+ onClick: [
277
+ {
278
+ type: "SEND_MESSAGE",
279
+ payload: {}
280
+ }
281
+ ]
282
+ }
283
+ }
284
+ ]
285
+ },
286
+ "behavior": "HIDE_IF_NOT_LAST_MESSAGE"
287
+ },
288
+ workflowOptions: {}
289
+ },
290
+ metaData: {
291
+ createdAt: "1777552525693",
292
+ },
293
+ "events": {
294
+ "onLoad": [
295
+ {
296
+ type: "SHOW_NATIVE_ACTIONS",
297
+ }
298
+ ]
299
+ }
300
+ };
301
+ var INITIAL_CHAT_AND_PREVIOUS_CHATS = {
302
+ messages: [
303
+ {
304
+ type: "BOT_MESSAGE",
305
+ id: "message_id_1",
306
+ chunks: [
307
+ BOT_INTERACTION_WIDGET
308
+ ],
309
+ metaData: {
310
+ createdAt: "1777552525693",
311
+ }
312
+ },
313
+ ],
314
+ pageData: {
315
+ isActiveChat: true,
316
+ },
317
+ status: "ON_GOING",
318
+ id: "chat_id_1",
319
+ };
320
+ var BOT_INTERACTION_WIDGET_1 = {
321
+ "type": "BOT_INTERACTION_WIDGET",
322
+ "data": {
323
+ "heading": {
324
+ "type": "HEADING",
325
+ "data": {
326
+ "content": [
327
+ {
328
+ "text": "Your ticket has been successfully cancelled!",
329
+ "prefixIcon": "SUCCESS_TICK"
330
+ }
331
+ ]
332
+ }
333
+ },
334
+ "dynamicSlot": {
335
+ "type": "TRIP_CARD",
336
+ "data": {
337
+ "title": "Kaveri Kamaksi Travels",
338
+ "description": "TRIP ID: Q28742382719",
339
+ "icon": "BUS_ICON",
340
+ "status": {
341
+ "label": "completed",
342
+ "id": "COMPLETED",
343
+ },
344
+ "origin": {
345
+ "name": "Thiruvananthapuram",
346
+ "date": "Sat, 3 Sep",
347
+ "time": "03:30 PM"
348
+ },
349
+ "destination": {
350
+ "name": "Bangalore",
351
+ "date": "Sun, 4 Sep",
352
+ "time": "12:30 AM"
353
+ },
354
+ "duration": "10h 20m"
355
+ },
356
+ "tracking": {}
357
+ },
358
+ },
359
+ metaData: {
360
+ createdAt: "1777552525693",
361
+ },
362
+ "events": {
363
+ "onLoad": [
364
+ {
365
+ type: "SHOW_NATIVE_ACTIONS",
366
+ }
367
+ ]
368
+ }
369
+ };
370
+ var PREVIOUS_CHAT_1 = {
371
+ messages: [
372
+ {
373
+ type: "BOT_MESSAGE",
374
+ id: "message_id_1",
375
+ chunks: [
376
+ BOT_INTERACTION_WIDGET_1
377
+ ],
378
+ metaData: {
379
+ createdAt: "1777552525693",
380
+ }
381
+ },
382
+ ],
383
+ pageData: {
384
+ title: "Cancel booking",
385
+ isActiveChat: false,
386
+ },
387
+ status: "CLOSED",
388
+ id: "chat_id_1",
389
+ };
390
+ var BOT_INTERACTION_WIDGET_2 = {
391
+ "type": "BOT_INTERACTION_WIDGET",
392
+ "data": {
393
+ "heading": {
394
+ "type": "HEADING",
395
+ "data": {
396
+ "content": [
397
+ {
398
+ "text": "Your ticket has been successfully cancelled!",
399
+ "prefixIcon": "SUCCESS_TICK"
400
+ }
401
+ ]
402
+ }
403
+ },
404
+ "dynamicSlot": {
405
+ "type": "TRIP_CARD",
406
+ "data": {
407
+ "title": "Kaveri Kamaksi Travels",
408
+ "description": "TRIP ID: Q28742382719",
409
+ "icon": "BUS_ICON",
410
+ "status": {
411
+ "label": "completed",
412
+ "id": "COMPLETED",
413
+ },
414
+ "origin": {
415
+ "name": "Thiruvananthapuram",
416
+ "date": "Sat, 3 Sep",
417
+ "time": "03:30 PM"
418
+ },
419
+ "destination": {
420
+ "name": "Bangalore",
421
+ "date": "Sun, 4 Sep",
422
+ "time": "12:30 AM"
423
+ },
424
+ "duration": "10h 20m"
425
+ },
426
+ "tracking": {}
427
+ },
428
+ "bodyContent": {
429
+ "type": "BODY_CONTENT",
430
+ "data": {
431
+ "content": [
432
+ {
433
+ "text": "Please contact your bank for any details."
434
+ },
435
+ {
436
+ "text": "Is there anything else I can help you with?",
437
+ },
438
+ ]
439
+ }
440
+ },
441
+ "listSelection": {
442
+ "type": "LIST_SELECT_OPTIONS",
443
+ "data": {
444
+ "options": [
445
+ {
446
+ type: "LIST_SELECT_OPTION_ITEM",
447
+ data: {
448
+ "label": "Operator cancelled the Bus",
449
+ },
450
+ events: {
451
+ onClick: [
452
+ {
453
+ type: "SEND_MESSAGE",
454
+ payload: {}
455
+ }
456
+ ]
457
+ }
458
+ },
459
+ {
460
+ type: "LIST_SELECT_OPTION_ITEM",
461
+ data: {
462
+ "label": "Get driver’s contact",
463
+ },
464
+ events: {
465
+ onClick: [
466
+ {
467
+ type: "SEND_MESSAGE",
468
+ payload: {}
469
+ }
470
+ ]
471
+ }
472
+ }
473
+ ]
474
+ },
475
+ "behavior": "HIDE_IF_NOT_LAST_MESSAGE"
476
+ },
477
+ workflowOptions: {}
478
+ },
479
+ metaData: {
480
+ createdAt: "1777552525693",
481
+ },
482
+ "events": {
483
+ "onLoad": [
484
+ {
485
+ type: "SHOW_NATIVE_ACTIONS",
486
+ }
487
+ ]
488
+ }
489
+ };
490
+ var PREVIOUS_CHAT_2 = {
491
+ messages: [
492
+ {
493
+ type: "BOT_MESSAGE",
494
+ id: "message_id_1",
495
+ chunks: [
496
+ BOT_INTERACTION_WIDGET_2
497
+ ],
498
+ metaData: {
499
+ createdAt: "1777552525693",
500
+ }
501
+ },
502
+ ],
503
+ pageData: {
504
+ title: "Bus is delayed",
505
+ footerSlots: [
506
+ {
507
+ type: "MESSAGE_CONTAINER",
508
+ data: {
509
+ message: "This query was closed on 11 Mar, If you have a query regarding this trip, you can start a new chat."
510
+ },
511
+ "behavior": "FIXED_BOTTOM"
512
+ }
513
+ ],
514
+ isActiveChat: false,
515
+ },
516
+ status: "CLOSED",
517
+ id: "chat_id_2",
518
+ };
519
+ var BOT_INTERACTION_WIDGET_3 = {
520
+ "type": "BOT_INTERACTION_WIDGET",
521
+ "data": {
522
+ "highlight": {
523
+ "type": "HIGHLIGHT",
524
+ "data": {
525
+ "text": "Refund: ₹580.00",
526
+ "variant": "PHONE",
527
+ "color": "SUCCESS"
528
+ },
529
+ "events": {
530
+ "onClick": []
531
+ }
532
+ },
533
+ "bodyContent": {
534
+ "type": "BODY_CONTENT",
535
+ "data": {
536
+ "content": [
537
+ {
538
+ "text": "Please contact your bank for any details."
539
+ },
540
+ {
541
+ "text": "Is there anything else I can help you with?",
542
+ },
543
+ ]
544
+ }
545
+ },
546
+ "listSelection": {
547
+ "type": "LIST_SELECT_OPTIONS",
548
+ "data": {
549
+ "options": [
550
+ {
551
+ type: "LIST_SELECT_OPTION_ITEM",
552
+ data: {
553
+ "label": "Operator cancelled the Bus",
554
+ },
555
+ events: {
556
+ onClick: [
557
+ {
558
+ type: "SEND_MESSAGE",
559
+ payload: {}
560
+ }
561
+ ]
562
+ }
563
+ },
564
+ {
565
+ type: "LIST_SELECT_OPTION_ITEM",
566
+ data: {
567
+ "label": "Get driver’s contact",
568
+ },
569
+ events: {
570
+ onClick: [
571
+ {
572
+ type: "SEND_MESSAGE",
573
+ payload: {}
574
+ }
575
+ ]
576
+ }
577
+ }
578
+ ]
579
+ },
580
+ "behavior": "HIDE_IF_NOT_LAST_MESSAGE"
581
+ },
582
+ workflowOptions: {}
583
+ },
584
+ metaData: {
585
+ createdAt: "1777552525693",
586
+ },
587
+ "events": {
588
+ "onLoad": [
589
+ {
590
+ type: "SHOW_NATIVE_ACTIONS",
591
+ }
592
+ ]
593
+ }
594
+ };
595
+ var PREVIOUS_CHAT_3 = {
596
+ messages: [
597
+ {
598
+ type: "BOT_MESSAGE",
599
+ id: "message_id_1",
600
+ chunks: [
601
+ BOT_INTERACTION_WIDGET_3
602
+ ],
603
+ metaData: {
604
+ createdAt: "1777552525693",
605
+ }
606
+ },
607
+ {
608
+ type: "USER_MESSAGE",
609
+ id: "message_id_2",
610
+ chunks: [
611
+ {
612
+ type: "USER_MESSAGE",
613
+ data: {
614
+ text: "Hello, how are you?",
615
+ media: [],
616
+ files: [],
617
+ }
618
+ }
619
+ ],
620
+ metaData: {
621
+ createdAt: "1777552525693",
622
+ }
623
+ },
624
+ {
625
+ type: "BOT_MESSAGE",
626
+ id: "message_id_1",
627
+ chunks: [
628
+ BOT_INTERACTION_WIDGET_3
629
+ ],
630
+ metaData: {
631
+ createdAt: "1777552525693",
632
+ }
633
+ },
634
+ {
635
+ type: "USER_MESSAGE",
636
+ id: "message_id_2",
637
+ chunks: [
638
+ {
639
+ type: "USER_MESSAGE",
640
+ data: {
641
+ text: "Hello, how are you?",
642
+ media: [],
643
+ files: [],
644
+ }
645
+ }
646
+ ],
647
+ metaData: {
648
+ createdAt: "1777552525693",
649
+ }
650
+ },
651
+ {
652
+ type: "BOT_MESSAGE",
653
+ id: "message_id_1",
654
+ chunks: [
655
+ BOT_INTERACTION_WIDGET_3
656
+ ],
657
+ metaData: {
658
+ createdAt: "1777552525693",
659
+ }
660
+ },
661
+ {
662
+ type: "USER_MESSAGE",
663
+ id: "message_id_2",
664
+ chunks: [
665
+ {
666
+ type: "USER_MESSAGE",
667
+ data: {
668
+ text: "Hello, how are you?",
669
+ media: [],
670
+ files: [],
671
+ }
672
+ }
673
+ ],
674
+ metaData: {
675
+ createdAt: "1777552525693",
676
+ }
677
+ },
678
+ {
679
+ type: "BOT_MESSAGE",
680
+ id: "message_id_1",
681
+ chunks: [
682
+ BOT_INTERACTION_WIDGET_3
683
+ ],
684
+ metaData: {
685
+ createdAt: "1777552525693",
686
+ }
687
+ },
688
+ {
689
+ type: "USER_MESSAGE",
690
+ id: "message_id_2",
691
+ chunks: [
692
+ {
693
+ type: "USER_MESSAGE",
694
+ data: {
695
+ text: "Hello, how are you?",
696
+ media: [],
697
+ files: [],
698
+ }
699
+ }
700
+ ],
701
+ metaData: {
702
+ createdAt: "1777552525693",
703
+ }
704
+ },
705
+ {
706
+ type: "BOT_MESSAGE",
707
+ id: "message_id_1",
708
+ chunks: [
709
+ BOT_INTERACTION_WIDGET_3
710
+ ],
711
+ metaData: {
712
+ createdAt: "1777552525693",
713
+ }
714
+ },
715
+ {
716
+ type: "USER_MESSAGE",
717
+ id: "message_id_2",
718
+ chunks: [
719
+ {
720
+ type: "USER_MESSAGE",
721
+ data: {
722
+ text: "Hello, how are you?",
723
+ media: [],
724
+ files: [],
725
+ }
726
+ }
727
+ ],
728
+ metaData: {
729
+ createdAt: "1777552525693",
730
+ }
731
+ }
732
+ ],
733
+ pageData: {
734
+ title: "I want to cancel booking for 2 passengers",
735
+ footerSlots: [
736
+ {
737
+ type: "MESSAGE_CONTAINER",
738
+ data: {
739
+ message: "This query was closed on 11 Mar, If you have a query regarding this trip, you can start a new chat."
740
+ },
741
+ "behavior": "FIXED_BOTTOM"
742
+ }
743
+ ],
744
+ isActiveChat: false,
745
+ },
746
+ status: "CLOSED",
747
+ id: "chat_id_3",
748
+ };
749
+
750
+ var sleep = function () { return new Promise(function (resolve) { return setTimeout(resolve, 5000); }); };
751
+ var useChatController = function (config) {
752
+ var _a = talosUseChat.useChat(config), chat = _a.chat, status = _a.status, baseSendMessage = _a.sendMessage, stop = _a.stop;
753
+ var _b = react.useState({}), messages = _b[0], setMessages = _b[1];
754
+ var _c = react.useState(false), isInitialLoading = _c[0], setIsInitialLoading = _c[1];
755
+ var _d = react.useState(false), isReplyLoading = _d[0], setIsReplyLoading = _d[1];
756
+ var _e = react.useState([]), chatStack = _e[0], setChatStack = _e[1];
757
+ var _f = react.useState(null), previousChats = _f[0], setPreviousChats = _f[1];
758
+ var _g = react.useState(false), previousChatLoading = _g[0], setPreviousChatLoading = _g[1];
759
+ var presentedRef = react.useRef(new Map());
760
+ var hasPresented = react.useCallback(function (cid, id) {
761
+ var _a, _b;
762
+ return (_b = (_a = presentedRef.current.get(cid)) === null || _a === void 0 ? void 0 : _a.has(id)) !== null && _b !== void 0 ? _b : false;
763
+ }, []);
764
+ var markPresented = react.useCallback(function (cid, id) {
765
+ var set = presentedRef.current.get(cid);
766
+ if (!set) {
767
+ set = new Set();
768
+ presentedRef.current.set(cid, set);
769
+ }
770
+ set.add(id);
771
+ }, []);
772
+ var seedPresented = function (cid, ids) {
773
+ var set = presentedRef.current.get(cid);
774
+ if (!set) {
775
+ set = new Set();
776
+ presentedRef.current.set(cid, set);
777
+ }
778
+ ids.forEach(function (id) { return set.add(id); });
779
+ };
780
+ var currentChatId = react.useMemo(function () {
781
+ var _a;
782
+ return ((_a = chatStack[chatStack.length - 1]) === null || _a === void 0 ? void 0 : _a.id) || "";
783
+ }, [chatStack]);
784
+ var seedInitialChat = function () { return tslib.__awaiter(void 0, void 0, void 0, function () {
785
+ var _a, initialChatMessages_1, initialChatStatus_1, initialChatId_1, error_1;
786
+ return tslib.__generator(this, function (_b) {
787
+ switch (_b.label) {
788
+ case 0:
789
+ _b.trys.push([0, 2, 3, 4]);
790
+ setIsInitialLoading(true);
791
+ _a = INITIAL_CHAT_AND_PREVIOUS_CHATS, initialChatMessages_1 = _a.messages, initialChatStatus_1 = _a.status, initialChatId_1 = _a.id;
792
+ setChatStack([{ type: exports.ChatPageType.CHAT, id: initialChatId_1 }]);
793
+ return [4, sleep()];
794
+ case 1:
795
+ _b.sent();
796
+ seedPresented(initialChatId_1, initialChatMessages_1.map(function (m) { return m.id; }));
797
+ setMessages(function (prev) {
798
+ var _a;
799
+ return (tslib.__assign(tslib.__assign({}, prev), (_a = {}, _a[initialChatId_1] = {
800
+ messages: initialChatMessages_1,
801
+ status: initialChatStatus_1,
802
+ id: initialChatId_1,
803
+ }, _a)));
804
+ });
805
+ return [3, 4];
806
+ case 2:
807
+ error_1 = _b.sent();
808
+ console.error(error_1);
809
+ return [3, 4];
810
+ case 3:
811
+ setIsInitialLoading(false);
812
+ return [7];
813
+ case 4: return [2];
814
+ }
815
+ });
816
+ }); };
817
+ react.useEffect(function () {
818
+ seedInitialChat();
819
+ }, []);
820
+ var handleChunk = react.useCallback(function (_a) {
821
+ _a.chunk; _a.chatId;
822
+ }, []);
823
+ react.useEffect(function () {
824
+ var removeChunkListener = chat.on(talosUseChat.ChatEventName.CHUNK, handleChunk);
825
+ return function () {
826
+ removeChunkListener();
827
+ };
828
+ }, [chat, handleChunk]);
829
+ var pushUserMessage = function (message) {
830
+ var userMessageWidget = formUserMessageWidget(message);
831
+ setMessages(function (prev) {
832
+ var _a;
833
+ var _b, _c;
834
+ return (tslib.__assign(tslib.__assign({}, prev), (_a = {}, _a[currentChatId] = tslib.__assign(tslib.__assign({}, prev[currentChatId]), { messages: tslib.__spreadArray(tslib.__spreadArray([], ((_c = (_b = prev[currentChatId]) === null || _b === void 0 ? void 0 : _b.messages) !== null && _c !== void 0 ? _c : []), true), [{ id: uuid.v4(), type: "USER_MESSAGE", chunks: [userMessageWidget], metaData: { createdAt: Date.now() } }], false) }), _a)));
835
+ });
836
+ };
837
+ var handleBotMessage = function () { return tslib.__awaiter(void 0, void 0, void 0, function () {
838
+ var error_2;
839
+ return tslib.__generator(this, function (_a) {
840
+ switch (_a.label) {
841
+ case 0:
842
+ _a.trys.push([0, 2, 3, 4]);
843
+ setIsReplyLoading(true);
844
+ return [4, sleep()];
845
+ case 1:
846
+ _a.sent();
847
+ setMessages(function (prev) {
848
+ var _a;
849
+ var _b, _c;
850
+ return (tslib.__assign(tslib.__assign({}, prev), (_a = {}, _a[currentChatId] = tslib.__assign(tslib.__assign({}, prev[currentChatId]), { messages: tslib.__spreadArray(tslib.__spreadArray([], ((_c = (_b = prev[currentChatId]) === null || _b === void 0 ? void 0 : _b.messages) !== null && _c !== void 0 ? _c : []), true), [{ id: uuid.v4(), type: "BOT_MESSAGE", chunks: [BOT_INTERACTION_WIDGET], metaData: { createdAt: Date.now(), messageId: uuid.v4() } }], false) }), _a)));
851
+ });
852
+ return [3, 4];
853
+ case 2:
854
+ error_2 = _a.sent();
855
+ console.error(error_2);
856
+ return [3, 4];
857
+ case 3:
858
+ setIsReplyLoading(false);
859
+ return [7];
860
+ case 4: return [2];
861
+ }
862
+ });
863
+ }); };
864
+ var sendMessage = react.useCallback(function (message) { return tslib.__awaiter(void 0, void 0, void 0, function () {
865
+ return tslib.__generator(this, function (_a) {
866
+ switch (_a.label) {
867
+ case 0:
868
+ pushUserMessage(message);
869
+ handleBotMessage();
870
+ return [4, baseSendMessage(message)];
871
+ case 1:
872
+ _a.sent();
873
+ return [2];
874
+ }
875
+ });
876
+ }); }, [baseSendMessage, pushUserMessage]);
877
+ var getPreviousChats = function () { return tslib.__awaiter(void 0, void 0, void 0, function () {
878
+ var error_3;
879
+ return tslib.__generator(this, function (_a) {
880
+ switch (_a.label) {
881
+ case 0:
882
+ _a.trys.push([0, 2, 3, 4]);
883
+ setPreviousChatLoading(true);
884
+ return [4, sleep()];
885
+ case 1:
886
+ _a.sent();
887
+ setPreviousChats(PREVIOUS_CHAT_LISTING.response);
888
+ return [3, 4];
889
+ case 2:
890
+ error_3 = _a.sent();
891
+ console.error(error_3);
892
+ return [3, 4];
893
+ case 3:
894
+ setPreviousChatLoading(false);
895
+ return [7];
896
+ case 4: return [2];
897
+ }
898
+ });
899
+ }); };
900
+ var pushToChatStack = function (item) {
901
+ setChatStack(function (prev) { return tslib.__spreadArray(tslib.__spreadArray([], prev, true), [item], false); });
902
+ };
903
+ var popFromChatStack = function () {
904
+ setChatStack(function (prev) { return prev.slice(0, -1); });
905
+ };
906
+ var clearChatStack = function () {
907
+ setChatStack([]);
908
+ };
909
+ var clearMessages = function () {
910
+ setMessages({});
911
+ };
912
+ var handleCreateNewChat = function () {
913
+ clearChatStack();
914
+ clearMessages();
915
+ seedInitialChat();
916
+ };
917
+ var getPreviousChatById = function (id) { return tslib.__awaiter(void 0, void 0, void 0, function () {
918
+ var MOCK_PREVIOUS_CHATS, previousChat_1, error_4;
919
+ return tslib.__generator(this, function (_a) {
920
+ switch (_a.label) {
921
+ case 0:
922
+ MOCK_PREVIOUS_CHATS = [PREVIOUS_CHAT_1, PREVIOUS_CHAT_2, PREVIOUS_CHAT_3];
923
+ if (messages.hasOwnProperty(id)) {
924
+ pushToChatStack({ type: exports.ChatPageType.PREVIOUS_CHAT, id: id });
925
+ return [2];
926
+ }
927
+ _a.label = 1;
928
+ case 1:
929
+ _a.trys.push([1, 3, 4, 5]);
930
+ setIsInitialLoading(true);
931
+ pushToChatStack({ type: exports.ChatPageType.PREVIOUS_CHAT, id: id });
932
+ return [4, sleep()];
933
+ case 2:
934
+ _a.sent();
935
+ previousChat_1 = MOCK_PREVIOUS_CHATS.find(function (chat) { return chat.id === id; });
936
+ if (previousChat_1) {
937
+ seedPresented(id, previousChat_1.messages.map(function (m) { return m.id; }));
938
+ setMessages(function (prev) {
939
+ var _a;
940
+ return (tslib.__assign(tslib.__assign({}, prev), (_a = {}, _a[id] = tslib.__assign(tslib.__assign({}, prev[id]), { messages: previousChat_1.messages, status: previousChat_1.status, pageData: previousChat_1.pageData }), _a)));
941
+ });
942
+ }
943
+ return [3, 5];
944
+ case 3:
945
+ error_4 = _a.sent();
946
+ console.error(error_4);
947
+ return [3, 5];
948
+ case 4:
949
+ setIsInitialLoading(false);
950
+ return [7];
951
+ case 5: return [2];
952
+ }
953
+ });
954
+ }); };
955
+ var _h = useChatAction({ sendMessage: sendMessage, pushToChatStack: pushToChatStack, getPreviousChatById: getPreviousChatById, handleCreateNewChat: handleCreateNewChat }), dispatch = _h.dispatch, dispatchAll = _h.dispatchAll;
956
+ return {
957
+ chat: chat,
958
+ chatStack: chatStack,
959
+ messages: messages,
960
+ previousChats: previousChats,
961
+ previousChatLoading: previousChatLoading,
962
+ status: status,
963
+ isInitialLoading: isInitialLoading,
964
+ isReplyLoading: isReplyLoading,
965
+ dispatch: dispatch,
966
+ dispatchAll: dispatchAll,
967
+ pushToChatStack: pushToChatStack,
968
+ popFromChatStack: popFromChatStack,
969
+ getPreviousChats: getPreviousChats,
970
+ clearChatStack: clearChatStack,
971
+ sendMessage: sendMessage,
972
+ stop: stop,
973
+ hasPresented: hasPresented,
974
+ markPresented: markPresented,
975
+ };
976
+ };
977
+
978
+ var ChatDispatchContext = react.createContext(null);
979
+ var ChatDispatchProvider = function (_a) {
980
+ var dispatch = _a.dispatch, dispatchAll = _a.dispatchAll, hasPresented = _a.hasPresented, markPresented = _a.markPresented, children = _a.children;
981
+ return (jsxRuntime.jsx(ChatDispatchContext.Provider, tslib.__assign({ value: { dispatch: dispatch, dispatchAll: dispatchAll, hasPresented: hasPresented, markPresented: markPresented } }, { children: children })));
982
+ };
983
+ var useDispatch = function () {
984
+ var _a;
985
+ var dispatch = ((_a = react.useContext(ChatDispatchContext)) !== null && _a !== void 0 ? _a : {}).dispatch;
986
+ if (!dispatch)
987
+ throw new Error("useDispatch must be used within ChatDispatchProvider");
988
+ return dispatch;
989
+ };
990
+ var useDispatchAll = function () {
991
+ var _a;
992
+ var dispatchAll = ((_a = react.useContext(ChatDispatchContext)) !== null && _a !== void 0 ? _a : {}).dispatchAll;
993
+ if (!dispatchAll)
994
+ throw new Error("useDispatchAll must be used within ChatDispatchProvider");
995
+ return dispatchAll;
996
+ };
997
+ var useAppDispatch = function () {
998
+ var dispatch = useDispatch();
999
+ var dispatchAll = useDispatchAll();
1000
+ return { dispatch: dispatch, dispatchAll: dispatchAll };
1001
+ };
1002
+ var usePresentation = function () {
1003
+ var _a;
1004
+ var _b = (_a = react.useContext(ChatDispatchContext)) !== null && _a !== void 0 ? _a : {}, hasPresented = _b.hasPresented, markPresented = _b.markPresented;
1005
+ if (!hasPresented || !markPresented)
1006
+ throw new Error("usePresentation must be used within ChatDispatchProvider");
1007
+ return { hasPresented: hasPresented, markPresented: markPresented };
1008
+ };
1009
+ var useChatContext = function () {
1010
+ var _a;
1011
+ var _b = (_a = react.useContext(ChatDispatchContext)) !== null && _a !== void 0 ? _a : {}, dispatch = _b.dispatch, dispatchAll = _b.dispatchAll, hasPresented = _b.hasPresented, markPresented = _b.markPresented;
1012
+ if (!dispatch || !dispatchAll || !hasPresented || !markPresented)
1013
+ throw new Error("useChatContext must be used within ChatDispatchProvider");
1014
+ return { dispatch: dispatch, dispatchAll: dispatchAll, hasPresented: hasPresented, markPresented: markPresented };
1015
+ };
1016
+
1017
+ exports.ChatDispatchProvider = ChatDispatchProvider;
1018
+ exports.useAppDispatch = useAppDispatch;
1019
+ exports.useChatAction = useChatAction;
1020
+ exports.useChatContext = useChatContext;
1021
+ exports.useChatController = useChatController;
1022
+ exports.useDispatch = useDispatch;
1023
+ exports.useDispatchAll = useDispatchAll;
1024
+ exports.usePresentation = usePresentation;
1025
+ //# sourceMappingURL=talos-use-chat-controller.cjs.js.map