aizek-chatbot 1.0.15 → 1.0.20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.cjs CHANGED
@@ -4,39 +4,1470 @@ var react = require('react');
4
4
  var jsxRuntime = require('react/jsx-runtime');
5
5
  var ReactMarkdown = require('react-markdown');
6
6
  var remarkGfm = require('remark-gfm');
7
- var Anthropic = require('@anthropic-ai/sdk');
8
- var client = require('@modelcontextprotocol/sdk/client');
9
- var sse_js = require('@modelcontextprotocol/sdk/client/sse.js');
10
7
 
11
8
  function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
12
9
 
13
10
  var ReactMarkdown__default = /*#__PURE__*/_interopDefault(ReactMarkdown);
14
11
  var remarkGfm__default = /*#__PURE__*/_interopDefault(remarkGfm);
15
- var Anthropic__default = /*#__PURE__*/_interopDefault(Anthropic);
16
-
17
- // src/services/chat-widget-api.ts
18
- var API_BASE_URL = "https://api-alpha.aizek.ai";
19
- var fetchChatWidgetSettings = async (clientId) => {
20
- try {
21
- const response = await fetch(`${API_BASE_URL}/ChatWidgetSettings/GetByClientId?client_id=${clientId}`, {
22
- method: "GET",
23
- headers: {
24
- "Content-Type": "application/json"
25
- }
26
- });
27
- if (!response.ok) {
28
- throw new Error(`HTTP error! status: ${response.status}`);
29
- }
30
- const data = await response.json();
31
- return data;
32
- } catch (error) {
33
- console.error("Error fetching chat widget settings:", error);
34
- throw error;
12
+
13
+ // src/styles/index.module.scss
14
+ var css = `@charset "UTF-8";
15
+ .message-container {
16
+ display: flex;
17
+ flex-direction: column;
18
+ width: 100%;
19
+ }
20
+ .message-container.user {
21
+ align-items: flex-end;
22
+ }
23
+ .message-container.assistant {
24
+ align-items: flex-start;
25
+ }
26
+
27
+ .message-bubble {
28
+ max-width: 80%;
29
+ padding: 12px 16px;
30
+ margin-bottom: 8px;
31
+ word-wrap: break-word;
32
+ line-height: 1.4;
33
+ font-size: 14px;
34
+ position: relative;
35
+ }
36
+ .message-bubble.user {
37
+ border-radius: 18px 18px 4px 18px;
38
+ background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
39
+ color: #ffffff;
40
+ margin-left: auto;
41
+ margin-right: 0;
42
+ }
43
+ .message-bubble.assistant {
44
+ border-radius: 18px 18px 18px 4px;
45
+ background: #f8fafc;
46
+ color: #334155;
47
+ border: 1px solid #e2e8f0;
48
+ margin-left: 0;
49
+ margin-right: auto;
50
+ }
51
+ .message-bubble .message-typing-indicator {
52
+ display: inline-flex;
53
+ align-items: center;
54
+ margin-left: 8px;
55
+ }
56
+
57
+ .message-time {
58
+ font-size: 11px;
59
+ opacity: 0.7;
60
+ margin-top: 4px;
61
+ }
62
+
63
+ .message-time.user {
64
+ text-align: right;
65
+ }
66
+
67
+ .message-time.assistant {
68
+ text-align: left;
69
+ }
70
+
71
+ .markdown-content {
72
+ line-height: 1.6;
73
+ word-break: break-word;
74
+ }
75
+ .markdown-content + .generative-ui-container {
76
+ margin-top: 16px;
77
+ }
78
+ .markdown-content p {
79
+ margin: 0 0 12px 0;
80
+ line-height: 1.6;
81
+ }
82
+ .markdown-content p:last-child {
83
+ margin-bottom: 0;
84
+ }
85
+ .markdown-content p:first-child {
86
+ margin-top: 0;
87
+ }
88
+ .markdown-content a {
89
+ color: #667eea;
90
+ text-decoration: none;
91
+ transition: all 0.15s ease;
92
+ font-weight: 500;
93
+ border-bottom: 1px solid transparent;
94
+ }
95
+ .markdown-content a:hover {
96
+ color: #764ba2;
97
+ border-bottom-color: #764ba2;
98
+ }
99
+ .markdown-content ul,
100
+ .markdown-content ol {
101
+ margin: 12px 0;
102
+ padding-left: 20px;
103
+ }
104
+ .markdown-content ul {
105
+ list-style: none;
106
+ padding-left: 0;
107
+ }
108
+ .markdown-content ol {
109
+ list-style: decimal;
110
+ }
111
+ .markdown-content li {
112
+ margin-bottom: 8px;
113
+ line-height: 1.6;
114
+ position: relative;
115
+ padding-left: 20px;
116
+ }
117
+ .markdown-content li:last-child {
118
+ margin-bottom: 0;
119
+ }
120
+ .markdown-content li::before {
121
+ content: "\u2022";
122
+ position: absolute;
123
+ left: 0;
124
+ color: #667eea;
125
+ font-weight: bold;
126
+ font-size: 16px;
127
+ }
128
+ .markdown-content li ul,
129
+ .markdown-content li ol {
130
+ margin-top: 4px;
131
+ margin-bottom: 4px;
132
+ }
133
+ .markdown-content ol li {
134
+ padding-left: 0;
135
+ }
136
+ .markdown-content ol li::before {
137
+ content: none;
138
+ }
139
+ .markdown-content code {
140
+ background: rgba(102, 126, 234, 0.1);
141
+ color: #764ba2;
142
+ padding: 2px 6px;
143
+ border-radius: 4px;
144
+ font-family: "Monaco", "Menlo", "Ubuntu Mono", "Courier New", monospace;
145
+ font-size: 0.9em;
146
+ border: 1px solid rgba(102, 126, 234, 0.2);
147
+ }
148
+ .markdown-content pre {
149
+ background: #f8fafc;
150
+ padding: 12px 16px;
151
+ border-radius: 8px;
152
+ overflow-x: auto;
153
+ margin: 12px 0;
154
+ border: 1px solid #e2e8f0;
155
+ box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
156
+ }
157
+ .markdown-content pre code {
158
+ background: none;
159
+ padding: 0;
160
+ border: none;
161
+ color: #1e293b;
162
+ font-size: 12px;
163
+ line-height: 1.5;
164
+ }
165
+ .markdown-content strong,
166
+ .markdown-content b {
167
+ font-weight: 600;
168
+ color: inherit;
169
+ }
170
+ .markdown-content em,
171
+ .markdown-content i {
172
+ font-style: italic;
173
+ }
174
+ .markdown-content h1,
175
+ .markdown-content h2,
176
+ .markdown-content h3,
177
+ .markdown-content h4,
178
+ .markdown-content h5,
179
+ .markdown-content h6 {
180
+ margin: 16px 0 8px 0;
181
+ font-weight: 600;
182
+ line-height: 1.4;
183
+ color: inherit;
184
+ }
185
+ .markdown-content h1:first-child,
186
+ .markdown-content h2:first-child,
187
+ .markdown-content h3:first-child,
188
+ .markdown-content h4:first-child,
189
+ .markdown-content h5:first-child,
190
+ .markdown-content h6:first-child {
191
+ margin-top: 0;
192
+ }
193
+ .markdown-content h1 {
194
+ font-size: 18px;
195
+ border-bottom: 2px solid #e2e8f0;
196
+ padding-bottom: 8px;
197
+ }
198
+ .markdown-content h2 {
199
+ font-size: 16px;
200
+ }
201
+ .markdown-content h3 {
202
+ font-size: 15px;
203
+ }
204
+ .markdown-content h4,
205
+ .markdown-content h5,
206
+ .markdown-content h6 {
207
+ font-size: 14px;
208
+ }
209
+ .markdown-content blockquote {
210
+ border-left: 3px solid #667eea;
211
+ padding-left: 12px;
212
+ margin: 12px 0;
213
+ color: inherit;
214
+ opacity: 0.9;
215
+ font-style: italic;
216
+ background: rgba(102, 126, 234, 0.05);
217
+ padding: 8px 12px;
218
+ border-radius: 0 4px 4px 0;
219
+ }
220
+ .markdown-content blockquote p {
221
+ margin: 0;
222
+ }
223
+ .markdown-content hr {
224
+ border: none;
225
+ border-top: 1px solid #e2e8f0;
226
+ margin: 16px 0;
227
+ }
228
+ .markdown-content table {
229
+ border-collapse: collapse;
230
+ width: 100%;
231
+ margin: 12px 0;
232
+ font-size: 12px;
233
+ border-radius: 8px;
234
+ overflow: hidden;
235
+ border: 1px solid #e2e8f0;
236
+ }
237
+ .markdown-content th,
238
+ .markdown-content td {
239
+ padding: 10px 12px;
240
+ text-align: left;
241
+ border-bottom: 1px solid #e2e8f0;
242
+ }
243
+ .markdown-content th {
244
+ background: #f1f5f9;
245
+ font-weight: 600;
246
+ color: #1e293b;
247
+ border-bottom: 2px solid #cbd5e1;
248
+ }
249
+ .markdown-content tr:last-child td {
250
+ border-bottom: none;
251
+ }
252
+ .markdown-content tbody tr {
253
+ transition: background-color 0.15s ease;
254
+ }
255
+ .markdown-content tbody tr:hover {
256
+ background-color: rgba(102, 126, 234, 0.05);
257
+ }
258
+ .markdown-content img {
259
+ max-width: 100%;
260
+ height: auto;
261
+ border-radius: 8px;
262
+ margin: 8px 0;
263
+ }
264
+ .markdown-content input[type=checkbox] {
265
+ margin-right: 6px;
266
+ }
267
+
268
+ .message-bubble.user .markdown-content {
269
+ color: #ffffff;
270
+ }
271
+ .message-bubble.user .markdown-content a {
272
+ color: #ffffff;
273
+ border-bottom-color: rgba(255, 255, 255, 0.4);
274
+ font-weight: 600;
275
+ }
276
+ .message-bubble.user .markdown-content a:hover {
277
+ border-bottom-color: #ffffff;
278
+ }
279
+ .message-bubble.user .markdown-content li::before {
280
+ color: #ffffff;
281
+ }
282
+ .message-bubble.user .markdown-content code {
283
+ background: rgba(255, 255, 255, 0.2);
284
+ color: #ffffff;
285
+ border-color: rgba(255, 255, 255, 0.3);
286
+ }
287
+ .message-bubble.user .markdown-content pre {
288
+ background: rgba(255, 255, 255, 0.1);
289
+ border-color: rgba(255, 255, 255, 0.2);
290
+ }
291
+ .message-bubble.user .markdown-content pre code {
292
+ color: #ffffff;
293
+ }
294
+ .message-bubble.user .markdown-content h1 {
295
+ border-bottom-color: rgba(255, 255, 255, 0.3);
296
+ }
297
+ .message-bubble.user .markdown-content blockquote {
298
+ border-left-color: #ffffff;
299
+ background: rgba(255, 255, 255, 0.1);
300
+ color: #ffffff;
301
+ }
302
+ .message-bubble.user .markdown-content hr {
303
+ border-top-color: rgba(255, 255, 255, 0.3);
304
+ }
305
+ .message-bubble.user .markdown-content table {
306
+ border-color: rgba(255, 255, 255, 0.3);
307
+ }
308
+ .message-bubble.user .markdown-content th,
309
+ .message-bubble.user .markdown-content td {
310
+ border-bottom-color: rgba(255, 255, 255, 0.2);
311
+ }
312
+ .message-bubble.user .markdown-content th {
313
+ background: rgba(255, 255, 255, 0.15);
314
+ color: #ffffff;
315
+ border-bottom-color: rgba(255, 255, 255, 0.3);
316
+ }
317
+ .message-bubble.user .markdown-content tbody tr:hover {
318
+ background-color: rgba(255, 255, 255, 0.1);
319
+ }
320
+
321
+ .message-bubble.assistant .markdown-content {
322
+ color: #334155;
323
+ }
324
+ .message-bubble.assistant .markdown-content a {
325
+ color: #667eea;
326
+ }
327
+ .message-bubble.assistant .markdown-content a:hover {
328
+ color: #764ba2;
329
+ }
330
+ .message-bubble.assistant .markdown-content li::before {
331
+ color: #667eea;
332
+ }
333
+ .message-bubble.assistant .markdown-content code {
334
+ background: rgba(102, 126, 234, 0.1);
335
+ color: #764ba2;
336
+ border-color: rgba(102, 126, 234, 0.2);
337
+ }
338
+ .message-bubble.assistant .markdown-content pre {
339
+ background: #ffffff;
340
+ border-color: #e2e8f0;
341
+ }
342
+ .message-bubble.assistant .markdown-content pre code {
343
+ color: #1e293b;
344
+ }
345
+ .message-bubble.assistant .markdown-content h1,
346
+ .message-bubble.assistant .markdown-content h2,
347
+ .message-bubble.assistant .markdown-content h3,
348
+ .message-bubble.assistant .markdown-content h4,
349
+ .message-bubble.assistant .markdown-content h5,
350
+ .message-bubble.assistant .markdown-content h6 {
351
+ color: #1e293b;
352
+ }
353
+ .message-bubble.assistant .markdown-content h1 {
354
+ border-bottom-color: #e2e8f0;
355
+ }
356
+ .message-bubble.assistant .markdown-content strong,
357
+ .message-bubble.assistant .markdown-content b {
358
+ color: #0f172a;
359
+ }
360
+ .message-bubble.assistant .markdown-content blockquote {
361
+ border-left-color: #667eea;
362
+ background: rgba(102, 126, 234, 0.05);
363
+ color: #334155;
364
+ }
365
+ .message-bubble.assistant .markdown-content th {
366
+ background: #f1f5f9;
367
+ color: #1e293b;
368
+ }
369
+ .message-bubble.assistant .markdown-content tbody tr:hover {
370
+ background-color: rgba(102, 126, 234, 0.05);
371
+ }
372
+
373
+ .input-container {
374
+ display: flex;
375
+ align-items: flex-end;
376
+ gap: 12px;
377
+ padding: 16px;
378
+ background: #ffffff;
379
+ border-top: 1px solid #e2e8f0;
380
+ border-radius: 0 0 12px 12px;
381
+ }
382
+
383
+ .textarea {
384
+ flex: 1;
385
+ min-height: 44px;
386
+ max-height: 120px;
387
+ padding: 12px 16px;
388
+ border: 1px solid #e2e8f0;
389
+ border-radius: 22px;
390
+ font-size: 14px;
391
+ line-height: 1.4;
392
+ resize: none;
393
+ outline: none;
394
+ transition: border-color 0.2s ease, box-shadow 0.2s ease;
395
+ font-family: inherit;
396
+ background: #f8fafc;
397
+ color: #334155;
398
+ }
399
+ .textarea:disabled {
400
+ opacity: 0.6;
401
+ cursor: not-allowed;
402
+ }
403
+ .textarea:focus:not(:disabled) {
404
+ border-color: #3b82f6;
405
+ box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
406
+ }
407
+
408
+ .send-button {
409
+ width: 44px;
410
+ height: 44px;
411
+ border-radius: 50%;
412
+ border: none;
413
+ color: #ffffff;
414
+ cursor: pointer;
415
+ display: flex;
416
+ align-items: center;
417
+ justify-content: center;
418
+ transition: all 0.2s ease;
419
+ font-size: 16px;
420
+ }
421
+ .send-button:disabled {
422
+ background: #e2e8f0;
423
+ cursor: not-allowed;
424
+ }
425
+ .send-button:not(:disabled) {
426
+ background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
427
+ }
428
+ .send-button:not(:disabled):hover {
429
+ transform: scale(1.05);
430
+ }
431
+
432
+ .header {
433
+ padding: 16px 20px;
434
+ color: #ffffff;
435
+ display: flex;
436
+ align-items: center;
437
+ gap: 12px;
438
+ }
439
+
440
+ .logo-container {
441
+ width: 40px;
442
+ height: 40px;
443
+ border-radius: 50%;
444
+ background: rgba(255, 255, 255, 0.2);
445
+ display: flex;
446
+ align-items: center;
447
+ justify-content: center;
448
+ font-size: 18px;
449
+ overflow: hidden;
450
+ }
451
+
452
+ .logo-image {
453
+ width: 100%;
454
+ height: 100%;
455
+ object-fit: cover;
456
+ border-radius: 50%;
457
+ }
458
+
459
+ .logo-text {
460
+ font-size: 16px;
461
+ font-weight: bold;
462
+ }
463
+
464
+ .company-name {
465
+ margin: 0;
466
+ font-size: 16px;
467
+ font-weight: 600;
468
+ }
469
+
470
+ .status-text {
471
+ margin: 0;
472
+ font-size: 12px;
473
+ opacity: 0.8;
474
+ }
475
+
476
+ .button-sizes.small {
477
+ width: 50px;
478
+ height: 50px;
479
+ font-size: 20px;
480
+ }
481
+ .button-sizes.medium {
482
+ width: 60px;
483
+ height: 60px;
484
+ font-size: 24px;
485
+ }
486
+ .button-sizes.large {
487
+ width: 70px;
488
+ height: 70px;
489
+ font-size: 28px;
490
+ }
491
+
492
+ .floating-button {
493
+ position: fixed;
494
+ bottom: 20px;
495
+ border-radius: 50%;
496
+ border: none;
497
+ color: #ffffff;
498
+ cursor: pointer;
499
+ display: flex;
500
+ align-items: center;
501
+ justify-content: center;
502
+ box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
503
+ transition: all 0.3s ease;
504
+ z-index: 1000;
505
+ }
506
+ .floating-button.bottom-left {
507
+ left: 20px;
508
+ }
509
+ .floating-button.bottom-right {
510
+ right: 20px;
511
+ }
512
+ .floating-button.is-open {
513
+ transform: scale(0.9);
514
+ }
515
+ .floating-button:hover {
516
+ box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25);
517
+ }
518
+
519
+ .chat-container {
520
+ position: fixed;
521
+ bottom: 90px;
522
+ z-index: 9999999;
523
+ transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
524
+ }
525
+ .chat-container.bottom-left {
526
+ left: 20px;
527
+ transform-origin: bottom left;
528
+ }
529
+ .chat-container.bottom-right {
530
+ right: 20px;
531
+ transform-origin: bottom right;
532
+ }
533
+ .chat-container.is-open {
534
+ transform: translateY(0) scale(1);
535
+ opacity: 1;
536
+ visibility: visible;
537
+ }
538
+ .chat-container:not(.is-open) {
539
+ transform: translateY(20px) scale(0.95);
540
+ opacity: 0;
541
+ visibility: hidden;
542
+ }
543
+
544
+ .overlay {
545
+ position: fixed;
546
+ top: 0;
547
+ left: 0;
548
+ right: 0;
549
+ bottom: 0;
550
+ background: rgba(0, 0, 0, 0.1);
551
+ z-index: 998;
552
+ transition: all 0.3s ease;
553
+ }
554
+ .overlay.is-open {
555
+ opacity: 1;
556
+ visibility: visible;
557
+ }
558
+ .overlay:not(.is-open) {
559
+ opacity: 0;
560
+ visibility: hidden;
561
+ }
562
+
563
+ .chatbot-container {
564
+ display: flex;
565
+ flex-direction: column;
566
+ height: 100%;
567
+ background: #ffffff;
568
+ border-radius: 12px;
569
+ box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
570
+ border: 1px solid #e2e8f0;
571
+ overflow: hidden;
572
+ }
573
+
574
+ .messages-container {
575
+ flex: 1;
576
+ overflow-y: auto;
577
+ padding: 16px;
578
+ display: flex;
579
+ flex-direction: column;
580
+ gap: 4px;
581
+ background: #f8fafc;
582
+ }
583
+
584
+ .empty-state {
585
+ display: flex;
586
+ flex-direction: column;
587
+ align-items: center;
588
+ justify-content: center;
589
+ height: 100%;
590
+ color: #64748b;
591
+ text-align: center;
592
+ padding: 40px 20px;
593
+ }
594
+ .empty-state .empty-state-icon {
595
+ font-size: 48px;
596
+ margin-bottom: 16px;
597
+ }
598
+ .empty-state .empty-state-title {
599
+ margin: 0 0 8px 0;
600
+ font-size: 18px;
601
+ }
602
+ .empty-state .empty-state-description {
603
+ margin: 0;
604
+ font-size: 14px;
605
+ opacity: 0.8;
606
+ }
607
+
608
+ @keyframes spin {
609
+ from {
610
+ transform: rotate(0deg);
35
611
  }
36
- };
612
+ to {
613
+ transform: rotate(360deg);
614
+ }
615
+ }
616
+ .loading-spinner {
617
+ width: 16px;
618
+ height: 16px;
619
+ border: 2px solid transparent;
620
+ border-top: 2px solid currentColor;
621
+ border-radius: 50%;
622
+ animation: spin 1s linear infinite;
623
+ }
624
+
625
+ @keyframes slideDown {
626
+ from {
627
+ opacity: 0;
628
+ transform: translateY(-10px);
629
+ }
630
+ to {
631
+ opacity: 1;
632
+ transform: translateY(0);
633
+ }
634
+ }
635
+ .alert-container {
636
+ border-radius: 12px;
637
+ padding: 14px 16px;
638
+ margin: 12px 16px;
639
+ box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
640
+ color: #ffffff;
641
+ font-size: 13px;
642
+ display: flex;
643
+ align-items: flex-start;
644
+ gap: 12px;
645
+ position: relative;
646
+ animation: slideDown 0.3s ease ease-out;
647
+ }
648
+ .alert-container.error {
649
+ background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
650
+ border: 1px solid #dc2626;
651
+ box-shadow: 0 4px 12px rgba(239, 68, 68, 0.2);
652
+ }
653
+ .alert-container.warning {
654
+ background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
655
+ border: 1px solid #d97706;
656
+ box-shadow: 0 4px 12px rgba(245, 158, 11, 0.2);
657
+ }
658
+ .alert-container.success {
659
+ background: linear-gradient(135deg, #10b981 0%, #059669 100%);
660
+ border: 1px solid #059669;
661
+ box-shadow: 0 4px 12px rgba(16, 185, 129, 0.2);
662
+ }
663
+
664
+ .alert-icon-container {
665
+ display: flex;
666
+ align-items: center;
667
+ justify-content: center;
668
+ width: 24px;
669
+ height: 24px;
670
+ flex-shrink: 0;
671
+ margin-top: 2px;
672
+ }
673
+
674
+ .alert-content {
675
+ flex: 1;
676
+ display: flex;
677
+ flex-direction: column;
678
+ gap: 8px;
679
+ }
680
+
681
+ .alert-title {
682
+ font-weight: 600;
683
+ font-size: 14px;
684
+ margin: 0;
685
+ line-height: 1.4;
686
+ }
687
+
688
+ .alert-message {
689
+ margin: 0;
690
+ line-height: 1.5;
691
+ opacity: 0.95;
692
+ }
693
+
694
+ .alert-list {
695
+ margin: 8px 0 0 0;
696
+ padding-left: 20px;
697
+ list-style: none;
698
+ }
699
+
700
+ .alert-list-item {
701
+ margin-bottom: 4px;
702
+ position: relative;
703
+ padding-left: 12px;
704
+ line-height: 1.4;
705
+ }
706
+ .alert-list-item li > span {
707
+ position: "absolute";
708
+ left: 0;
709
+ top: 2px;
710
+ font-weight: bold;
711
+ }
712
+ .alert-list-item li > code {
713
+ background: rgba(255, 255, 255, 0.2);
714
+ padding: 2px 6px;
715
+ border-radius: 4px;
716
+ font-size: 12px;
717
+ }
718
+
719
+ .alert-close-button {
720
+ position: absolute;
721
+ top: 12px;
722
+ right: 12px;
723
+ background: rgba(255, 255, 255, 0.2);
724
+ border: none;
725
+ border-radius: 6px;
726
+ width: 24px;
727
+ height: 24px;
728
+ display: flex;
729
+ align-items: center;
730
+ justify-content: center;
731
+ cursor: pointer;
732
+ color: #ffffff;
733
+ transition: all 0.2s ease;
734
+ padding: 0;
735
+ }
736
+ .alert-close-button:hover {
737
+ background: rgba(255, 255, 255, 0.3);
738
+ }
739
+
740
+ .ui-renderer {
741
+ display: flex;
742
+ flex-direction: column;
743
+ gap: 16px;
744
+ width: 100%;
745
+ }
746
+
747
+ .form-component {
748
+ width: 100%;
749
+ max-width: 500px;
750
+ border: 1px solid #e0e0e0;
751
+ border-radius: 12px;
752
+ padding: 24px;
753
+ background-color: #ffffff;
754
+ box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
755
+ font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
756
+ }
757
+
758
+ .form-title {
759
+ font-weight: 600;
760
+ font-size: 16px;
761
+ margin-bottom: 20px;
762
+ color: #1a1a1a;
763
+ margin-top: 0;
764
+ }
765
+
766
+ .form-fields {
767
+ display: flex;
768
+ flex-direction: column;
769
+ gap: 20px;
770
+ }
771
+
772
+ .form-field {
773
+ display: flex;
774
+ flex-direction: column;
775
+ gap: 8px;
776
+ }
777
+
778
+ .form-label {
779
+ font-weight: 500;
780
+ font-size: 13px;
781
+ color: #475569;
782
+ display: flex;
783
+ align-items: center;
784
+ gap: 4px;
785
+ }
786
+ .form-label span {
787
+ color: #ef4444;
788
+ font-size: 12px;
789
+ }
790
+
791
+ .form-input,
792
+ .form-select {
793
+ border: 1px solid #d1d5db;
794
+ border-radius: 8px;
795
+ padding: 10px 12px;
796
+ font-size: 13px;
797
+ color: #1a1a1a;
798
+ background-color: #ffffff;
799
+ font-family: inherit;
800
+ outline: none;
801
+ transition: border-color 0.15s ease, box-shadow 0.15s ease;
802
+ cursor: pointer;
803
+ }
804
+ .form-input:focus,
805
+ .form-select:focus {
806
+ border-color: #3b82f6;
807
+ box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
808
+ }
809
+
810
+ .form-select {
811
+ cursor: pointer;
812
+ }
813
+
814
+ .form-submit-button {
815
+ margin-top: 24px;
816
+ display: inline-flex;
817
+ align-items: center;
818
+ justify-content: center;
819
+ border-radius: 8px;
820
+ padding: 12px 24px;
821
+ font-size: 13px;
822
+ font-weight: 500;
823
+ background-color: #3b82f6;
824
+ color: #ffffff;
825
+ border: none;
826
+ cursor: pointer;
827
+ transition: background-color 0.15s ease, transform 0.1s ease;
828
+ font-family: inherit;
829
+ }
830
+ .form-submit-button:hover {
831
+ background-color: #2563eb;
832
+ }
833
+ .form-submit-button:active {
834
+ transform: scale(0.98);
835
+ }
836
+
837
+ .buttons-component {
838
+ display: flex;
839
+ gap: 12px;
840
+ flex-wrap: wrap;
841
+ }
842
+
843
+ .button-component {
844
+ border-radius: 8px;
845
+ padding: 10px 20px;
846
+ font-size: 13px;
847
+ font-weight: 500;
848
+ border: 1px solid #e0e0e0;
849
+ background-color: #ffffff;
850
+ color: #475569;
851
+ cursor: pointer;
852
+ transition: all 0.15s ease;
853
+ font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
854
+ outline: none;
855
+ }
856
+ .button-component.primary {
857
+ background-color: #3b82f6;
858
+ color: #ffffff;
859
+ border-color: #3b82f6;
860
+ }
861
+ .button-component.primary:hover {
862
+ background-color: #2563eb;
863
+ border-color: #2563eb;
864
+ }
865
+ .button-component.secondary {
866
+ background-color: #f3f4f6;
867
+ color: #475569;
868
+ border-color: #d1d5db;
869
+ }
870
+ .button-component.secondary:hover {
871
+ background-color: #e5e7eb;
872
+ border-color: #9ca3af;
873
+ }
874
+ .button-component.danger {
875
+ background-color: #ef4444;
876
+ color: #ffffff;
877
+ border-color: #ef4444;
878
+ }
879
+ .button-component.danger:hover {
880
+ background-color: #dc2626;
881
+ border-color: #dc2626;
882
+ }
883
+ .button-component:not(.primary):not(.secondary):not(.danger):hover {
884
+ background-color: #f9fafb;
885
+ border-color: #d1d5db;
886
+ }
887
+ .button-component:active {
888
+ transform: scale(0.97);
889
+ }
890
+
891
+ .table-component {
892
+ border: 1px solid #e0e0e0;
893
+ border-radius: 12px;
894
+ overflow: hidden;
895
+ font-size: 13px;
896
+ background-color: #ffffff;
897
+ box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
898
+ font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
899
+ }
900
+
901
+ .table-caption {
902
+ padding: 16px 20px;
903
+ font-weight: 600;
904
+ font-size: 14px;
905
+ border-bottom: 1px solid #e0e0e0;
906
+ background-color: #f8f9fa;
907
+ color: #1a1a1a;
908
+ }
909
+
910
+ .table-wrapper {
911
+ overflow-x: auto;
912
+ }
913
+
914
+ .table {
915
+ width: 100%;
916
+ border-collapse: collapse;
917
+ min-width: 100%;
918
+ }
919
+
920
+ .table-header {
921
+ background-color: #f8f9fa;
922
+ }
923
+
924
+ .table-th {
925
+ border-bottom: 2px solid #e0e0e0;
926
+ padding: 14px 20px;
927
+ text-align: left;
928
+ font-weight: 600;
929
+ font-size: 12px;
930
+ color: #4a5568;
931
+ text-transform: uppercase;
932
+ letter-spacing: 0.5px;
933
+ white-space: nowrap;
934
+ }
935
+
936
+ .table-tbody tr {
937
+ background-color: #ffffff;
938
+ transition: background-color 0.15s ease;
939
+ }
940
+ .table-tbody tr:nth-child(even) {
941
+ background-color: #fafbfc;
942
+ }
943
+ .table-tbody tr:hover {
944
+ background-color: #f0f4f8;
945
+ }
946
+
947
+ .table-td {
948
+ border-bottom: 1px solid #e8e8e8;
949
+ padding: 16px 20px;
950
+ font-size: 13px;
951
+ vertical-align: middle;
952
+ }
953
+ .table-td > span {
954
+ color: #a0a0a0;
955
+ font-style: italic;
956
+ }
957
+
958
+ .table-cell-image {
959
+ display: flex;
960
+ align-items: center;
961
+ }
962
+
963
+ .table-image {
964
+ width: 40px;
965
+ height: 40px;
966
+ border-radius: 8px;
967
+ object-fit: cover;
968
+ border: 1px solid #e0e0e0;
969
+ }
970
+
971
+ .table-cell-text {
972
+ color: #2d3748;
973
+ line-height: 1.5;
974
+ }
975
+
976
+ .table-empty {
977
+ padding: 40px;
978
+ text-align: center;
979
+ color: #9ca3af;
980
+ font-size: 13px;
981
+ }
982
+
983
+ .card-component {
984
+ border: 1px solid #e5e7eb;
985
+ border-radius: 16px;
986
+ padding: 16px;
987
+ background-color: #ffffff;
988
+ box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1);
989
+ overflow: hidden;
990
+ margin-bottom: 12px;
991
+ }
992
+
993
+ .card-content {
994
+ display: flex;
995
+ gap: 12px;
996
+ }
997
+
998
+ .card-image {
999
+ width: 64px;
1000
+ height: 64px;
1001
+ border-radius: 8px;
1002
+ object-fit: cover;
1003
+ flex-shrink: 0;
1004
+ }
1005
+
1006
+ .card-info {
1007
+ flex: 1;
1008
+ min-width: 0;
1009
+ }
1010
+
1011
+ .card-title {
1012
+ font-weight: 600;
1013
+ font-size: 14px;
1014
+ margin-bottom: 8px;
1015
+ overflow: hidden;
1016
+ text-overflow: ellipsis;
1017
+ white-space: nowrap;
1018
+ }
1019
+
1020
+ .card-subtitle {
1021
+ color: #64748b;
1022
+ font-size: 12px;
1023
+ margin-bottom: 4px;
1024
+ margin: 0;
1025
+ }
1026
+
1027
+ .card-status {
1028
+ display: flex;
1029
+ gap: 8px;
1030
+ font-size: 12px;
1031
+ margin-bottom: 4px;
1032
+ }
1033
+
1034
+ .card-status-label {
1035
+ color: #64748b;
1036
+ font-weight: 500;
1037
+ }
1038
+
1039
+ .card-status-value {
1040
+ color: #475569;
1041
+ }
1042
+
1043
+ .card-fields {
1044
+ display: flex;
1045
+ flex-direction: column;
1046
+ gap: 4px;
1047
+ }
1048
+
1049
+ .card-field {
1050
+ display: flex;
1051
+ gap: 8px;
1052
+ font-size: 12px;
1053
+ }
1054
+
1055
+ .card-field-label {
1056
+ color: #64748b;
1057
+ font-weight: 500;
1058
+ }
1059
+
1060
+ .card-field-value {
1061
+ color: #475569;
1062
+ }
1063
+
1064
+ .card-description {
1065
+ color: #64748b;
1066
+ font-size: 12px;
1067
+ margin-top: 8px;
1068
+ margin: 0;
1069
+ }
1070
+
1071
+ .card-list {
1072
+ width: 100%;
1073
+ }
1074
+
1075
+ .card-list-title {
1076
+ font-weight: 600;
1077
+ margin-bottom: 12px;
1078
+ font-size: 14px;
1079
+ color: #1a1a1a;
1080
+ margin-top: 0;
1081
+ }
1082
+
1083
+ .card-list-description {
1084
+ color: #64748b;
1085
+ margin-bottom: 12px;
1086
+ font-size: 12px;
1087
+ margin-top: 0;
1088
+ }
1089
+
1090
+ .card-grid {
1091
+ display: grid;
1092
+ grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
1093
+ gap: 12px;
1094
+ }
1095
+
1096
+ .card-item {
1097
+ font-size: 12px;
1098
+ border: 1px solid #e0e0e0;
1099
+ border-radius: 12px;
1100
+ padding: 16px;
1101
+ background-color: #ffffff;
1102
+ box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
1103
+ overflow: hidden;
1104
+ }
1105
+
1106
+ .card-item-content {
1107
+ display: flex;
1108
+ gap: 12px;
1109
+ }
1110
+
1111
+ .card-item-image {
1112
+ width: 64px;
1113
+ height: 64px;
1114
+ border-radius: 8px;
1115
+ object-fit: cover;
1116
+ flex-shrink: 0;
1117
+ }
1118
+
1119
+ .card-item-info {
1120
+ flex: 1;
1121
+ min-width: 0;
1122
+ }
1123
+
1124
+ .card-item-title {
1125
+ font-weight: 600;
1126
+ font-size: 14px;
1127
+ margin-bottom: 4px;
1128
+ overflow: hidden;
1129
+ text-overflow: ellipsis;
1130
+ white-space: nowrap;
1131
+ color: #1a1a1a;
1132
+ margin-top: 0;
1133
+ }
1134
+
1135
+ .card-item-subtitle {
1136
+ color: #64748b;
1137
+ font-size: 12px;
1138
+ margin: 0;
1139
+ }
1140
+
1141
+ .card-item-legacy {
1142
+ display: flex;
1143
+ justify-content: space-between;
1144
+ gap: 8px;
1145
+ font-size: 12px;
1146
+ }
1147
+
1148
+ .card-item-legacy-label {
1149
+ color: #64748b;
1150
+ margin: 0;
1151
+ }
1152
+
1153
+ .card-item-legacy-value {
1154
+ font-weight: 500;
1155
+ color: #1a1a1a;
1156
+ margin: 0;
1157
+ }
1158
+
1159
+ .field-image {
1160
+ width: 24px;
1161
+ height: 24px;
1162
+ border-radius: 999px;
1163
+ object-fit: cover;
1164
+ }
1165
+
1166
+ .field-link {
1167
+ text-decoration: underline;
1168
+ }
1169
+
1170
+ .field-badge {
1171
+ display: inline-block;
1172
+ padding: 2px 6px;
1173
+ border-radius: 999px;
1174
+ font-size: 10px;
1175
+ font-weight: 500;
1176
+ }
1177
+ .field-badge.success {
1178
+ background-color: #e0fce5;
1179
+ color: #1a7f36;
1180
+ }
1181
+ .field-badge.warning {
1182
+ background-color: #fff7d6;
1183
+ color: #8a6a00;
1184
+ }
1185
+ .field-badge.danger {
1186
+ background-color: #ffe4e4;
1187
+ color: #b42318;
1188
+ }
1189
+ .field-badge:not(.success):not(.warning):not(.danger) {
1190
+ background-color: #f2f2f2;
1191
+ color: #333;
1192
+ }
1193
+
1194
+ .field-list {
1195
+ margin: 0;
1196
+ padding-left: 16px;
1197
+ }
1198
+
1199
+ .generative-ui-container {
1200
+ display: flex;
1201
+ flex-direction: column;
1202
+ gap: 16px;
1203
+ width: 100%;
1204
+ }
1205
+
1206
+ .generative-ui-header {
1207
+ margin-bottom: 12px;
1208
+ }
1209
+
1210
+ .generative-ui-title {
1211
+ font-size: 18px;
1212
+ font-weight: 600;
1213
+ color: #0f172a;
1214
+ margin: 0 0 8px 0;
1215
+ }
1216
+
1217
+ .generative-ui-description {
1218
+ font-size: 14px;
1219
+ color: #475569;
1220
+ margin: 0;
1221
+ line-height: 1.5;
1222
+ }
1223
+
1224
+ .gen-ui-text {
1225
+ font-size: 13px;
1226
+ color: #1e293b;
1227
+ line-height: 1.6;
1228
+ margin: 0;
1229
+ }
1230
+
1231
+ .gen-ui-input-wrapper {
1232
+ display: flex;
1233
+ flex-direction: column;
1234
+ gap: 8px;
1235
+ }
1236
+
1237
+ .gen-ui-input-label {
1238
+ font-size: 12px;
1239
+ font-weight: 500;
1240
+ color: #334155;
1241
+ margin: 0;
1242
+ }
1243
+
1244
+ .gen-ui-input,
1245
+ .gen-ui-textarea {
1246
+ width: 100%;
1247
+ padding: 10px 12px;
1248
+ border: 1px solid #cbd5e1;
1249
+ border-radius: 8px;
1250
+ font-size: 13px;
1251
+ color: #0f172a;
1252
+ background-color: #ffffff;
1253
+ outline: none;
1254
+ transition: border-color 0.2s ease, box-shadow 0.2s ease;
1255
+ font-family: inherit;
1256
+ }
1257
+ .gen-ui-input::placeholder,
1258
+ .gen-ui-textarea::placeholder {
1259
+ color: #94a3b8;
1260
+ }
1261
+ .gen-ui-input:focus,
1262
+ .gen-ui-textarea:focus {
1263
+ border-color: #3b82f6;
1264
+ box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
1265
+ }
1266
+ .gen-ui-input:disabled,
1267
+ .gen-ui-textarea:disabled {
1268
+ background-color: #f1f5f9;
1269
+ cursor: not-allowed;
1270
+ opacity: 0.6;
1271
+ }
1272
+
1273
+ .gen-ui-textarea {
1274
+ min-height: 80px;
1275
+ resize: vertical;
1276
+ }
1277
+
1278
+ .gen-ui-select-wrapper {
1279
+ display: flex;
1280
+ flex-direction: column;
1281
+ gap: 8px;
1282
+ }
1283
+
1284
+ .gen-ui-select-label {
1285
+ font-size: 12px;
1286
+ font-weight: 500;
1287
+ color: #334155;
1288
+ margin: 0;
1289
+ }
1290
+
1291
+ .gen-ui-select {
1292
+ width: 100%;
1293
+ padding: 10px 12px;
1294
+ border: 1px solid #cbd5e1;
1295
+ border-radius: 8px;
1296
+ font-size: 13px;
1297
+ color: #0f172a;
1298
+ background-color: #ffffff;
1299
+ outline: none;
1300
+ transition: border-color 0.2s ease, box-shadow 0.2s ease;
1301
+ cursor: pointer;
1302
+ font-family: inherit;
1303
+ }
1304
+ .gen-ui-select:focus {
1305
+ border-color: #3b82f6;
1306
+ box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
1307
+ }
1308
+ .gen-ui-select:disabled {
1309
+ background-color: #f1f5f9;
1310
+ cursor: not-allowed;
1311
+ opacity: 0.6;
1312
+ }
1313
+
1314
+ .gen-ui-button {
1315
+ display: inline-flex;
1316
+ align-items: center;
1317
+ justify-content: center;
1318
+ padding: 10px 16px;
1319
+ border-radius: 8px;
1320
+ font-size: 13px;
1321
+ font-weight: 500;
1322
+ border: none;
1323
+ cursor: pointer;
1324
+ transition: all 0.2s ease;
1325
+ font-family: inherit;
1326
+ outline: none;
1327
+ background: #2563eb;
1328
+ color: #ffffff;
1329
+ }
1330
+ .gen-ui-button:hover {
1331
+ background: #1d4ed8;
1332
+ }
1333
+ .gen-ui-button:active {
1334
+ transform: scale(0.98);
1335
+ }
1336
+ .gen-ui-button:disabled {
1337
+ background: #cbd5e1;
1338
+ cursor: not-allowed;
1339
+ opacity: 0.6;
1340
+ }
1341
+
1342
+ .gen-ui-card {
1343
+ border: 1px solid #e2e8f0;
1344
+ border-radius: 12px;
1345
+ padding: 16px;
1346
+ background-color: #ffffff;
1347
+ box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
1348
+ transition: box-shadow 0.2s ease;
1349
+ }
1350
+ .gen-ui-card:hover {
1351
+ box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
1352
+ }
1353
+
1354
+ .gen-ui-card-title {
1355
+ font-size: 16px;
1356
+ font-weight: 600;
1357
+ color: #0f172a;
1358
+ margin: 0 0 8px 0;
1359
+ }
1360
+
1361
+ .gen-ui-card-content {
1362
+ font-size: 13px;
1363
+ color: #334155;
1364
+ margin: 0;
1365
+ line-height: 1.5;
1366
+ }
1367
+
1368
+ .gen-ui-list {
1369
+ list-style-type: disc;
1370
+ padding-left: 20px;
1371
+ margin: 0;
1372
+ }
1373
+
1374
+ .gen-ui-list-item {
1375
+ font-size: 13px;
1376
+ color: #1e293b;
1377
+ line-height: 1.6;
1378
+ margin-bottom: 4px;
1379
+ }
1380
+ .gen-ui-list-item:last-child {
1381
+ margin-bottom: 0;
1382
+ }
1383
+
1384
+ .gen-ui-image {
1385
+ max-width: 100%;
1386
+ height: auto;
1387
+ border-radius: 8px;
1388
+ display: block;
1389
+ }
1390
+
1391
+ .gen-ui-link {
1392
+ color: #2563eb;
1393
+ text-decoration: none;
1394
+ font-size: 13px;
1395
+ transition: color 0.2s ease;
1396
+ }
1397
+ .gen-ui-link:hover {
1398
+ color: #1d4ed8;
1399
+ text-decoration: underline;
1400
+ }
1401
+ .gen-ui-link:visited {
1402
+ color: #2563eb;
1403
+ }
1404
+
1405
+ .gen-ui-table-wrapper {
1406
+ width: 100%;
1407
+ overflow-x: auto;
1408
+ border: 1px solid #e2e8f0;
1409
+ border-radius: 12px;
1410
+ background-color: #ffffff;
1411
+ box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
1412
+ }
1413
+
1414
+ .gen-ui-table {
1415
+ width: 100%;
1416
+ border-collapse: collapse;
1417
+ min-width: 100%;
1418
+ }
1419
+
1420
+ .gen-ui-table-header {
1421
+ background-color: #f8fafc;
1422
+ }
1423
+
1424
+ .gen-ui-table-th {
1425
+ padding: 12px 16px;
1426
+ text-align: left;
1427
+ font-size: 12px;
1428
+ font-weight: 600;
1429
+ color: #334155;
1430
+ border-bottom: 2px solid #e2e8f0;
1431
+ white-space: nowrap;
1432
+ }
1433
+
1434
+ .gen-ui-table-body tr {
1435
+ transition: background-color 0.2s ease;
1436
+ }
1437
+ .gen-ui-table-body tr:hover {
1438
+ background-color: #f8fafc;
1439
+ }
1440
+ .gen-ui-table-body tr:not(:last-child) {
1441
+ border-bottom: 1px solid #e2e8f0;
1442
+ }
1443
+
1444
+ .gen-ui-table-td {
1445
+ padding: 12px 16px;
1446
+ font-size: 13px;
1447
+ color: #1e293b;
1448
+ vertical-align: middle;
1449
+ }
1450
+
1451
+ .gen-ui-form {
1452
+ display: flex;
1453
+ flex-direction: column;
1454
+ gap: 16px;
1455
+ width: 100%;
1456
+ }
1457
+ /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"C:\\Calismalar\\zekai\\aizek-widget\\src\\styles","sources":["messageStyles.scss","variables.scss","inputStyles.scss","headerStyles.scss","containerStyles.scss","loadingStyles.scss","alertStyles.scss","uiRenderer.scss","generativeUI.scss"],"names":[],"mappings":";AAEA;EACE;EACA;EACA;;AAEA;EACE;;AAGF;EACE;;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA,WC2BQ;ED1BR;;AAEA;EACE;EACA,YC1Be;ED2Bf,OCxBI;EDyBJ;EACA;;AAGF;EACE;EACA,YC7BM;ED8BN,OCvBO;EDwBP;EACA;EACA;;AAGF;EACE;EACA;EACA;;;AAKJ;EACE,WCLQ;EDMR;EACA,YCtBW;;;ADyBb;EACE;;;AAGF;EACE;;;AAGF;EACE;EACA;;AAEA;EACE;;AAIF;EACE;EACA;;AAEA;EACE;;AAGF;EACE;;AAKJ;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAKJ;AAAA;EAEE;EACA;;AAGF;EACE;EACA;;AAGF;EACE;;AAGF;EACE;EACA;EACA;EACA;;AAEA;EACE;;AAIF;EACE;EACA;EACA;EACA;EACA;EACA;;AAIF;AAAA;EAEE;EACA;;AAIJ;EACE;;AAEA;EACE;;AAKJ;EACE;EACA;EACA;EACA,eCtHQ;EDuHR;EACA;EACA;;AAIF;EACE,YC/JM;EDgKN;EACA,eC/HQ;EDgIR;EACA;EACA;EACA,YChHQ;;ADkHR;EACE;EACA;EACA;EACA,OCnKK;EDoKL,WCnII;EDoIJ;;AAKJ;AAAA;EAEE;EACA;;AAIF;AAAA;EAEE;;AAIF;AAAA;AAAA;AAAA;AAAA;AAAA;EAME;EACA;EACA;EACA;;AAEA;AAAA;AAAA;AAAA;AAAA;AAAA;EACE;;AAIJ;EACE,WCnKM;EDoKN;EACA;;AAGF;EACE,WC1KM;;AD6KR;EACE;;AAGF;AAAA;AAAA;EAGE,WCrLM;;ADyLR;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAKJ;EACE;EACA;EACA;;AAIF;EACE;EACA;EACA;EACA,WCvNM;EDwNN,eC/NQ;EDgOR;EACA;;AAGF;AAAA;EAEE;EACA;EACA;;AAGF;EACE,YC7QO;ED8QP;EACA,OCxQO;EDyQP;;AAGF;EACE;;AAGF;EACE;;AAEA;EACE;;AAKJ;EACE;EACA;EACA,eClQQ;EDmQR;;AAIF;EACE;;;AAMF;EACE,OCnTI;;ADsTJ;EACE,OCvTE;EDwTF;EACA;;AAEA;EACE,qBC5TA;;ADiUJ;EACE,OClUE;;ADsUJ;EACE;EACA,OCxUE;EDyUF;;AAIF;EACE;EACA;;AAEA;EACE,OClVA;;ADuVJ;EACE;;AAIF;EACE,mBC7VE;ED8VF;EACA,OC/VE;;ADmWJ;EACE;;AAIF;EACE;;AAGF;AAAA;EAEE;;AAGF;EACE;EACA,OCnXE;EDoXF;;AAGF;EACE;;;AAOJ;EACE,OCvXO;;AD0XP;EACE;;AAEA;EACE;;AAKJ;EACE;;AAIF;EACE;EACA;EACA;;AAIF;EACE,YCzZE;ED0ZF,cCtZK;;ADwZL;EACE,OCnZG;;ADwZP;AAAA;AAAA;AAAA;AAAA;AAAA;EAME,OC9ZK;;ADiaP;EACE,qBCxaK;;AD4aP;AAAA;EAEE,OCvaK;;AD2aP;EACE;EACA;EACA,OChbK;;ADobP;EACE,YC3bK;ED4bL,OCrbK;;ADwbP;EACE;;;AErcN;EACE;EACA;EACA;EACA,SD4BW;EC3BX,YDHM;ECIN;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA,WD8BQ;EC7BR;EACA;EACA;EACA;EACA;EACA,YDnBQ;ECoBR,ODbS;;ACeT;EACE;EACA;;AAGF;EACE,cDhBO;ECiBP;;;AAIJ;EACE;EACA;EACA,eDCY;ECAZ;EACA,ODxCM;ECyCN;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE,YD7CO;EC8CP;;AAGF;EACE,YDzDe;;AC2Df;EACE;;;AC3DN;EACE;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA,eF8BY;EE7BZ;EACA;EACA;EACA;EACA,WFiCQ;EEhCR;;;AAGF;EACE;EACA;EACA;EACA,eFiBY;;;AEdd;EACE,WFoBQ;EEnBR;;;AAGF;EACE;EACA,WFcQ;EEbR;;;AAGF;EACE;EACA,WFKQ;EEJR;;;ACxCA;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;;;AAIJ;EACE;EACA,QHWW;EGVX,eHkBY;EGjBZ;EACA,OHvBM;EGwBN;EACA;EACA;EACA;EACA,YH6BU;EG5BV;EACA;;AAEA;EACE,MHFS;;AGKX;EACE,OHNS;;AGSX;EACE;;AAGF;EACE,YHaQ;;;AGTZ;EACE;EACA;EACA;EACA;;AAEA;EACE,MHzBS;EG0BT;;AAGF;EACE,OH9BS;EG+BT;;AAGF;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAGF;EACE;EACA;;;AAIJ;EACE;EACA;EACA;EACA,YHvGM;EGwGN,eHnEU;EGoEV;EACA;EACA;;;AAGF;EACE;EACA;EACA,SHnFW;EGoFX;EACA;EACA,KHzFW;EG0FX,YHnHQ;;;AGsHV;EACE;EACA;EACA;EACA;EACA;EACA,OHvHS;EGwHT;EACA;;AAEA;EACE;EACA;;AAGF;EACE;EACA;;AAGF;EACE;EACA;EACA;;;ACjJJ;EACE;IACE;;EAEF;IACE;;;AAIJ;EACE;EACA;EACA;EACA;EACA,eJ2BY;EI1BZ;;;ACfF;EACE;IACE;IACA;;EAGF;IACE;IACA;;;AAIJ;EACE,eL0BU;EKzBV;EACA;EACA;EACA,OLfM;EKgBN,WL4BU;EK3BV;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA,KL5BW;;;AK+Bb;EACE;EACA,WLhBQ;EKiBR;EACA;;;AAGF;EACE;EACA;EACA;;;AAGF;EACE;EACA,cL3CW;EK4CX;;;AAGF;EACE,eLpDW;EKqDX;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAIF;EACE;EACA;EACA;EACA;;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA,OLjHM;EKkHN;EACA;;AAEA;EACE;;;ACxHJ;EACE;EACA;EACA,KN6BW;EM5BX;;;AAIF;EACE;EACA;EACA;EACA,eN2BU;EM1BV,SNqBY;EMpBZ,kBNZM;EMaN,YN2CU;EM1CV;;;AAGF;EACE;EACA,WN2BQ;EM1BR,eNWW;EMVX,ONpBM;EMqBN;;;AAGF;EACE;EACA;EACA,KNGW;;;AMAb;EACE;EACA;EACA,KNNW;;;AMSb;EACE;EACA,WNKU;EMJV,ONhCS;EMiCT;EACA;EACA,KNhBW;;AMkBX;EACE,ON3BI;EM4BJ,WNJM;;;AMQV;AAAA;EAEE;EACA,eNlBU;EMmBV;EACA,WNZU;EMaV,ONxDM;EMyDN,kBN1DM;EM2DN;EACA;EACA;EACA;;AAEA;AAAA;EACE,cNnDO;EMoDP;;;AAIJ;EACE;;;AAGF;EACE,YN3CY;EM4CZ;EACA;EACA;EACA,eN3CU;EM4CV;EACA,WNrCU;EMsCV;EACA,kBNrES;EMsET,ONpFM;EMqFN;EACA;EACA;EACA;;AAEA;EACE,kBN5EO;;AM+ET;EACE;;;AAKJ;EACE;EACA;EACA;;;AAGF;EACE,eNvEU;EMwEV;EACA,WNjEU;EMkEV;EACA;EACA,kBNhHM;EMiHN,ONzGS;EM0GT;EACA;EACA;EACA;;AAEA;EACE,kBN1GO;EM2GP,ONzHI;EM0HJ,cN5GO;;AM8GP;EACE,kBN9GK;EM+GL,cN/GK;;AMmHT;EACE;EACA,ON5HO;EM6HP;;AAEA;EACE;EACA;;AAIJ;EACE,kBN3HI;EM4HJ,ON/II;EMgJJ,cN7HI;;AM+HJ;EACE,kBN/HO;EMgIP,cNhIO;;AMoIX;EACE;EACA;;AAGF;EACE;;;AAKJ;EACE;EACA,eNhIU;EMiIV;EACA,WN3HU;EM4HV,kBNxKM;EMyKN,YNjHU;EMkHV;;;AAGF;EACE;EACA;EACA,WNnIQ;EMoIR;EACA;EACA,ONlLM;;;AMqLR;EACE;;;AAGF;EACE;EACA;EACA;;;AAGF;EACE;;;AAGF;EACE;EACA;EACA;EACA;EACA,WN9JQ;EM+JR;EACA;EACA;EACA;;;AAIA;EACE,kBNlNI;EMmNJ;;AAEA;EACE;;AAGF;EACE;;;AAKN;EACE;EACA;EACA,WNtLU;EMuLV;;AAEA;EACE;EACA;;;AAIJ;EACE;EACA;;;AAGF;EACE;EACA;EACA,eN/MU;EMgNV;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;EACA;EACA,WNrNU;;;AMyNZ;EACE;EACA,eNjOU;EMkOV,SN1OW;EM2OX,kBNzQM;EM0QN;EACA;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;EACA,eNnPU;EMoPV;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA,WNtPQ;EMuPR,eNxQW;EMyQX;EACA;EACA;;;AAGF;EACE,ONpSS;EMqST,WNjQQ;EMkQR,eNlRW;EMmRX;;;AAGF;EACE;EACA,KNvRW;EMwRX,WNzQQ;EM0QR,eN1RW;;;AM6Rb;EACE,ONlTS;EMmTT;;;AAGF;EACE,ONtTS;;;AMyTX;EACE;EACA;EACA,KNzSW;;;AM4Sb;EACE;EACA,KN7SW;EM8SX,WN/RQ;;;AMkSV;EACE,ONvUS;EMwUT;;;AAGF;EACE,ON3US;;;AM8UX;EACE,ONhVS;EMiVT,WN7SQ;EM8SR,YN7TW;EM8TX;;;AAGF;EACE;;;AAGF;EACE;EACA;EACA,WNvTQ;EMwTR,ONpWM;EMqWN;;;AAGF;EACE,ONnWS;EMoWT;EACA,WNjUQ;EMkUR;;;AAGF;EACE;EACA;EACA;;;AAGF;EACE,WN5UQ;EM6UR;EACA,eNpVU;EMqVV,SN5VW;EM6VX,kBN3XM;EM4XN,YNpUU;EMqUV;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;EACA,eNpWU;EMqWV;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA,WNvWQ;EMwWR;EACA;EACA;EACA;EACA,ONxZM;EMyZN;;;AAGF;EACE,ONvZS;EMwZT,WNpXQ;EMqXR;;;AAGF;EACE;EACA;EACA,KN1YW;EM2YX,WN5XQ;;;AM+XV;EACE,ONpaS;EMqaT;;;AAGF;EACE;EACA,ONhbM;EMibN;;;AAQF;EACE;EACA;EACA;EACA;;;AAGF;EACE;;;AAGF;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAGF;EACE;EACA;;AAGF;EACE;EACA;;AAGF;EACE;EACA;;;AAIJ;EACE;EACA;;;ACreF;EACE;EACA;EACA,KP6BW;EO5BX;;;AAKF;EACE,ePqBW;;;AOlBb;EACE,WPmCQ;EOlCR;EACA,OPHS;EOIT;;;AAGF;EACE,WP0BQ;EOzBR,OPZS;EOaT;EACA;;;AAIF;EACE,WPiBU;EOhBV,OPlBS;EOmBT;EACA;;;AAIF;EACE;EACA;EACA,KPTW;;;AOYb;EACE,WPEQ;EODR;EACA,OPlCS;EOmCT;;;AAGF;AAAA;EAEE;EACA;EACA;EACA,ePhBU;EOiBV,WPTU;EOUV,OP3CS;EO4CT,kBPvDM;EOwDN;EACA;EACA;;AAEA;AAAA;EACE,OPvDO;;AO0DT;AAAA;EACE,cPnDO;EOoDP;;AAGF;AAAA;EACE,kBPnEO;EOoEP;EACA;;;AAIJ;EACE;EACA;;;AAIF;EACE;EACA;EACA,KPzDW;;;AO4Db;EACE,WP9CQ;EO+CR;EACA,OPlFS;EOmFT;;;AAGF;EACE;EACA;EACA;EACA,eP/DU;EOgEV,WPxDU;EOyDV,OP1FS;EO2FT,kBPtGM;EOuGN;EACA;EACA;EACA;;AAEA;EACE,cP/FO;EOgGP;;AAGF;EACE,kBP/GO;EOgHP;EACA;;;AAKJ;EACE;EACA;EACA;EACA;EACA,eP1FU;EO2FV,WPnFU;EOoFV;EACA;EACA;EACA;EACA;EACA;EACA,YPvHS;EOwHT,OPvIM;;AOyIN;EACE,YP1HO;;AO6HT;EACE;;AAGF;EACE,YP7IO;EO8IP;EACA;;;AAKJ;EACE;EACA,ePtHU;EOuHV,SP9HW;EO+HX,kBP7JM;EO8JN,YPvGU;EOwGV;;AAEA;EACE,YP1GQ;;;AO8GZ;EACE,WPzHQ;EO0HR;EACA,OP9JS;EO+JT;;;AAGF;EACE,WPlIU;EOmIV,OPtKS;EOuKT;EACA;;;AAIF;EACE;EACA,cPxJW;EOyJX;;;AAGF;EACE,WPhJU;EOiJV,OPnLS;EOoLT;EACA,ePpKW;;AOsKX;EACE;;;AAKJ;EACE;EACA;EACA,ePtKU;EOuKV;;;AAIF;EACE,OPjMS;EOkMT;EACA,WPtKU;EOuKV;;AAEA;EACE,OPtMO;EOuMP;;AAGF;EACE,OP5MO;;;AOiNX;EACE;EACA;EACA;EACA,eP/LU;EOgMV,kBPrOM;EOsON,YP/KU;;;AOkLZ;EACE;EACA;EACA;;;AAGF;EACE,kBP9OQ;;;AOiPV;EACE;EACA;EACA,WP3MQ;EO4MR;EACA,OP/OS;EOgPT;EACA;;;AAIA;EACE;;AAEA;EACE,kBPhQI;;AOmQN;EACE;;;AAKN;EACE;EACA,WPjOU;EOkOV,OPpQS;EOqQT;;;AAIF;EACE;EACA;EACA,KPxPW;EOyPX","sourcesContent":["@use './variables.scss' as *;\r\n\r\n.message-container {\r\n  display: flex;\r\n  flex-direction: column;\r\n  width: 100%;\r\n\r\n  &.user {\r\n    align-items: flex-end;\r\n  }\r\n\r\n  &.assistant {\r\n    align-items: flex-start;\r\n  }\r\n}\r\n\r\n.message-bubble {\r\n  max-width: 80%;\r\n  padding: 12px 16px;\r\n  margin-bottom: 8px;\r\n  word-wrap: break-word;\r\n  line-height: 1.4;\r\n  font-size: $text-md;\r\n  position: relative;\r\n\r\n  &.user {\r\n    border-radius: 18px 18px 4px 18px;\r\n    background: $primary-gradient;\r\n    color: $white;\r\n    margin-left: auto;\r\n    margin-right: 0;\r\n  }\r\n\r\n  &.assistant {\r\n    border-radius: 18px 18px 18px 4px;\r\n    background: $gray-50;\r\n    color: $gray-700;\r\n    border: 1px solid $gray-200;\r\n    margin-left: 0;\r\n    margin-right: auto;\r\n  }\r\n\r\n  .message-typing-indicator {\r\n    display: inline-flex;\r\n    align-items: center;\r\n    margin-left: 8px;\r\n  }\r\n\r\n}\r\n\r\n.message-time {\r\n  font-size: $text-xs;\r\n  opacity: 0.7;\r\n  margin-top: $spacing-xs;\r\n}\r\n\r\n.message-time.user {\r\n  text-align: right;\r\n}\r\n\r\n.message-time.assistant {\r\n  text-align: left;\r\n}\r\n\r\n.markdown-content {\r\n  line-height: 1.6;\r\n  word-break: break-word;\r\n\r\n  &+.generative-ui-container {\r\n    margin-top: 16px;\r\n  }\r\n\r\n  // Paragraflar\r\n  p {\r\n    margin: 0 0 12px 0;\r\n    line-height: 1.6;\r\n\r\n    &:last-child {\r\n      margin-bottom: 0;\r\n    }\r\n\r\n    &:first-child {\r\n      margin-top: 0;\r\n    }\r\n  }\r\n\r\n  // Linkler\r\n  a {\r\n    color: #667eea;\r\n    text-decoration: none;\r\n    transition: all $transition-fast;\r\n    font-weight: 500;\r\n    border-bottom: 1px solid transparent;\r\n\r\n    &:hover {\r\n      color: #764ba2;\r\n      border-bottom-color: #764ba2;\r\n    }\r\n  }\r\n\r\n  // Listeler\r\n  ul,\r\n  ol {\r\n    margin: 12px 0;\r\n    padding-left: 20px;\r\n  }\r\n\r\n  ul {\r\n    list-style: none;\r\n    padding-left: 0;\r\n  }\r\n\r\n  ol {\r\n    list-style: decimal;\r\n  }\r\n\r\n  li {\r\n    margin-bottom: 8px;\r\n    line-height: 1.6;\r\n    position: relative;\r\n    padding-left: 20px;\r\n\r\n    &:last-child {\r\n      margin-bottom: 0;\r\n    }\r\n\r\n    // Bullet point için\r\n    &::before {\r\n      content: \"•\";\r\n      position: absolute;\r\n      left: 0;\r\n      color: #667eea;\r\n      font-weight: bold;\r\n      font-size: 16px;\r\n    }\r\n\r\n    // Nested list için daha iyi görünüm\r\n    ul,\r\n    ol {\r\n      margin-top: 4px;\r\n      margin-bottom: 4px;\r\n    }\r\n  }\r\n\r\n  ol li {\r\n    padding-left: 0;\r\n\r\n    &::before {\r\n      content: none;\r\n    }\r\n  }\r\n\r\n  // Inline kod\r\n  code {\r\n    background: rgba(102, 126, 234, 0.1);\r\n    color: #764ba2;\r\n    padding: 2px 6px;\r\n    border-radius: $radius-sm;\r\n    font-family: 'Monaco', 'Menlo', 'Ubuntu Mono', 'Courier New', monospace;\r\n    font-size: 0.9em;\r\n    border: 1px solid rgba(102, 126, 234, 0.2);\r\n  }\r\n\r\n  // Kod blokları\r\n  pre {\r\n    background: $gray-50;\r\n    padding: 12px 16px;\r\n    border-radius: $radius-md;\r\n    overflow-x: auto;\r\n    margin: 12px 0;\r\n    border: 1px solid $gray-200;\r\n    box-shadow: $shadow-sm;\r\n\r\n    code {\r\n      background: none;\r\n      padding: 0;\r\n      border: none;\r\n      color: $gray-800;\r\n      font-size: $text-sm;\r\n      line-height: 1.5;\r\n    }\r\n  }\r\n\r\n  // Vurgu metni\r\n  strong,\r\n  b {\r\n    font-weight: 600;\r\n    color: inherit;\r\n  }\r\n\r\n  // İtalik metin\r\n  em,\r\n  i {\r\n    font-style: italic;\r\n  }\r\n\r\n  // Başlıklar\r\n  h1,\r\n  h2,\r\n  h3,\r\n  h4,\r\n  h5,\r\n  h6 {\r\n    margin: 16px 0 8px 0;\r\n    font-weight: 600;\r\n    line-height: 1.4;\r\n    color: inherit;\r\n\r\n    &:first-child {\r\n      margin-top: 0;\r\n    }\r\n  }\r\n\r\n  h1 {\r\n    font-size: $text-xl;\r\n    border-bottom: 2px solid $gray-200;\r\n    padding-bottom: 8px;\r\n  }\r\n\r\n  h2 {\r\n    font-size: $text-lg;\r\n  }\r\n\r\n  h3 {\r\n    font-size: 15px;\r\n  }\r\n\r\n  h4,\r\n  h5,\r\n  h6 {\r\n    font-size: $text-md;\r\n  }\r\n\r\n  // Alıntılar\r\n  blockquote {\r\n    border-left: 3px solid #667eea;\r\n    padding-left: 12px;\r\n    margin: 12px 0;\r\n    color: inherit;\r\n    opacity: 0.9;\r\n    font-style: italic;\r\n    background: rgba(102, 126, 234, 0.05);\r\n    padding: 8px 12px;\r\n    border-radius: 0 $radius-sm $radius-sm 0;\r\n\r\n    p {\r\n      margin: 0;\r\n    }\r\n  }\r\n\r\n  // Yatay çizgi\r\n  hr {\r\n    border: none;\r\n    border-top: 1px solid $gray-200;\r\n    margin: 16px 0;\r\n  }\r\n\r\n  // Tablolar\r\n  table {\r\n    border-collapse: collapse;\r\n    width: 100%;\r\n    margin: 12px 0;\r\n    font-size: $text-sm;\r\n    border-radius: $radius-md;\r\n    overflow: hidden;\r\n    border: 1px solid $gray-200;\r\n  }\r\n\r\n  th,\r\n  td {\r\n    padding: 10px 12px;\r\n    text-align: left;\r\n    border-bottom: 1px solid $gray-200;\r\n  }\r\n\r\n  th {\r\n    background: $gray-100;\r\n    font-weight: 600;\r\n    color: $gray-800;\r\n    border-bottom: 2px solid $gray-300;\r\n  }\r\n\r\n  tr:last-child td {\r\n    border-bottom: none;\r\n  }\r\n\r\n  tbody tr {\r\n    transition: background-color $transition-fast;\r\n\r\n    &:hover {\r\n      background-color: rgba(102, 126, 234, 0.05);\r\n    }\r\n  }\r\n\r\n  // Görseller\r\n  img {\r\n    max-width: 100%;\r\n    height: auto;\r\n    border-radius: $radius-md;\r\n    margin: 8px 0;\r\n  }\r\n\r\n  // Checkbox listeler (GitHub style)\r\n  input[type=\"checkbox\"] {\r\n    margin-right: 6px;\r\n  }\r\n}\r\n\r\n// User message specific styles\r\n.message-bubble.user {\r\n  .markdown-content {\r\n    color: $white;\r\n\r\n    // Linkler\r\n    a {\r\n      color: $white;\r\n      border-bottom-color: rgba(255, 255, 255, 0.4);\r\n      font-weight: 600;\r\n\r\n      &:hover {\r\n        border-bottom-color: $white;\r\n      }\r\n    }\r\n\r\n    // Bullet points\r\n    li::before {\r\n      color: $white;\r\n    }\r\n\r\n    // Inline kod\r\n    code {\r\n      background: rgba(255, 255, 255, 0.2);\r\n      color: $white;\r\n      border-color: rgba(255, 255, 255, 0.3);\r\n    }\r\n\r\n    // Kod blokları\r\n    pre {\r\n      background: rgba(255, 255, 255, 0.1);\r\n      border-color: rgba(255, 255, 255, 0.2);\r\n\r\n      code {\r\n        color: $white;\r\n      }\r\n    }\r\n\r\n    // Başlıklar\r\n    h1 {\r\n      border-bottom-color: rgba(255, 255, 255, 0.3);\r\n    }\r\n\r\n    // Alıntılar\r\n    blockquote {\r\n      border-left-color: $white;\r\n      background: rgba(255, 255, 255, 0.1);\r\n      color: $white;\r\n    }\r\n\r\n    // Yatay çizgi\r\n    hr {\r\n      border-top-color: rgba(255, 255, 255, 0.3);\r\n    }\r\n\r\n    // Tablolar\r\n    table {\r\n      border-color: rgba(255, 255, 255, 0.3);\r\n    }\r\n\r\n    th,\r\n    td {\r\n      border-bottom-color: rgba(255, 255, 255, 0.2);\r\n    }\r\n\r\n    th {\r\n      background: rgba(255, 255, 255, 0.15);\r\n      color: $white;\r\n      border-bottom-color: rgba(255, 255, 255, 0.3);\r\n    }\r\n\r\n    tbody tr:hover {\r\n      background-color: rgba(255, 255, 255, 0.1);\r\n    }\r\n  }\r\n}\r\n\r\n// Assistant message specific styles\r\n.message-bubble.assistant {\r\n  .markdown-content {\r\n    color: $gray-700;\r\n\r\n    // Linkler\r\n    a {\r\n      color: #667eea;\r\n\r\n      &:hover {\r\n        color: #764ba2;\r\n      }\r\n    }\r\n\r\n    // Bullet points\r\n    li::before {\r\n      color: #667eea;\r\n    }\r\n\r\n    // Inline kod\r\n    code {\r\n      background: rgba(102, 126, 234, 0.1);\r\n      color: #764ba2;\r\n      border-color: rgba(102, 126, 234, 0.2);\r\n    }\r\n\r\n    // Kod blokları\r\n    pre {\r\n      background: $white;\r\n      border-color: $gray-200;\r\n\r\n      code {\r\n        color: $gray-800;\r\n      }\r\n    }\r\n\r\n    // Başlıklar\r\n    h1,\r\n    h2,\r\n    h3,\r\n    h4,\r\n    h5,\r\n    h6 {\r\n      color: $gray-800;\r\n    }\r\n\r\n    h1 {\r\n      border-bottom-color: $gray-200;\r\n    }\r\n\r\n    // Vurgu\r\n    strong,\r\n    b {\r\n      color: $gray-900;\r\n    }\r\n\r\n    // Alıntılar\r\n    blockquote {\r\n      border-left-color: #667eea;\r\n      background: rgba(102, 126, 234, 0.05);\r\n      color: $gray-700;\r\n    }\r\n\r\n    // Tablolar\r\n    th {\r\n      background: $gray-100;\r\n      color: $gray-800;\r\n    }\r\n\r\n    tbody tr:hover {\r\n      background-color: rgba(102, 126, 234, 0.05);\r\n    }\r\n  }\r\n}","// Color Variables\r\n$primary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);\r\n$button-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);\r\n\r\n$white: #ffffff;\r\n$black: #1a1a1a;\r\n$gray-50: #f8fafc;\r\n$gray-100: #f1f5f9;\r\n$gray-200: #e2e8f0;\r\n$gray-300: #cbd5e1;\r\n$gray-400: #94a3b8;\r\n$gray-500: #64748b;\r\n$gray-600: #475569;\r\n$gray-700: #334155;\r\n$gray-800: #1e293b;\r\n$gray-900: #0f172a;\r\n\r\n// Brand Colors\r\n$blue-500: #3b82f6;\r\n$blue-600: #2563eb;\r\n$blue-700: #1d4ed8;\r\n\r\n// Status Colors\r\n$error: #ef4444;\r\n$error-dark: #dc2626;\r\n$warning: #f59e0b;\r\n$warning-dark: #d97706;\r\n$success: #10b981;\r\n$success-dark: #059669;\r\n\r\n// Spacing\r\n$spacing-xs: 4px;\r\n$spacing-sm: 8px;\r\n$spacing-md: 12px;\r\n$spacing-lg: 16px;\r\n$spacing-xl: 20px;\r\n$spacing-2xl: 24px;\r\n\r\n// Border Radius\r\n$radius-sm: 4px;\r\n$radius-md: 8px;\r\n$radius-lg: 12px;\r\n$radius-xl: 16px;\r\n$radius-full: 50%;\r\n\r\n// Font Sizes\r\n$text-xs: 11px;\r\n$text-sm: 12px;\r\n$text-base: 13px;\r\n$text-md: 14px;\r\n$text-lg: 16px;\r\n$text-xl: 18px;\r\n\r\n// Transitions\r\n$transition-fast: 0.15s ease;\r\n$transition-base: 0.2s ease;\r\n$transition-slow: 0.3s ease;\r\n\r\n// Shadows\r\n$shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.05);\r\n$shadow-md: 0 2px 8px rgba(0, 0, 0, 0.08);\r\n$shadow-lg: 0 4px 12px rgba(0, 0, 0, 0.15);\r\n$shadow-xl: 0 6px 20px rgba(0, 0, 0, 0.25);\r\n\r\n","@use './variables.scss' as *;\r\n\r\n.input-container {\r\n  display: flex;\r\n  align-items: flex-end;\r\n  gap: 12px;\r\n  padding: $spacing-lg;\r\n  background: $white;\r\n  border-top: 1px solid $gray-200;\r\n  border-radius: 0 0 $radius-lg $radius-lg;\r\n}\r\n\r\n.textarea {\r\n  flex: 1;\r\n  min-height: 44px;\r\n  max-height: 120px;\r\n  padding: 12px $spacing-lg;\r\n  border: 1px solid $gray-200;\r\n  border-radius: 22px;\r\n  font-size: $text-md;\r\n  line-height: 1.4;\r\n  resize: none;\r\n  outline: none;\r\n  transition: border-color $transition-base, box-shadow $transition-base;\r\n  font-family: inherit;\r\n  background: $gray-50;\r\n  color: $gray-700;\r\n\r\n  &:disabled {\r\n    opacity: 0.6;\r\n    cursor: not-allowed;\r\n  }\r\n\r\n  &:focus:not(:disabled) {\r\n    border-color: $blue-500;\r\n    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);\r\n  }\r\n}\r\n\r\n.send-button {\r\n  width: 44px;\r\n  height: 44px;\r\n  border-radius: $radius-full;\r\n  border: none;\r\n  color: $white;\r\n  cursor: pointer;\r\n  display: flex;\r\n  align-items: center;\r\n  justify-content: center;\r\n  transition: all $transition-base;\r\n  font-size: $text-lg;\r\n\r\n  &:disabled {\r\n    background: $gray-200;\r\n    cursor: not-allowed;\r\n  }\r\n\r\n  &:not(:disabled) {\r\n    background: $primary-gradient;\r\n    \r\n    &:hover {\r\n      transform: scale(1.05);\r\n    }\r\n  }\r\n}\r\n\r\n","@use './variables.scss' as *;\r\n\r\n.header {\r\n  padding: $spacing-lg $spacing-xl;\r\n  color: $white;\r\n  display: flex;\r\n  align-items: center;\r\n  gap: 12px;\r\n}\r\n\r\n.logo-container {\r\n  width: 40px;\r\n  height: 40px;\r\n  border-radius: $radius-full;\r\n  background: rgba(255, 255, 255, 0.2);\r\n  display: flex;\r\n  align-items: center;\r\n  justify-content: center;\r\n  font-size: $text-xl;\r\n  overflow: hidden;\r\n}\r\n\r\n.logo-image {\r\n  width: 100%;\r\n  height: 100%;\r\n  object-fit: cover;\r\n  border-radius: $radius-full;\r\n}\r\n\r\n.logo-text {\r\n  font-size: $text-lg;\r\n  font-weight: bold;\r\n}\r\n\r\n.company-name {\r\n  margin: 0;\r\n  font-size: $text-lg;\r\n  font-weight: 600;\r\n}\r\n\r\n.status-text {\r\n  margin: 0;\r\n  font-size: $text-sm;\r\n  opacity: 0.8;\r\n}\r\n\r\n","@use './variables.scss' as *;\r\n\r\n.button-sizes {\r\n  &.small {\r\n    width: 50px;\r\n    height: 50px;\r\n    font-size: 20px;\r\n  }\r\n\r\n  &.medium {\r\n    width: 60px;\r\n    height: 60px;\r\n    font-size: 24px;\r\n  }\r\n\r\n  &.large {\r\n    width: 70px;\r\n    height: 70px;\r\n    font-size: 28px;\r\n  }\r\n}\r\n\r\n.floating-button {\r\n  position: fixed;\r\n  bottom: $spacing-xl;\r\n  border-radius: $radius-full;\r\n  border: none;\r\n  color: $white;\r\n  cursor: pointer;\r\n  display: flex;\r\n  align-items: center;\r\n  justify-content: center;\r\n  box-shadow: $shadow-lg;\r\n  transition: all $transition-slow;\r\n  z-index: 1000;\r\n\r\n  &.bottom-left {\r\n    left: $spacing-xl;\r\n  }\r\n\r\n  &.bottom-right {\r\n    right: $spacing-xl;\r\n  }\r\n\r\n  &.is-open {\r\n    transform: scale(0.9);\r\n  }\r\n\r\n  &:hover {\r\n    box-shadow: $shadow-xl;\r\n  }\r\n}\r\n\r\n.chat-container {\r\n  position: fixed;\r\n  bottom: 90px;\r\n  z-index: 9999999;\r\n  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);\r\n\r\n  &.bottom-left {\r\n    left: $spacing-xl;\r\n    transform-origin: bottom left;\r\n  }\r\n\r\n  &.bottom-right {\r\n    right: $spacing-xl;\r\n    transform-origin: bottom right;\r\n  }\r\n\r\n  &.is-open {\r\n    transform: translateY(0) scale(1);\r\n    opacity: 1;\r\n    visibility: visible;\r\n  }\r\n\r\n  &:not(.is-open) {\r\n    transform: translateY(20px) scale(0.95);\r\n    opacity: 0;\r\n    visibility: hidden;\r\n  }\r\n}\r\n\r\n.overlay {\r\n  position: fixed;\r\n  top: 0;\r\n  left: 0;\r\n  right: 0;\r\n  bottom: 0;\r\n  background: rgba(0, 0, 0, 0.1);\r\n  z-index: 998;\r\n  transition: all $transition-slow;\r\n\r\n  &.is-open {\r\n    opacity: 1;\r\n    visibility: visible;\r\n  }\r\n\r\n  &:not(.is-open) {\r\n    opacity: 0;\r\n    visibility: hidden;\r\n  }\r\n}\r\n\r\n.chatbot-container {\r\n  display: flex;\r\n  flex-direction: column;\r\n  height: 100%;\r\n  background: $white;\r\n  border-radius: $radius-lg;\r\n  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);\r\n  border: 1px solid $gray-200;\r\n  overflow: hidden;\r\n}\r\n\r\n.messages-container {\r\n  flex: 1;\r\n  overflow-y: auto;\r\n  padding: $spacing-lg;\r\n  display: flex;\r\n  flex-direction: column;\r\n  gap: $spacing-xs;\r\n  background: $gray-50;\r\n}\r\n\r\n.empty-state {\r\n  display: flex;\r\n  flex-direction: column;\r\n  align-items: center;\r\n  justify-content: center;\r\n  height: 100%;\r\n  color: $gray-500;\r\n  text-align: center;\r\n  padding: 40px $spacing-xl;\r\n\r\n  .empty-state-icon {\r\n    font-size: 48px;\r\n    margin-bottom: 16px;\r\n  }\r\n\r\n  .empty-state-title {\r\n    margin: 0 0 8px 0;\r\n    font-size: 18px;\r\n  }\r\n\r\n  .empty-state-description {\r\n    margin: 0;\r\n    font-size: 14px;\r\n    opacity: 0.8;\r\n  }\r\n}","@use './variables.scss' as *;\r\n\r\n@keyframes spin {\r\n  from {\r\n    transform: rotate(0deg);\r\n  }\r\n  to {\r\n    transform: rotate(360deg);\r\n  }\r\n}\r\n\r\n.loading-spinner {\r\n  width: 16px;\r\n  height: 16px;\r\n  border: 2px solid transparent;\r\n  border-top: 2px solid currentColor;\r\n  border-radius: $radius-full;\r\n  animation: spin 1s linear infinite;\r\n}\r\n\r\n","@use './variables.scss' as *;\r\n\r\n@keyframes slideDown {\r\n  from {\r\n    opacity: 0;\r\n    transform: translateY(-10px);\r\n  }\r\n\r\n  to {\r\n    opacity: 1;\r\n    transform: translateY(0);\r\n  }\r\n}\r\n\r\n.alert-container {\r\n  border-radius: $radius-lg;\r\n  padding: 14px $spacing-lg;\r\n  margin: 12px $spacing-lg;\r\n  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);\r\n  color: $white;\r\n  font-size: $text-base;\r\n  display: flex;\r\n  align-items: flex-start;\r\n  gap: 12px;\r\n  position: relative;\r\n  animation: slideDown $transition-slow ease-out;\r\n\r\n  &.error {\r\n    background: linear-gradient(135deg, $error 0%, $error-dark 100%);\r\n    border: 1px solid $error-dark;\r\n    box-shadow: 0 4px 12px rgba(239, 68, 68, 0.2);\r\n  }\r\n\r\n  &.warning {\r\n    background: linear-gradient(135deg, $warning 0%, $warning-dark 100%);\r\n    border: 1px solid $warning-dark;\r\n    box-shadow: 0 4px 12px rgba(245, 158, 11, 0.2);\r\n  }\r\n\r\n  &.success {\r\n    background: linear-gradient(135deg, $success 0%, $success-dark 100%);\r\n    border: 1px solid $success-dark;\r\n    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.2);\r\n  }\r\n}\r\n\r\n.alert-icon-container {\r\n  display: flex;\r\n  align-items: center;\r\n  justify-content: center;\r\n  width: 24px;\r\n  height: 24px;\r\n  flex-shrink: 0;\r\n  margin-top: 2px;\r\n}\r\n\r\n.alert-content {\r\n  flex: 1;\r\n  display: flex;\r\n  flex-direction: column;\r\n  gap: $spacing-sm;\r\n}\r\n\r\n.alert-title {\r\n  font-weight: 600;\r\n  font-size: $text-md;\r\n  margin: 0;\r\n  line-height: 1.4;\r\n}\r\n\r\n.alert-message {\r\n  margin: 0;\r\n  line-height: 1.5;\r\n  opacity: 0.95;\r\n}\r\n\r\n.alert-list {\r\n  margin: $spacing-sm 0 0 0;\r\n  padding-left: $spacing-xl;\r\n  list-style: none;\r\n}\r\n\r\n.alert-list-item {\r\n  margin-bottom: $spacing-xs;\r\n  position: relative;\r\n  padding-left: 12px;\r\n  line-height: 1.4;\r\n\r\n  li>span {\r\n    position: \"absolute\";\r\n    left: 0;\r\n    top: 2px;\r\n    font-weight: bold;\r\n\r\n  }\r\n\r\n  li>code {\r\n    background: rgba(255, 255, 255, 0.2);\r\n    padding: 2px 6px;\r\n    border-radius: 4px;\r\n    font-size: 12px;\r\n  }\r\n}\r\n\r\n.alert-close-button {\r\n  position: absolute;\r\n  top: 12px;\r\n  right: 12px;\r\n  background: rgba(255, 255, 255, 0.2);\r\n  border: none;\r\n  border-radius: 6px;\r\n  width: 24px;\r\n  height: 24px;\r\n  display: flex;\r\n  align-items: center;\r\n  justify-content: center;\r\n  cursor: pointer;\r\n  color: $white;\r\n  transition: all $transition-base;\r\n  padding: 0;\r\n\r\n  &:hover {\r\n    background: rgba(255, 255, 255, 0.3);\r\n  }\r\n}","@use './variables.scss' as *;\r\n\r\n.ui-renderer {\r\n  display: flex;\r\n  flex-direction: column;\r\n  gap: $spacing-lg;\r\n  width: 100%;\r\n}\r\n\r\n// Form Component\r\n.form-component {\r\n  width: 100%;\r\n  max-width: 500px;\r\n  border: 1px solid #e0e0e0;\r\n  border-radius: $radius-lg;\r\n  padding: $spacing-2xl;\r\n  background-color: $white;\r\n  box-shadow: $shadow-md;\r\n  font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, \"Helvetica Neue\", Arial, sans-serif;\r\n}\r\n\r\n.form-title {\r\n  font-weight: 600;\r\n  font-size: $text-lg;\r\n  margin-bottom: $spacing-xl;\r\n  color: $black;\r\n  margin-top: 0;\r\n}\r\n\r\n.form-fields {\r\n  display: flex;\r\n  flex-direction: column;\r\n  gap: $spacing-xl;\r\n}\r\n\r\n.form-field {\r\n  display: flex;\r\n  flex-direction: column;\r\n  gap: $spacing-sm;\r\n}\r\n\r\n.form-label {\r\n  font-weight: 500;\r\n  font-size: $text-base;\r\n  color: $gray-600;\r\n  display: flex;\r\n  align-items: center;\r\n  gap: $spacing-xs;\r\n\r\n  span {\r\n    color: $error;\r\n    font-size: $text-sm;\r\n  }\r\n}\r\n\r\n.form-input,\r\n.form-select {\r\n  border: 1px solid #d1d5db;\r\n  border-radius: $radius-md;\r\n  padding: 10px 12px;\r\n  font-size: $text-base;\r\n  color: $black;\r\n  background-color: $white;\r\n  font-family: inherit;\r\n  outline: none;\r\n  transition: border-color $transition-fast, box-shadow $transition-fast;\r\n  cursor: pointer;\r\n\r\n  &:focus {\r\n    border-color: $blue-500;\r\n    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);\r\n  }\r\n}\r\n\r\n.form-select {\r\n  cursor: pointer;\r\n}\r\n\r\n.form-submit-button {\r\n  margin-top: $spacing-2xl;\r\n  display: inline-flex;\r\n  align-items: center;\r\n  justify-content: center;\r\n  border-radius: $radius-md;\r\n  padding: 12px $spacing-2xl;\r\n  font-size: $text-base;\r\n  font-weight: 500;\r\n  background-color: $blue-500;\r\n  color: $white;\r\n  border: none;\r\n  cursor: pointer;\r\n  transition: background-color $transition-fast, transform 0.1s ease;\r\n  font-family: inherit;\r\n\r\n  &:hover {\r\n    background-color: $blue-600;\r\n  }\r\n\r\n  &:active {\r\n    transform: scale(0.98);\r\n  }\r\n}\r\n\r\n// Buttons Component\r\n.buttons-component {\r\n  display: flex;\r\n  gap: 12px;\r\n  flex-wrap: wrap;\r\n}\r\n\r\n.button-component {\r\n  border-radius: $radius-md;\r\n  padding: 10px $spacing-xl;\r\n  font-size: $text-base;\r\n  font-weight: 500;\r\n  border: 1px solid #e0e0e0;\r\n  background-color: $white;\r\n  color: $gray-600;\r\n  cursor: pointer;\r\n  transition: all $transition-fast;\r\n  font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, \"Helvetica Neue\", Arial, sans-serif;\r\n  outline: none;\r\n\r\n  &.primary {\r\n    background-color: $blue-500;\r\n    color: $white;\r\n    border-color: $blue-500;\r\n\r\n    &:hover {\r\n      background-color: $blue-600;\r\n      border-color: $blue-600;\r\n    }\r\n  }\r\n\r\n  &.secondary {\r\n    background-color: #f3f4f6;\r\n    color: $gray-600;\r\n    border-color: #d1d5db;\r\n\r\n    &:hover {\r\n      background-color: #e5e7eb;\r\n      border-color: #9ca3af;\r\n    }\r\n  }\r\n\r\n  &.danger {\r\n    background-color: $error;\r\n    color: $white;\r\n    border-color: $error;\r\n\r\n    &:hover {\r\n      background-color: $error-dark;\r\n      border-color: $error-dark;\r\n    }\r\n  }\r\n\r\n  &:not(.primary):not(.secondary):not(.danger):hover {\r\n    background-color: #f9fafb;\r\n    border-color: #d1d5db;\r\n  }\r\n\r\n  &:active {\r\n    transform: scale(0.97);\r\n  }\r\n}\r\n\r\n// Table Component\r\n.table-component {\r\n  border: 1px solid #e0e0e0;\r\n  border-radius: $radius-lg;\r\n  overflow: hidden;\r\n  font-size: $text-base;\r\n  background-color: $white;\r\n  box-shadow: $shadow-md;\r\n  font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, \"Helvetica Neue\", Arial, sans-serif;\r\n}\r\n\r\n.table-caption {\r\n  padding: $spacing-lg $spacing-xl;\r\n  font-weight: 600;\r\n  font-size: $text-md;\r\n  border-bottom: 1px solid #e0e0e0;\r\n  background-color: #f8f9fa;\r\n  color: $black;\r\n}\r\n\r\n.table-wrapper {\r\n  overflow-x: auto;\r\n}\r\n\r\n.table {\r\n  width: 100%;\r\n  border-collapse: collapse;\r\n  min-width: 100%;\r\n}\r\n\r\n.table-header {\r\n  background-color: #f8f9fa;\r\n}\r\n\r\n.table-th {\r\n  border-bottom: 2px solid #e0e0e0;\r\n  padding: 14px $spacing-xl;\r\n  text-align: left;\r\n  font-weight: 600;\r\n  font-size: $text-sm;\r\n  color: #4a5568;\r\n  text-transform: uppercase;\r\n  letter-spacing: 0.5px;\r\n  white-space: nowrap;\r\n}\r\n\r\n.table-tbody {\r\n  tr {\r\n    background-color: $white;\r\n    transition: background-color $transition-fast;\r\n\r\n    &:nth-child(even) {\r\n      background-color: #fafbfc;\r\n    }\r\n\r\n    &:hover {\r\n      background-color: #f0f4f8;\r\n    }\r\n  }\r\n}\r\n\r\n.table-td {\r\n  border-bottom: 1px solid #e8e8e8;\r\n  padding: $spacing-lg $spacing-xl;\r\n  font-size: $text-base;\r\n  vertical-align: middle;\r\n\r\n  >span {\r\n    color: #a0a0a0;\r\n    font-style: italic;\r\n  }\r\n}\r\n\r\n.table-cell-image {\r\n  display: flex;\r\n  align-items: center;\r\n}\r\n\r\n.table-image {\r\n  width: 40px;\r\n  height: 40px;\r\n  border-radius: $radius-md;\r\n  object-fit: cover;\r\n  border: 1px solid #e0e0e0;\r\n}\r\n\r\n.table-cell-text {\r\n  color: #2d3748;\r\n  line-height: 1.5;\r\n}\r\n\r\n.table-empty {\r\n  padding: 40px;\r\n  text-align: center;\r\n  color: #9ca3af;\r\n  font-size: $text-base;\r\n}\r\n\r\n// Card Component\r\n.card-component {\r\n  border: 1px solid #e5e7eb;\r\n  border-radius: $radius-xl;\r\n  padding: $spacing-lg;\r\n  background-color: $white;\r\n  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1);\r\n  overflow: hidden;\r\n  margin-bottom: 12px;\r\n}\r\n\r\n.card-content {\r\n  display: flex;\r\n  gap: 12px;\r\n}\r\n\r\n.card-image {\r\n  width: 64px;\r\n  height: 64px;\r\n  border-radius: $radius-md;\r\n  object-fit: cover;\r\n  flex-shrink: 0;\r\n}\r\n\r\n.card-info {\r\n  flex: 1;\r\n  min-width: 0;\r\n}\r\n\r\n.card-title {\r\n  font-weight: 600;\r\n  font-size: $text-md;\r\n  margin-bottom: $spacing-sm;\r\n  overflow: hidden;\r\n  text-overflow: ellipsis;\r\n  white-space: nowrap;\r\n}\r\n\r\n.card-subtitle {\r\n  color: $gray-500;\r\n  font-size: $text-sm;\r\n  margin-bottom: $spacing-xs;\r\n  margin: 0;\r\n}\r\n\r\n.card-status {\r\n  display: flex;\r\n  gap: $spacing-sm;\r\n  font-size: $text-sm;\r\n  margin-bottom: $spacing-xs;\r\n}\r\n\r\n.card-status-label {\r\n  color: $gray-500;\r\n  font-weight: 500;\r\n}\r\n\r\n.card-status-value {\r\n  color: $gray-600;\r\n}\r\n\r\n.card-fields {\r\n  display: flex;\r\n  flex-direction: column;\r\n  gap: $spacing-xs;\r\n}\r\n\r\n.card-field {\r\n  display: flex;\r\n  gap: $spacing-sm;\r\n  font-size: $text-sm;\r\n}\r\n\r\n.card-field-label {\r\n  color: $gray-500;\r\n  font-weight: 500;\r\n}\r\n\r\n.card-field-value {\r\n  color: $gray-600;\r\n}\r\n\r\n.card-description {\r\n  color: $gray-500;\r\n  font-size: $text-sm;\r\n  margin-top: $spacing-sm;\r\n  margin: 0;\r\n}\r\n\r\n.card-list {\r\n  width: 100%;\r\n}\r\n\r\n.card-list-title {\r\n  font-weight: 600;\r\n  margin-bottom: 12px;\r\n  font-size: $text-md;\r\n  color: $black;\r\n  margin-top: 0;\r\n}\r\n\r\n.card-list-description {\r\n  color: $gray-500;\r\n  margin-bottom: 12px;\r\n  font-size: $text-sm;\r\n  margin-top: 0;\r\n}\r\n\r\n.card-grid {\r\n  display: grid;\r\n  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));\r\n  gap: 12px;\r\n}\r\n\r\n.card-item {\r\n  font-size: $text-sm;\r\n  border: 1px solid #e0e0e0;\r\n  border-radius: $radius-lg;\r\n  padding: $spacing-lg;\r\n  background-color: $white;\r\n  box-shadow: $shadow-md;\r\n  overflow: hidden;\r\n}\r\n\r\n.card-item-content {\r\n  display: flex;\r\n  gap: 12px;\r\n}\r\n\r\n.card-item-image {\r\n  width: 64px;\r\n  height: 64px;\r\n  border-radius: $radius-md;\r\n  object-fit: cover;\r\n  flex-shrink: 0;\r\n}\r\n\r\n.card-item-info {\r\n  flex: 1;\r\n  min-width: 0;\r\n}\r\n\r\n.card-item-title {\r\n  font-weight: 600;\r\n  font-size: $text-md;\r\n  margin-bottom: 4px;\r\n  overflow: hidden;\r\n  text-overflow: ellipsis;\r\n  white-space: nowrap;\r\n  color: $black;\r\n  margin-top: 0;\r\n}\r\n\r\n.card-item-subtitle {\r\n  color: $gray-500;\r\n  font-size: $text-sm;\r\n  margin: 0;\r\n}\r\n\r\n.card-item-legacy {\r\n  display: flex;\r\n  justify-content: space-between;\r\n  gap: $spacing-sm;\r\n  font-size: $text-sm;\r\n}\r\n\r\n.card-item-legacy-label {\r\n  color: $gray-500;\r\n  margin: 0;\r\n}\r\n\r\n.card-item-legacy-value {\r\n  font-weight: 500;\r\n  color: $black;\r\n  margin: 0;\r\n}\r\n\r\n// Field renderer\r\n.field-text {\r\n  // Text field styles if needed\r\n}\r\n\r\n.field-image {\r\n  width: 24px;\r\n  height: 24px;\r\n  border-radius: 999px;\r\n  object-fit: cover;\r\n}\r\n\r\n.field-link {\r\n  text-decoration: underline;\r\n}\r\n\r\n.field-badge {\r\n  display: inline-block;\r\n  padding: 2px 6px;\r\n  border-radius: 999px;\r\n  font-size: 10px;\r\n  font-weight: 500;\r\n\r\n  &.success {\r\n    background-color: #e0fce5;\r\n    color: #1a7f36;\r\n  }\r\n\r\n  &.warning {\r\n    background-color: #fff7d6;\r\n    color: #8a6a00;\r\n  }\r\n\r\n  &.danger {\r\n    background-color: #ffe4e4;\r\n    color: #b42318;\r\n  }\r\n\r\n  &:not(.success):not(.warning):not(.danger) {\r\n    background-color: #f2f2f2;\r\n    color: #333;\r\n  }\r\n}\r\n\r\n.field-list {\r\n  margin: 0;\r\n  padding-left: 16px;\r\n}","@use './variables.scss' as *;\r\n\r\n.generative-ui-container {\r\n  display: flex;\r\n  flex-direction: column;\r\n  gap: $spacing-lg;\r\n  width: 100%;\r\n\r\n   \r\n}\r\n\r\n.generative-ui-header {\r\n  margin-bottom: $spacing-md;\r\n}\r\n\r\n.generative-ui-title {\r\n  font-size: $text-xl;\r\n  font-weight: 600;\r\n  color: $gray-900;\r\n  margin: 0 0 $spacing-sm 0;\r\n}\r\n\r\n.generative-ui-description {\r\n  font-size: $text-md;\r\n  color: $gray-600;\r\n  margin: 0;\r\n  line-height: 1.5;\r\n}\r\n\r\n// Text Component\r\n.gen-ui-text {\r\n  font-size: $text-base;\r\n  color: $gray-800;\r\n  line-height: 1.6;\r\n  margin: 0;\r\n}\r\n\r\n// Input Component\r\n.gen-ui-input-wrapper {\r\n  display: flex;\r\n  flex-direction: column;\r\n  gap: $spacing-sm;\r\n}\r\n\r\n.gen-ui-input-label {\r\n  font-size: $text-sm;\r\n  font-weight: 500;\r\n  color: $gray-700;\r\n  margin: 0;\r\n}\r\n\r\n.gen-ui-input,\r\n.gen-ui-textarea {\r\n  width: 100%;\r\n  padding: 10px 12px;\r\n  border: 1px solid $gray-300;\r\n  border-radius: $radius-md;\r\n  font-size: $text-base;\r\n  color: $gray-900;\r\n  background-color: $white;\r\n  outline: none;\r\n  transition: border-color $transition-base, box-shadow $transition-base;\r\n  font-family: inherit;\r\n\r\n  &::placeholder {\r\n    color: $gray-400;\r\n  }\r\n\r\n  &:focus {\r\n    border-color: $blue-500;\r\n    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);\r\n  }\r\n\r\n  &:disabled {\r\n    background-color: $gray-100;\r\n    cursor: not-allowed;\r\n    opacity: 0.6;\r\n  }\r\n}\r\n\r\n.gen-ui-textarea {\r\n  min-height: 80px;\r\n  resize: vertical;\r\n}\r\n\r\n// Select Component\r\n.gen-ui-select-wrapper {\r\n  display: flex;\r\n  flex-direction: column;\r\n  gap: $spacing-sm;\r\n}\r\n\r\n.gen-ui-select-label {\r\n  font-size: $text-sm;\r\n  font-weight: 500;\r\n  color: $gray-700;\r\n  margin: 0;\r\n}\r\n\r\n.gen-ui-select {\r\n  width: 100%;\r\n  padding: 10px 12px;\r\n  border: 1px solid $gray-300;\r\n  border-radius: $radius-md;\r\n  font-size: $text-base;\r\n  color: $gray-900;\r\n  background-color: $white;\r\n  outline: none;\r\n  transition: border-color $transition-base, box-shadow $transition-base;\r\n  cursor: pointer;\r\n  font-family: inherit;\r\n\r\n  &:focus {\r\n    border-color: $blue-500;\r\n    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);\r\n  }\r\n\r\n  &:disabled {\r\n    background-color: $gray-100;\r\n    cursor: not-allowed;\r\n    opacity: 0.6;\r\n  }\r\n}\r\n\r\n// Button Component\r\n.gen-ui-button {\r\n  display: inline-flex;\r\n  align-items: center;\r\n  justify-content: center;\r\n  padding: 10px $spacing-lg;\r\n  border-radius: $radius-md;\r\n  font-size: $text-base;\r\n  font-weight: 500;\r\n  border: none;\r\n  cursor: pointer;\r\n  transition: all $transition-base;\r\n  font-family: inherit;\r\n  outline: none;\r\n  background: $blue-600;\r\n  color: $white;\r\n\r\n  &:hover {\r\n    background: $blue-700;\r\n  }\r\n\r\n  &:active {\r\n    transform: scale(0.98);\r\n  }\r\n\r\n  &:disabled {\r\n    background: $gray-300;\r\n    cursor: not-allowed;\r\n    opacity: 0.6;\r\n  }\r\n}\r\n\r\n// Card Component\r\n.gen-ui-card {\r\n  border: 1px solid $gray-200;\r\n  border-radius: $radius-lg;\r\n  padding: $spacing-lg;\r\n  background-color: $white;\r\n  box-shadow: $shadow-sm;\r\n  transition: box-shadow $transition-base;\r\n\r\n  &:hover {\r\n    box-shadow: $shadow-md;\r\n  }\r\n}\r\n\r\n.gen-ui-card-title {\r\n  font-size: $text-lg;\r\n  font-weight: 600;\r\n  color: $gray-900;\r\n  margin: 0 0 $spacing-sm 0;\r\n}\r\n\r\n.gen-ui-card-content {\r\n  font-size: $text-base;\r\n  color: $gray-700;\r\n  margin: 0;\r\n  line-height: 1.5;\r\n}\r\n\r\n// List Component\r\n.gen-ui-list {\r\n  list-style-type: disc;\r\n  padding-left: $spacing-xl;\r\n  margin: 0;\r\n}\r\n\r\n.gen-ui-list-item {\r\n  font-size: $text-base;\r\n  color: $gray-800;\r\n  line-height: 1.6;\r\n  margin-bottom: $spacing-xs;\r\n\r\n  &:last-child {\r\n    margin-bottom: 0;\r\n  }\r\n}\r\n\r\n// Image Component\r\n.gen-ui-image {\r\n  max-width: 100%;\r\n  height: auto;\r\n  border-radius: $radius-md;\r\n  display: block;\r\n}\r\n\r\n// Link Component\r\n.gen-ui-link {\r\n  color: $blue-600;\r\n  text-decoration: none;\r\n  font-size: $text-base;\r\n  transition: color $transition-base;\r\n\r\n  &:hover {\r\n    color: $blue-700;\r\n    text-decoration: underline;\r\n  }\r\n\r\n  &:visited {\r\n    color: $blue-600;\r\n  }\r\n}\r\n\r\n// Table Component\r\n.gen-ui-table-wrapper {\r\n  width: 100%;\r\n  overflow-x: auto;\r\n  border: 1px solid $gray-200;\r\n  border-radius: $radius-lg;\r\n  background-color: $white;\r\n  box-shadow: $shadow-sm;\r\n}\r\n\r\n.gen-ui-table {\r\n  width: 100%;\r\n  border-collapse: collapse;\r\n  min-width: 100%;\r\n}\r\n\r\n.gen-ui-table-header {\r\n  background-color: $gray-50;\r\n}\r\n\r\n.gen-ui-table-th {\r\n  padding: 12px $spacing-lg;\r\n  text-align: left;\r\n  font-size: $text-sm;\r\n  font-weight: 600;\r\n  color: $gray-700;\r\n  border-bottom: 2px solid $gray-200;\r\n  white-space: nowrap;\r\n}\r\n\r\n.gen-ui-table-body {\r\n  tr {\r\n    transition: background-color $transition-base;\r\n\r\n    &:hover {\r\n      background-color: $gray-50;\r\n    }\r\n\r\n    &:not(:last-child) {\r\n      border-bottom: 1px solid $gray-200;\r\n    }\r\n  }\r\n}\r\n\r\n.gen-ui-table-td {\r\n  padding: 12px $spacing-lg;\r\n  font-size: $text-base;\r\n  color: $gray-800;\r\n  vertical-align: middle;\r\n}\r\n\r\n// Form Component\r\n.gen-ui-form {\r\n  display: flex;\r\n  flex-direction: column;\r\n  gap: $spacing-lg;\r\n  width: 100%;\r\n}\r\n\r\n"]} */`;
1458
+ document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css));
37
1459
 
38
1460
  // src/utils/cx.ts
39
1461
  function validateHeaders(headers, authConfig, opts = {}) {
1462
+ if (headers && (!authConfig || Object.keys(authConfig).length === 0)) {
1463
+ return {
1464
+ isValid: false,
1465
+ missingKeys: [],
1466
+ extraKeys: [],
1467
+ emptyValueKeys: [],
1468
+ warning: "Auth config bo\u015F ya da tan\u0131ms\u0131z, header do\u011Frulamas\u0131 yap\u0131lam\u0131yor."
1469
+ };
1470
+ }
40
1471
  const { caseSensitive = false, allowExtra = false } = opts;
41
1472
  const normalize = (s) => caseSensitive ? s : s.toLowerCase();
42
1473
  const headerEntries = Object.entries(headers).map(([k, v]) => [normalize(k), v.trim()]);
@@ -55,90 +1486,14 @@ function validateHeaders(headers, authConfig, opts = {}) {
55
1486
  const isValid = hasAllRequired && !hasExtraKeys && emptyValueKeys.length === 0;
56
1487
  return { isValid, missingKeys, extraKeys, emptyValueKeys };
57
1488
  }
58
-
59
- // src/store/static.ts
60
- var defaultConfig = {
61
- auth_config: {
62
- "header": ""
63
- },
64
- chat_widget_settings: {
65
- welcome_message: "Merhaba! Size nas\u0131l yard\u0131mc\u0131 olabilirim?",
66
- button_background: "linear-gradient(135deg, #667eea 0%, #764ba2 100%)",
67
- placeholder: "Mesaj\u0131n\u0131z\u0131 yaz\u0131n...",
68
- button_position: "bottom-left",
69
- button_size: "medium",
70
- chat_width: "400px",
71
- chat_height: "600px",
72
- show_typing_indicator: true,
73
- initial_open: true,
74
- header_background: "linear-gradient(135deg, #667eea 0%, #764ba2 100%)",
75
- company_logo: "",
76
- company_name: "Aizek",
77
- api_source_id: 0,
78
- chat_widget_settings_id: 0,
79
- created_at: "",
80
- updated_at: ""
81
- },
82
- mcp_url: "",
83
- openai_key: ""
84
- };
85
- var GENERATIVE_UI_SYSTEM_PROMPT = `
86
- You can generate interactive UI components as part of your responses.
87
- When users need to:
88
- - Provide multiple pieces of information \u2192 Generate a FORM
89
- - Make a choice between options \u2192 Generate BUTTONS
90
- - View structured data \u2192 Generate a TABLE or LIST
91
- - See entity details \u2192 Generate a CARD
92
-
93
- For each component type, include JSON in this format:
94
-
95
- \`\`\`ui-component
96
- {
97
- "version": "1.0",
98
- "title": string,
99
- "description"?: string,
100
- "components": Array<{
101
- id: string,
102
- type:
103
- | "text"
104
- | "input"
105
- | "button"
106
- | "select"
107
- | "card"
108
- | "list"
109
- | "image"
110
- | "link"
111
- | "table"
112
- | "form",
113
- label?: string,
114
- fieldType?: "text" | "number" | "date" | "textarea",
115
- requiredField?: boolean,
116
- placeholder?: string,
117
- options?: string[],
118
- columns?: string[],
119
- rows?: string[][],
120
- url?: string,
121
- fieldName?: string
122
- buttonType?: click | submit
123
- }>
124
- }
125
- \`\`\`
126
-
127
-
128
-
129
-
130
-
131
- Always provide both a conversational text response AND appropriate UI components.
132
-
133
- `;
134
1489
  var HeaderAlert = ({ headerValidation, showAlert, setShowAlert }) => {
135
1490
  if (!headerValidation || !showAlert) return null;
136
- const { isValid, missingKeys, extraKeys, emptyValueKeys } = headerValidation;
137
- if (isValid && missingKeys.length === 0 && extraKeys.length === 0 && emptyValueKeys.length === 0) {
1491
+ const { isValid, missingKeys, extraKeys, emptyValueKeys, warning } = headerValidation;
1492
+ if (isValid && missingKeys.length === 0 && extraKeys.length === 0 && emptyValueKeys.length === 0 && !warning) {
138
1493
  return null;
139
1494
  }
140
1495
  const hasErrors = missingKeys.length > 0 || emptyValueKeys.length > 0;
141
- const hasWarnings = extraKeys.length > 0;
1496
+ const hasWarnings = extraKeys.length > 0 || !!warning;
142
1497
  const alertType = hasErrors ? "error" : "warning";
143
1498
  const getAlertIcon = () => {
144
1499
  if (hasErrors) {
@@ -172,6 +1527,10 @@ var HeaderAlert = ({ headerValidation, showAlert, setShowAlert }) => {
172
1527
  /* @__PURE__ */ jsxRuntime.jsx("span", { children: "\u2022" }),
173
1528
  /* @__PURE__ */ jsxRuntime.jsx("code", { children: key })
174
1529
  ] }, index)) })
1530
+ ] }),
1531
+ warning && /* @__PURE__ */ jsxRuntime.jsxs("div", { children: [
1532
+ /* @__PURE__ */ jsxRuntime.jsx("strong", { children: "Uyar\u0131:" }),
1533
+ /* @__PURE__ */ jsxRuntime.jsx("p", { className: "alert-message", children: warning })
175
1534
  ] })
176
1535
  ] }),
177
1536
  /* @__PURE__ */ jsxRuntime.jsx(
@@ -517,138 +1876,95 @@ var extractUIJsonFromText = (text) => {
517
1876
  uiData
518
1877
  };
519
1878
  };
520
- var generateId = () => Date.now().toString() + Math.random().toString(36).substr(2, 9);
521
- var normalizeHeaders = (headers) => {
522
- const result = {};
523
- for (const [key, value] of Object.entries(headers)) {
524
- if (!value) continue;
525
- if (key.toLowerCase() === "cookie") {
526
- result["x-cookie"] = value;
527
- } else {
528
- result[key] = value;
529
- }
530
- }
531
- return result;
532
- };
533
- var AizekChatBot = ({ clientId, headers }) => {
1879
+ var AizekChatBot = ({ clientId, headers, onMounted, onReady, onOpen, onClose, onMessage, onToolCall, onDisconnect }) => {
534
1880
  const messagesEndRef = react.useRef(null);
535
- const [config, setConfig] = react.useState(defaultConfig);
536
- const [anthropic, setAnthropic] = react.useState();
1881
+ const [config, setConfig] = react.useState();
537
1882
  const [messages, setMessages] = react.useState([]);
538
1883
  const [isLoading, setIsLoading] = react.useState(false);
539
- const [mcpClient, setMcpClient] = react.useState();
540
1884
  const [isConfigLoading, setIsConfigLoading] = react.useState(true);
541
1885
  const [isOpen, setIsOpen] = react.useState(false);
542
1886
  const [headerValidation, setHeaderValidation] = react.useState(null);
543
1887
  const [showAlert, setShowAlert] = react.useState(true);
544
- const { button_background, button_position, button_size, chat_height, chat_width, company_logo, company_name, header_background, initial_open, placeholder, show_typing_indicator, welcome_message } = config.chat_widget_settings;
545
- react.useEffect(() => {
546
- const loadConfig = async () => {
547
- try {
548
- setIsConfigLoading(true);
549
- const apiResponse = await fetchChatWidgetSettings(clientId);
550
- if (apiResponse.success) {
551
- const anthropic2 = new Anthropic__default.default({ apiKey: apiResponse.data.openai_key, dangerouslyAllowBrowser: true });
552
- const mcpClient2 = new client.Client({ name: "mcp-client-cli", version: "1.0.0" });
553
- const transport = new sse_js.SSEClientTransport(new URL("", apiResponse.data.mcp_url), {
554
- eventSourceInit: {
555
- fetch: (url, init) => {
556
- if (headers) {
557
- const dynamicHeaders = normalizeHeaders(headers);
558
- return fetch(url, {
559
- headers: {
560
- ...init?.headers ?? {},
561
- ...dynamicHeaders
562
- }
563
- });
564
- } else {
565
- return fetch(url, {
566
- headers: {
567
- ...init?.headers ?? {}
568
- }
569
- });
570
- }
571
- }
1888
+ const loadConfig = async () => {
1889
+ try {
1890
+ setIsConfigLoading(true);
1891
+ const response = await fetch("https://proxy.aizek.ai/api/aizek-connect", {
1892
+ method: "POST",
1893
+ headers: {
1894
+ "Content-Type": "application/json",
1895
+ ...headers
1896
+ },
1897
+ body: JSON.stringify({ clientId }),
1898
+ credentials: "include"
1899
+ });
1900
+ const data = await response.json();
1901
+ if (data.success) {
1902
+ setIsOpen(data.data.chat_widget_settings.initial_open);
1903
+ setConfig(data.data);
1904
+ console.log(data.data);
1905
+ if (headers) {
1906
+ const validationResult = validateHeaders(
1907
+ headers,
1908
+ data.data.auth_config,
1909
+ {
1910
+ allowExtra: false,
1911
+ caseSensitive: true
572
1912
  }
573
- });
574
- await mcpClient2.connect(transport);
575
- setMcpClient(mcpClient2);
576
- setAnthropic(anthropic2);
577
- if (headers && apiResponse.data.auth_config) {
578
- const validationResult = validateHeaders(
579
- headers,
580
- apiResponse.data.auth_config,
581
- {
582
- allowExtra: false,
583
- caseSensitive: true
584
- }
585
- );
586
- setHeaderValidation(validationResult);
587
- }
588
- if (!apiResponse.data.chat_widget_settings) {
589
- setConfig({
590
- auth_config: apiResponse.data.auth_config,
591
- mcp_url: apiResponse.data.mcp_url,
592
- openai_key: apiResponse.data.openai_key,
593
- chat_widget_settings: {
594
- api_source_id: 0,
595
- chat_widget_settings_id: 0,
596
- created_at: "",
597
- updated_at: "",
598
- button_background: defaultConfig.chat_widget_settings.button_background,
599
- button_position: defaultConfig.chat_widget_settings.button_position,
600
- button_size: defaultConfig.chat_widget_settings.button_size,
601
- chat_height: defaultConfig.chat_widget_settings.chat_height,
602
- chat_width: defaultConfig.chat_widget_settings.chat_width,
603
- company_logo: defaultConfig.chat_widget_settings.company_logo,
604
- company_name: defaultConfig.chat_widget_settings.company_name,
605
- header_background: defaultConfig.chat_widget_settings.header_background,
606
- initial_open: defaultConfig.chat_widget_settings.initial_open,
607
- placeholder: defaultConfig.chat_widget_settings.placeholder,
608
- show_typing_indicator: defaultConfig.chat_widget_settings.show_typing_indicator,
609
- welcome_message: defaultConfig.chat_widget_settings.welcome_message
610
- }
611
- });
612
- } else {
613
- setConfig(apiResponse.data);
614
- }
1913
+ );
1914
+ setHeaderValidation(validationResult);
615
1915
  }
616
- } catch (error) {
617
- console.error("Failed to load chat widget config:", error);
618
- } finally {
619
- setIsConfigLoading(false);
1916
+ onReady?.({ config: { ...data.data } });
1917
+ } else {
1918
+ setIsOpen(false);
620
1919
  }
621
- };
1920
+ } catch (error) {
1921
+ console.error("Failed to load chat widget config:", error);
1922
+ } finally {
1923
+ setIsConfigLoading(false);
1924
+ }
1925
+ };
1926
+ const disconnect = async () => {
1927
+ try {
1928
+ setIsConfigLoading(true);
1929
+ await fetch("http://localhost:3001/api/aizek-disconnect", {
1930
+ method: "POST",
1931
+ headers: {
1932
+ "Content-Type": "application/json",
1933
+ ...headers
1934
+ },
1935
+ credentials: "include"
1936
+ });
1937
+ onDisconnect?.();
1938
+ } catch (error) {
1939
+ console.error("Failed to load chat widget config:", error);
1940
+ } finally {
1941
+ setIsConfigLoading(false);
1942
+ }
1943
+ };
1944
+ react.useEffect(() => {
1945
+ onMounted?.();
622
1946
  loadConfig();
1947
+ return () => {
1948
+ disconnect();
1949
+ };
623
1950
  }, []);
624
1951
  react.useEffect(() => {
625
- setIsOpen(initial_open);
626
- }, [initial_open]);
1952
+ const newIsOpen = !isOpen;
1953
+ setIsOpen(newIsOpen);
1954
+ if (newIsOpen) onOpen?.();
1955
+ else onClose?.();
1956
+ }, [config?.chat_widget_settings.initial_open]);
627
1957
  react.useEffect(() => {
628
1958
  messagesEndRef.current?.scrollIntoView({ behavior: "smooth" });
629
1959
  }, [messages]);
630
- if (isConfigLoading || !mcpClient || !anthropic) {
631
- return /* @__PURE__ */ jsxRuntime.jsx("button", { className: `floating-button ${button_position} button-sizes ${button_size}`, style: { background: button_background }, children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: "loading-spinner" }) });
632
- }
633
- const historyMessages = (history, currentUserText) => {
634
- const claudeHistory = history.filter((m) => m.role === "user" || m.role === "assistant").map((m) => ({
635
- role: m.role,
636
- content: m.text ?? JSON.stringify(m.ui ?? "")
637
- }));
638
- claudeHistory.push({
639
- role: "user",
640
- content: currentUserText
641
- });
642
- return claudeHistory;
643
- };
644
1960
  const addMessage = (payload) => {
645
1961
  const newMessage = {
646
- id: generateId(),
647
1962
  text: payload.text,
648
1963
  ui: payload.ui,
649
1964
  role: payload.role,
650
1965
  timestamp: /* @__PURE__ */ new Date()
651
1966
  };
1967
+ onMessage?.(newMessage);
652
1968
  setMessages((prev) => [...prev, newMessage]);
653
1969
  messagesEndRef.current?.scrollIntoView({ behavior: "smooth" });
654
1970
  return newMessage;
@@ -656,7 +1972,6 @@ var AizekChatBot = ({ clientId, headers }) => {
656
1972
  const sendMessage = async (message, approval) => {
657
1973
  if (!message.trim() || isLoading) return;
658
1974
  const newMessage = {
659
- id: generateId(),
660
1975
  text: message,
661
1976
  ui: void 0,
662
1977
  role: approval ? "approval" : "user",
@@ -664,105 +1979,141 @@ var AizekChatBot = ({ clientId, headers }) => {
664
1979
  };
665
1980
  setMessages((prev) => [...prev, newMessage]);
666
1981
  setIsLoading(true);
667
- const toolsResult = await mcpClient.listTools();
668
- const tools = toolsResult.tools.map((tool) => {
669
- return {
670
- name: tool.name,
671
- description: tool.description,
672
- input_schema: tool.inputSchema
673
- };
674
- });
675
1982
  try {
676
- const historyForContext = historyMessages([...messages, newMessage], message);
677
- const response = await anthropic.beta.messages.create({
678
- model: "claude-sonnet-4-5",
679
- betas: ["structured-outputs-2025-11-13"],
680
- max_tokens: 5e3,
681
- messages: historyForContext,
682
- tools,
683
- system: GENERATIVE_UI_SYSTEM_PROMPT
1983
+ const response = await fetch("http://localhost:3001/api/aizek-chat", {
1984
+ method: "POST",
1985
+ headers: {
1986
+ "Content-Type": "application/json"
1987
+ },
1988
+ body: JSON.stringify({ message }),
1989
+ credentials: "include"
684
1990
  });
685
- for (const content of response.content) {
686
- if (content.type === "tool_use") {
687
- const toolCall = await mcpClient.callTool({ name: content.name, arguments: content.input });
688
- const toolMessagesForContext = historyMessages([...messages, newMessage], JSON.stringify(toolCall.structuredContent));
689
- const finalResponse = await anthropic.beta.messages.create({
690
- model: "claude-sonnet-4-5",
691
- max_tokens: 1024,
692
- betas: ["structured-outputs-2025-11-13"],
693
- messages: toolMessagesForContext,
694
- tools,
695
- system: GENERATIVE_UI_SYSTEM_PROMPT
696
- });
697
- const textBlock = finalResponse.content.find((x) => x.type === "text");
698
- const { cleanedText, uiData } = extractUIJsonFromText(textBlock?.text ?? "");
699
- addMessage({ ui: uiData, text: cleanedText || void 0, role: "assistant" });
700
- } else if (content.type === "text") {
701
- const { cleanedText, uiData } = extractUIJsonFromText(content?.text);
702
- console.log(cleanedText, uiData);
703
- addMessage({ ui: uiData, text: cleanedText || void 0, role: "assistant" });
1991
+ if (!response.ok) {
1992
+ throw new Error(`HTTP error ${response.status}`);
1993
+ }
1994
+ if (!response.body) {
1995
+ throw new Error("Streaming desteklenmiyor (response.body yok)");
1996
+ }
1997
+ const reader = response.body.getReader();
1998
+ const decoder = new TextDecoder();
1999
+ let buffer = "";
2000
+ while (true) {
2001
+ const { value, done } = await reader.read();
2002
+ if (done) break;
2003
+ buffer += decoder.decode(value, { stream: true });
2004
+ const chunks = buffer.split("\n\n");
2005
+ buffer = chunks.pop() ?? "";
2006
+ for (const rawChunk of chunks) {
2007
+ const line = rawChunk.split("\n").find((l) => l.startsWith("data:"));
2008
+ if (!line) continue;
2009
+ const jsonStr = line.replace(/^data:\s*/, "").trim();
2010
+ if (!jsonStr) continue;
2011
+ const event = JSON.parse(jsonStr);
2012
+ if (event.type === "assistant_text" && event.content) {
2013
+ const { cleanedText, uiData } = extractUIJsonFromText(event.content);
2014
+ addMessage({
2015
+ text: cleanedText,
2016
+ ui: uiData,
2017
+ role: "assistant"
2018
+ });
2019
+ }
2020
+ if (event.type === "assistant_tool_result" && event.content) {
2021
+ const toolInfoParsed = JSON.parse(event.content);
2022
+ onToolCall?.(toolInfoParsed);
2023
+ }
2024
+ if (event.type === "error" && event.content) {
2025
+ const { cleanedText, uiData } = extractUIJsonFromText(event.content);
2026
+ addMessage({
2027
+ text: cleanedText,
2028
+ ui: uiData,
2029
+ role: "assistant"
2030
+ });
2031
+ }
704
2032
  }
705
2033
  }
706
- setIsLoading(false);
707
2034
  } catch (error) {
708
2035
  console.error("Error sending message:", error);
709
2036
  addMessage({ text: "\xDCzg\xFCn\xFCm, bir hata olu\u015Ftu. L\xFCtfen tekrar deneyin.", role: "assistant" });
2037
+ } finally {
710
2038
  setIsLoading(false);
711
2039
  }
712
2040
  };
713
2041
  const toggleChat = () => {
714
2042
  const newIsOpen = !isOpen;
715
2043
  setIsOpen(newIsOpen);
2044
+ if (newIsOpen) onOpen?.();
2045
+ else onClose?.();
716
2046
  };
717
- return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
2047
+ return /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, { children: isConfigLoading ? /* @__PURE__ */ jsxRuntime.jsx(
2048
+ "button",
2049
+ {
2050
+ className: "floating-button bottom-right button-sizes medium loading-state",
2051
+ style: { background: "#4f46e5" },
2052
+ "aria-label": "Y\xFCkleniyor",
2053
+ children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: "loading-spinner" })
2054
+ }
2055
+ ) : /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
718
2056
  isOpen && /* @__PURE__ */ jsxRuntime.jsx("div", { className: `overlay floating-chat-overlay ${isOpen ? "is-open" : ""}`, onClick: toggleChat }),
719
- /* @__PURE__ */ jsxRuntime.jsx("div", { className: `chat-container ${button_position} ${isOpen ? "is-open" : ""}`, style: { width: chat_width, height: chat_height }, children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "chatbot-container", children: [
720
- /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "header", style: { background: header_background }, children: [
721
- /* @__PURE__ */ jsxRuntime.jsx("div", { className: "logo-container", children: company_logo ? company_logo.startsWith("http") || company_logo.startsWith("data:") ? /* @__PURE__ */ jsxRuntime.jsx(
2057
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: `chat-container ${config?.chat_widget_settings.button_position} ${isOpen ? "is-open" : ""}`, style: { width: config?.chat_widget_settings.chat_width, height: config?.chat_widget_settings.chat_height }, children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "chatbot-container", children: [
2058
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "header", style: { background: config?.chat_widget_settings.header_background }, children: [
2059
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: "logo-container", children: config?.chat_widget_settings.company_logo ? config?.chat_widget_settings.company_logo.startsWith("http") || config?.chat_widget_settings.company_logo.startsWith("data:") ? /* @__PURE__ */ jsxRuntime.jsx(
722
2060
  "img",
723
2061
  {
724
- src: company_logo,
2062
+ src: config?.chat_widget_settings.company_logo,
725
2063
  alt: "Company Logo",
726
2064
  className: "logo-image"
727
2065
  }
728
- ) : /* @__PURE__ */ jsxRuntime.jsx("span", { className: "logo-text", children: company_logo }) : "\u{1F916}" }),
2066
+ ) : /* @__PURE__ */ jsxRuntime.jsx("span", { className: "logo-text", children: config?.chat_widget_settings.company_logo }) : "\u{1F916}" }),
729
2067
  /* @__PURE__ */ jsxRuntime.jsxs("div", { children: [
730
- /* @__PURE__ */ jsxRuntime.jsx("h3", { className: "company-name", children: company_name }),
2068
+ /* @__PURE__ */ jsxRuntime.jsx("h3", { className: "company-name", children: config?.chat_widget_settings.company_name }),
731
2069
  /* @__PURE__ */ jsxRuntime.jsx("p", { className: "status-text", children: isLoading ? "Yaz\u0131yor..." : "\xC7evrimi\xE7i" })
732
2070
  ] })
733
2071
  ] }),
734
2072
  /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "messages-container", children: [
735
- /* @__PURE__ */ jsxRuntime.jsx(HeaderAlert, { headerValidation, setShowAlert, showAlert }),
2073
+ /* @__PURE__ */ jsxRuntime.jsx(
2074
+ HeaderAlert,
2075
+ {
2076
+ headerValidation,
2077
+ setShowAlert,
2078
+ showAlert
2079
+ }
2080
+ ),
736
2081
  messages.length === 0 ? /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "empty-state", children: [
737
2082
  /* @__PURE__ */ jsxRuntime.jsx("div", { className: "empty-state-icon", children: "\u{1F4AC}" }),
738
- /* @__PURE__ */ jsxRuntime.jsx("h4", { className: "empty-state-title", children: welcome_message }),
2083
+ /* @__PURE__ */ jsxRuntime.jsx("h4", { className: "empty-state-title", children: config?.chat_widget_settings.welcome_message }),
739
2084
  /* @__PURE__ */ jsxRuntime.jsx("p", { className: "empty-state-description", children: "A\u015Fa\u011F\u0131daki alana mesaj\u0131n\u0131z\u0131 yazarak ba\u015Flayabilirsiniz." })
740
2085
  ] }) : /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
741
- messages.map((message) => /* @__PURE__ */ jsxRuntime.jsx(
2086
+ messages.map((message, index) => /* @__PURE__ */ jsxRuntime.jsx(
742
2087
  MessageBubble,
743
2088
  {
744
2089
  message,
745
2090
  onAction: sendMessage
746
2091
  },
747
- message.id
2092
+ index
748
2093
  )),
749
- show_typing_indicator && isLoading && /* @__PURE__ */ jsxRuntime.jsx(TypingDots, {})
750
- ] }),
751
- /* @__PURE__ */ jsxRuntime.jsx("div", { ref: messagesEndRef })
2094
+ config?.chat_widget_settings.show_typing_indicator && isLoading && /* @__PURE__ */ jsxRuntime.jsx(TypingDots, {})
2095
+ ] })
752
2096
  ] }),
753
- /* @__PURE__ */ jsxRuntime.jsx(ChatInput, { handleSendMessage: sendMessage, isLoading, placeholder })
2097
+ /* @__PURE__ */ jsxRuntime.jsx(
2098
+ ChatInput,
2099
+ {
2100
+ handleSendMessage: sendMessage,
2101
+ isLoading,
2102
+ placeholder: config?.chat_widget_settings.placeholder ?? ""
2103
+ }
2104
+ )
754
2105
  ] }) }),
755
2106
  /* @__PURE__ */ jsxRuntime.jsx(
756
2107
  "button",
757
2108
  {
758
2109
  onClick: toggleChat,
759
- className: `floating-button ${button_position} button-sizes ${button_size} ${isOpen ? "is-open" : ""}`,
760
- style: { background: button_background },
2110
+ className: `floating-button ${config?.chat_widget_settings.button_position} button-sizes ${config?.chat_widget_settings.button_size} ${isOpen ? "is-open" : ""}`,
2111
+ style: { background: config?.chat_widget_settings.button_background },
761
2112
  "aria-label": isOpen ? "Chati kapat" : "Chati a\xE7",
762
2113
  children: isOpen ? /* @__PURE__ */ jsxRuntime.jsx("svg", { width: "24", height: "24", viewBox: "0 0 24 24", fill: "currentColor", children: /* @__PURE__ */ jsxRuntime.jsx("path", { d: "M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z" }) }) : /* @__PURE__ */ jsxRuntime.jsx("svg", { width: "24", height: "24", viewBox: "0 0 24 24", fill: "currentColor", children: /* @__PURE__ */ jsxRuntime.jsx("path", { d: "M20 2H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h4l4 4 4-4h4c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-2 12H6v-2h12v2zm0-3H6V9h12v2zm0-3H6V6h12v2z" }) })
763
2114
  }
764
2115
  )
765
- ] });
2116
+ ] }) });
766
2117
  };
767
2118
 
768
2119
  exports.AizekChatBot = AizekChatBot;