@promptbook/components 0.103.0-55 → 0.103.0-66
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/esm/index.es.js +1083 -552
- package/esm/index.es.js.map +1 -1
- package/esm/typings/src/_packages/components.index.d.ts +2 -2
- package/esm/typings/src/_packages/core.index.d.ts +6 -8
- package/esm/typings/src/_packages/types.index.d.ts +7 -1
- package/esm/typings/src/book-2.0/agent-source/AgentBasicInformation.d.ts +2 -1
- package/esm/typings/src/book-2.0/agent-source/createCommitmentRegex.d.ts +1 -1
- package/esm/typings/src/book-components/Chat/AgentChat/AgentChat.d.ts +3 -0
- package/esm/typings/src/book-components/Chat/Chat/ChatProps.d.ts +6 -0
- package/esm/typings/src/book-components/Chat/LlmChat/LlmChatProps.d.ts +5 -0
- package/esm/typings/src/book-components/PromptbookAgent/PromptbookAgentIntegration.d.ts +52 -0
- package/esm/typings/src/book-components/PromptbookAgent/PromptbookAgentSeamlessIntegration.d.ts +14 -0
- package/esm/typings/src/book-components/icons/SendIcon.d.ts +3 -0
- package/esm/typings/src/commitments/CLOSED/CLOSED.d.ts +4 -0
- package/esm/typings/src/commitments/CLOSED/CLOSED.test.d.ts +4 -0
- package/esm/typings/src/commitments/META_COLOR/META_COLOR.d.ts +6 -0
- package/esm/typings/src/commitments/META_FONT/META_FONT.d.ts +42 -0
- package/esm/typings/src/commitments/USE/USE.d.ts +53 -0
- package/esm/typings/src/commitments/USE_BROWSER/USE_BROWSER.d.ts +42 -0
- package/esm/typings/src/commitments/USE_BROWSER/USE_BROWSER.test.d.ts +1 -0
- package/esm/typings/src/commitments/{IMPORTANT/IMPORTANT.d.ts → USE_MCP/USE_MCP.d.ts} +16 -5
- package/esm/typings/src/commitments/USE_SEARCH_ENGINE/USE_SEARCH_ENGINE.d.ts +38 -0
- package/esm/typings/src/commitments/_base/BaseCommitmentDefinition.d.ts +6 -0
- package/esm/typings/src/commitments/index.d.ts +93 -1
- package/esm/typings/src/llm-providers/agent/Agent.d.ts +3 -1
- package/esm/typings/src/other/templates/getTemplatesPipelineCollection.d.ts +1 -1
- package/esm/typings/src/playground/playground.d.ts +3 -0
- package/esm/typings/src/types/typeAliases.d.ts +6 -0
- package/esm/typings/src/utils/color/Color.d.ts +9 -1
- package/esm/typings/src/utils/color/css-colors.d.ts +1 -0
- package/esm/typings/src/utils/random/$generateBookBoilerplate.d.ts +6 -0
- package/esm/typings/src/utils/random/CzechNamePool.d.ts +7 -0
- package/esm/typings/src/utils/random/EnglishNamePool.d.ts +7 -0
- package/esm/typings/src/utils/random/NamePool.d.ts +17 -0
- package/esm/typings/src/utils/random/getNamePool.d.ts +10 -0
- package/esm/typings/src/version.d.ts +1 -1
- package/package.json +2 -2
- package/umd/index.umd.js +1071 -540
- package/umd/index.umd.js.map +1 -1
- package/esm/typings/src/book-components/PromptbookAgent/PromptbookAgent.d.ts +0 -29
- package/esm/typings/src/commitments/registry.d.ts +0 -68
- package/esm/typings/src/playground/playground1.d.ts +0 -2
package/esm/index.es.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
|
|
2
2
|
import { useMemo, useEffect, useState, useRef, useCallback, forwardRef, memo } from 'react';
|
|
3
|
-
import spaceTrim, { spaceTrim as spaceTrim$1 } from 'spacetrim';
|
|
3
|
+
import spaceTrim$2, { spaceTrim as spaceTrim$1 } from 'spacetrim';
|
|
4
4
|
import { SHA256 } from 'crypto-js';
|
|
5
5
|
import hexEncoder from 'crypto-js/enc-hex';
|
|
6
6
|
import { basename, join, dirname, isAbsolute } from 'path';
|
|
@@ -35,7 +35,7 @@ const BOOK_LANGUAGE_VERSION = '2.0.0';
|
|
|
35
35
|
* @generated
|
|
36
36
|
* @see https://github.com/webgptorg/promptbook
|
|
37
37
|
*/
|
|
38
|
-
const PROMPTBOOK_ENGINE_VERSION = '0.103.0-
|
|
38
|
+
const PROMPTBOOK_ENGINE_VERSION = '0.103.0-66';
|
|
39
39
|
/**
|
|
40
40
|
* TODO: string_promptbook_version should be constrained to the all versions of Promptbook engine
|
|
41
41
|
* Note: [💞] Ignore a discrepancy between file name and entity name
|
|
@@ -247,6 +247,17 @@ CORE_SERVER.urls;
|
|
|
247
247
|
* Note: [💞] Ignore a discrepancy between file name and entity name
|
|
248
248
|
*/
|
|
249
249
|
|
|
250
|
+
/**
|
|
251
|
+
* Trims string from all 4 sides
|
|
252
|
+
*
|
|
253
|
+
* Note: This is a re-exported function from the `spacetrim` package which is
|
|
254
|
+
* Developed by same author @hejny as this package
|
|
255
|
+
*
|
|
256
|
+
* @public exported from `@promptbook/utils`
|
|
257
|
+
* @see https://github.com/hejny/spacetrim#usage
|
|
258
|
+
*/
|
|
259
|
+
const spaceTrim = spaceTrim$1;
|
|
260
|
+
|
|
250
261
|
/**
|
|
251
262
|
* @private util of `@promptbook/color`
|
|
252
263
|
* @de
|
|
@@ -295,6 +306,7 @@ function take(initialValue) {
|
|
|
295
306
|
* @public exported from `@promptbook/color`
|
|
296
307
|
*/
|
|
297
308
|
const CSS_COLORS = {
|
|
309
|
+
promptbook: '#79EAFD',
|
|
298
310
|
transparent: 'rgba(0,0,0,0)',
|
|
299
311
|
aliceblue: '#f0f8ff',
|
|
300
312
|
antiquewhite: '#faebd7',
|
|
@@ -495,21 +507,61 @@ class Color {
|
|
|
495
507
|
* @param color
|
|
496
508
|
* @returns Color object
|
|
497
509
|
*/
|
|
498
|
-
static from(color) {
|
|
499
|
-
if (color
|
|
510
|
+
static from(color, _isSingleValue = false) {
|
|
511
|
+
if (color === '') {
|
|
512
|
+
throw new Error(`Can not create color from empty string`);
|
|
513
|
+
}
|
|
514
|
+
else if (color instanceof Color) {
|
|
500
515
|
return take(color);
|
|
501
516
|
}
|
|
502
517
|
else if (Color.isColor(color)) {
|
|
503
518
|
return take(color);
|
|
504
519
|
}
|
|
505
520
|
else if (typeof color === 'string') {
|
|
506
|
-
|
|
521
|
+
try {
|
|
522
|
+
return Color.fromString(color);
|
|
523
|
+
}
|
|
524
|
+
catch (error) {
|
|
525
|
+
// <- Note: Can not use `assertsError(error)` here because it causes circular dependency
|
|
526
|
+
if (_isSingleValue) {
|
|
527
|
+
throw error;
|
|
528
|
+
}
|
|
529
|
+
const parts = color.split(/[\s+,;|]/);
|
|
530
|
+
if (parts.length > 0) {
|
|
531
|
+
return Color.from(parts[0].trim(), true);
|
|
532
|
+
}
|
|
533
|
+
else {
|
|
534
|
+
throw new Error(`Can not create color from given string "${color}"`);
|
|
535
|
+
}
|
|
536
|
+
}
|
|
507
537
|
}
|
|
508
538
|
else {
|
|
509
539
|
console.error({ color });
|
|
510
540
|
throw new Error(`Can not create color from given object`);
|
|
511
541
|
}
|
|
512
542
|
}
|
|
543
|
+
/**
|
|
544
|
+
* Creates a new Color instance from miscellaneous formats
|
|
545
|
+
* It just does not throw error when it fails, it returns PROMPTBOOK_COLOR instead
|
|
546
|
+
*
|
|
547
|
+
* @param color
|
|
548
|
+
* @returns Color object
|
|
549
|
+
*/
|
|
550
|
+
static fromSafe(color) {
|
|
551
|
+
try {
|
|
552
|
+
return Color.from(color);
|
|
553
|
+
}
|
|
554
|
+
catch (error) {
|
|
555
|
+
// <- Note: Can not use `assertsError(error)` here because it causes circular dependency
|
|
556
|
+
console.warn(spaceTrim((block) => `
|
|
557
|
+
Color.fromSafe error:
|
|
558
|
+
${block(error.message)}
|
|
559
|
+
|
|
560
|
+
Returning default PROMPTBOOK_COLOR.
|
|
561
|
+
`));
|
|
562
|
+
return Color.fromString('promptbook');
|
|
563
|
+
}
|
|
564
|
+
}
|
|
513
565
|
/**
|
|
514
566
|
* Creates a new Color instance from miscellaneous string formats
|
|
515
567
|
*
|
|
@@ -1127,7 +1179,7 @@ const CLAIM = `Turn your company's scattered knowledge into AI ready books`;
|
|
|
1127
1179
|
*
|
|
1128
1180
|
* @public exported from `@promptbook/core`
|
|
1129
1181
|
*/
|
|
1130
|
-
const PROMPTBOOK_COLOR = Color.
|
|
1182
|
+
const PROMPTBOOK_COLOR = Color.fromString('promptbook');
|
|
1131
1183
|
// <- TODO: [🧠][🈵] Using `Color` here increases the package size approx 3kb, maybe remove it
|
|
1132
1184
|
/**
|
|
1133
1185
|
* Colors for syntax highlighting in the `<BookEditor/>`
|
|
@@ -1359,7 +1411,7 @@ false);
|
|
|
1359
1411
|
function getErrorReportUrl(error) {
|
|
1360
1412
|
const report = {
|
|
1361
1413
|
title: `🐜 Error report from ${NAME}`,
|
|
1362
|
-
body: spaceTrim((block) => `
|
|
1414
|
+
body: spaceTrim$2((block) => `
|
|
1363
1415
|
|
|
1364
1416
|
|
|
1365
1417
|
\`${error.name || 'Error'}\` has occurred in the [${NAME}], please look into it @${ADMIN_GITHUB_NAME}.
|
|
@@ -1554,7 +1606,7 @@ function valueToString(value) {
|
|
|
1554
1606
|
* @public exported from `@promptbook/utils`
|
|
1555
1607
|
*/
|
|
1556
1608
|
function computeHash(value) {
|
|
1557
|
-
return SHA256(hexEncoder.parse(spaceTrim(valueToString(value)))).toString( /* hex */);
|
|
1609
|
+
return SHA256(hexEncoder.parse(spaceTrim$2(valueToString(value)))).toString( /* hex */);
|
|
1558
1610
|
}
|
|
1559
1611
|
/**
|
|
1560
1612
|
* TODO: [🥬][🥬] Use this ACRY
|
|
@@ -1661,7 +1713,7 @@ function checkSerializableAsJson(options) {
|
|
|
1661
1713
|
}
|
|
1662
1714
|
else if (typeof value === 'object') {
|
|
1663
1715
|
if (value instanceof Date) {
|
|
1664
|
-
throw new UnexpectedError(spaceTrim((block) => `
|
|
1716
|
+
throw new UnexpectedError(spaceTrim$2((block) => `
|
|
1665
1717
|
\`${name}\` is Date
|
|
1666
1718
|
|
|
1667
1719
|
Use \`string_date_iso8601\` instead
|
|
@@ -1680,7 +1732,7 @@ function checkSerializableAsJson(options) {
|
|
|
1680
1732
|
throw new UnexpectedError(`${name} is RegExp`);
|
|
1681
1733
|
}
|
|
1682
1734
|
else if (value instanceof Error) {
|
|
1683
|
-
throw new UnexpectedError(spaceTrim((block) => `
|
|
1735
|
+
throw new UnexpectedError(spaceTrim$2((block) => `
|
|
1684
1736
|
\`${name}\` is unserialized Error
|
|
1685
1737
|
|
|
1686
1738
|
Use function \`serializeError\`
|
|
@@ -1703,7 +1755,7 @@ function checkSerializableAsJson(options) {
|
|
|
1703
1755
|
}
|
|
1704
1756
|
catch (error) {
|
|
1705
1757
|
assertsError(error);
|
|
1706
|
-
throw new UnexpectedError(spaceTrim((block) => `
|
|
1758
|
+
throw new UnexpectedError(spaceTrim$2((block) => `
|
|
1707
1759
|
\`${name}\` is not serializable
|
|
1708
1760
|
|
|
1709
1761
|
${block(error.stack || error.message)}
|
|
@@ -1735,7 +1787,7 @@ function checkSerializableAsJson(options) {
|
|
|
1735
1787
|
}
|
|
1736
1788
|
}
|
|
1737
1789
|
else {
|
|
1738
|
-
throw new UnexpectedError(spaceTrim((block) => `
|
|
1790
|
+
throw new UnexpectedError(spaceTrim$2((block) => `
|
|
1739
1791
|
\`${name}\` is unknown type
|
|
1740
1792
|
|
|
1741
1793
|
Additional message for \`${name}\`:
|
|
@@ -2688,7 +2740,7 @@ function deserializeError(error) {
|
|
|
2688
2740
|
message = `${name}: ${message}`;
|
|
2689
2741
|
}
|
|
2690
2742
|
if (stack !== undefined && stack !== '') {
|
|
2691
|
-
message = spaceTrim((block) => `
|
|
2743
|
+
message = spaceTrim$2((block) => `
|
|
2692
2744
|
${block(message)}
|
|
2693
2745
|
|
|
2694
2746
|
Original stack trace:
|
|
@@ -2709,7 +2761,7 @@ function serializeError(error) {
|
|
|
2709
2761
|
const { name, message, stack } = error;
|
|
2710
2762
|
const { id } = error;
|
|
2711
2763
|
if (!Object.keys(ALL_ERRORS).includes(name)) {
|
|
2712
|
-
console.error(spaceTrim((block) => `
|
|
2764
|
+
console.error(spaceTrim$2((block) => `
|
|
2713
2765
|
|
|
2714
2766
|
Cannot serialize error with name "${name}"
|
|
2715
2767
|
|
|
@@ -2815,7 +2867,7 @@ function jsonParse(value) {
|
|
|
2815
2867
|
}
|
|
2816
2868
|
else if (typeof value !== 'string') {
|
|
2817
2869
|
console.error('Can not parse JSON from non-string value.', { text: value });
|
|
2818
|
-
throw new Error(spaceTrim(`
|
|
2870
|
+
throw new Error(spaceTrim$2(`
|
|
2819
2871
|
Can not parse JSON from non-string value.
|
|
2820
2872
|
|
|
2821
2873
|
The value type: ${typeof value}
|
|
@@ -2829,7 +2881,7 @@ function jsonParse(value) {
|
|
|
2829
2881
|
if (!(error instanceof Error)) {
|
|
2830
2882
|
throw error;
|
|
2831
2883
|
}
|
|
2832
|
-
throw new Error(spaceTrim((block) => `
|
|
2884
|
+
throw new Error(spaceTrim$2((block) => `
|
|
2833
2885
|
${block(error.message)}
|
|
2834
2886
|
|
|
2835
2887
|
The expected JSON text:
|
|
@@ -2948,7 +3000,7 @@ function templateParameters(template, parameters) {
|
|
|
2948
3000
|
*/
|
|
2949
3001
|
function prompt(strings, ...values) {
|
|
2950
3002
|
if (values.length === 0) {
|
|
2951
|
-
return spaceTrim(strings.join(''));
|
|
3003
|
+
return spaceTrim$2(strings.join(''));
|
|
2952
3004
|
}
|
|
2953
3005
|
const stringsWithHiddenParameters = strings.map((stringsItem) =>
|
|
2954
3006
|
// TODO: [0] DRY
|
|
@@ -2959,7 +3011,7 @@ function prompt(strings, ...values) {
|
|
|
2959
3011
|
let pipelineString = stringsWithHiddenParameters.reduce((result, stringsItem, i) => placeholderParameterNames[i] === undefined
|
|
2960
3012
|
? `${result}${stringsItem}`
|
|
2961
3013
|
: `${result}${stringsItem}{${placeholderParameterNames[i]}}`, '');
|
|
2962
|
-
pipelineString = spaceTrim(pipelineString);
|
|
3014
|
+
pipelineString = spaceTrim$2(pipelineString);
|
|
2963
3015
|
try {
|
|
2964
3016
|
pipelineString = templateParameters(pipelineString, parameters);
|
|
2965
3017
|
}
|
|
@@ -2968,7 +3020,7 @@ function prompt(strings, ...values) {
|
|
|
2968
3020
|
throw error;
|
|
2969
3021
|
}
|
|
2970
3022
|
console.error({ pipelineString, parameters, placeholderParameterNames, error });
|
|
2971
|
-
throw new UnexpectedError(spaceTrim((block) => `
|
|
3023
|
+
throw new UnexpectedError(spaceTrim$2((block) => `
|
|
2972
3024
|
Internal error in prompt template literal
|
|
2973
3025
|
|
|
2974
3026
|
${block(JSON.stringify({ strings, values }, null, 4))}}
|
|
@@ -3418,7 +3470,7 @@ function serializeToPromptbookJavascript(value) {
|
|
|
3418
3470
|
imports.push(`import { Color } from '@promptbook/color';`);
|
|
3419
3471
|
}
|
|
3420
3472
|
else if (typeof value === 'string') {
|
|
3421
|
-
const trimmed = spaceTrim(value);
|
|
3473
|
+
const trimmed = spaceTrim$2(value);
|
|
3422
3474
|
if (trimmed.includes('\n')) {
|
|
3423
3475
|
// Multiline string -> use `spaceTrim`
|
|
3424
3476
|
serializedValue = `spaceTrim(\`\n${value.replace(/`/g, '\\`')}\n\`)`;
|
|
@@ -3588,7 +3640,7 @@ function isValidPipelineUrl(url) {
|
|
|
3588
3640
|
* @public exported from `@promptbook/core`
|
|
3589
3641
|
*/
|
|
3590
3642
|
function normalizeAgentName(rawAgentName) {
|
|
3591
|
-
return titleToName(spaceTrim(rawAgentName));
|
|
3643
|
+
return titleToName(spaceTrim$2(rawAgentName));
|
|
3592
3644
|
}
|
|
3593
3645
|
|
|
3594
3646
|
/**
|
|
@@ -3609,15 +3661,19 @@ function createDefaultAgentName(agentSource) {
|
|
|
3609
3661
|
*
|
|
3610
3662
|
* @private - TODO: [🧠] Maybe should be public?
|
|
3611
3663
|
*/
|
|
3612
|
-
function createCommitmentRegex(commitment, aliases = []) {
|
|
3664
|
+
function createCommitmentRegex(commitment, aliases = [], requiresContent = true) {
|
|
3613
3665
|
const allCommitments = [commitment, ...aliases];
|
|
3614
3666
|
const patterns = allCommitments.map((c) => {
|
|
3615
3667
|
const escapedCommitment = c.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
|
|
3616
3668
|
return escapedCommitment.split(/\s+/).join('\\s+');
|
|
3617
3669
|
});
|
|
3618
3670
|
const keywordPattern = patterns.join('|');
|
|
3619
|
-
|
|
3620
|
-
|
|
3671
|
+
if (requiresContent) {
|
|
3672
|
+
return new RegExp(`^\\s*(?<type>${keywordPattern})\\b\\s+(?<contents>.+)$`, 'gim');
|
|
3673
|
+
}
|
|
3674
|
+
else {
|
|
3675
|
+
return new RegExp(`^\\s*(?<type>${keywordPattern})\\b(?:\\s+(?<contents>.+))?$`, 'gim');
|
|
3676
|
+
}
|
|
3621
3677
|
}
|
|
3622
3678
|
/**
|
|
3623
3679
|
* Generates a regex pattern to match a specific commitment type
|
|
@@ -3650,12 +3706,20 @@ class BaseCommitmentDefinition {
|
|
|
3650
3706
|
this.type = type;
|
|
3651
3707
|
this.aliases = aliases;
|
|
3652
3708
|
}
|
|
3709
|
+
/**
|
|
3710
|
+
* Whether this commitment requires content.
|
|
3711
|
+
* If true, regex will match only if there is content after the commitment keyword.
|
|
3712
|
+
* If false, regex will match even if there is no content.
|
|
3713
|
+
*/
|
|
3714
|
+
get requiresContent() {
|
|
3715
|
+
return true;
|
|
3716
|
+
}
|
|
3653
3717
|
/**
|
|
3654
3718
|
* Creates a regex pattern to match this commitment in agent source
|
|
3655
3719
|
* Uses the existing createCommitmentRegex function as internal helper
|
|
3656
3720
|
*/
|
|
3657
3721
|
createRegex() {
|
|
3658
|
-
return createCommitmentRegex(this.type, this.aliases);
|
|
3722
|
+
return createCommitmentRegex(this.type, this.aliases, this.requiresContent);
|
|
3659
3723
|
}
|
|
3660
3724
|
/**
|
|
3661
3725
|
* Creates a regex pattern to match just the commitment type
|
|
@@ -3824,6 +3888,12 @@ class ClosedCommitmentDefinition extends BaseCommitmentDefinition {
|
|
|
3824
3888
|
constructor() {
|
|
3825
3889
|
super('CLOSED');
|
|
3826
3890
|
}
|
|
3891
|
+
/**
|
|
3892
|
+
* The `CLOSED` commitment is standalone.
|
|
3893
|
+
*/
|
|
3894
|
+
get requiresContent() {
|
|
3895
|
+
return false;
|
|
3896
|
+
}
|
|
3827
3897
|
/**
|
|
3828
3898
|
* Short one-line description of CLOSED.
|
|
3829
3899
|
*/
|
|
@@ -4311,227 +4381,6 @@ class GoalCommitmentDefinition extends BaseCommitmentDefinition {
|
|
|
4311
4381
|
* Note: [💞] Ignore a discrepancy between file name and entity name
|
|
4312
4382
|
*/
|
|
4313
4383
|
|
|
4314
|
-
/**
|
|
4315
|
-
* Placeholder commitment definition for commitments that are not yet implemented
|
|
4316
|
-
*
|
|
4317
|
-
* This commitment simply adds its content 1:1 into the system message,
|
|
4318
|
-
* preserving the original behavior until proper implementation is added.
|
|
4319
|
-
*
|
|
4320
|
-
* @public exported from `@promptbook/core`
|
|
4321
|
-
*/
|
|
4322
|
-
class NotYetImplementedCommitmentDefinition extends BaseCommitmentDefinition {
|
|
4323
|
-
constructor(type) {
|
|
4324
|
-
super(type);
|
|
4325
|
-
}
|
|
4326
|
-
/**
|
|
4327
|
-
* Short one-line description of a placeholder commitment.
|
|
4328
|
-
*/
|
|
4329
|
-
get description() {
|
|
4330
|
-
return 'Placeholder commitment that appends content verbatim to the system message.';
|
|
4331
|
-
}
|
|
4332
|
-
/**
|
|
4333
|
-
* Icon for this commitment.
|
|
4334
|
-
*/
|
|
4335
|
-
get icon() {
|
|
4336
|
-
return '🚧';
|
|
4337
|
-
}
|
|
4338
|
-
/**
|
|
4339
|
-
* Markdown documentation available at runtime.
|
|
4340
|
-
*/
|
|
4341
|
-
get documentation() {
|
|
4342
|
-
return spaceTrim$1(`
|
|
4343
|
-
# ${this.type}
|
|
4344
|
-
|
|
4345
|
-
This commitment is not yet fully implemented.
|
|
4346
|
-
|
|
4347
|
-
## Key aspects
|
|
4348
|
-
|
|
4349
|
-
- Content is appended directly to the system message.
|
|
4350
|
-
- No special processing or validation is performed.
|
|
4351
|
-
- Behavior preserved until proper implementation is added.
|
|
4352
|
-
|
|
4353
|
-
## Status
|
|
4354
|
-
|
|
4355
|
-
- **Status:** Placeholder implementation
|
|
4356
|
-
- **Effect:** Appends content prefixed by commitment type
|
|
4357
|
-
- **Future:** Will be replaced with specialized logic
|
|
4358
|
-
|
|
4359
|
-
## Examples
|
|
4360
|
-
|
|
4361
|
-
\`\`\`book
|
|
4362
|
-
Example Agent
|
|
4363
|
-
|
|
4364
|
-
PERSONA You are a helpful assistant
|
|
4365
|
-
${this.type} Your content here
|
|
4366
|
-
RULE Always be helpful
|
|
4367
|
-
\`\`\`
|
|
4368
|
-
`);
|
|
4369
|
-
}
|
|
4370
|
-
applyToAgentModelRequirements(requirements, content) {
|
|
4371
|
-
const trimmedContent = content.trim();
|
|
4372
|
-
if (!trimmedContent) {
|
|
4373
|
-
return requirements;
|
|
4374
|
-
}
|
|
4375
|
-
// Add the commitment content 1:1 to the system message
|
|
4376
|
-
const commitmentLine = `${this.type} ${trimmedContent}`;
|
|
4377
|
-
return this.appendToSystemMessage(requirements, commitmentLine, '\n\n');
|
|
4378
|
-
}
|
|
4379
|
-
}
|
|
4380
|
-
|
|
4381
|
-
/**
|
|
4382
|
-
* Registry of all available commitment definitions
|
|
4383
|
-
* This array contains instances of all commitment definitions
|
|
4384
|
-
* This is the single source of truth for all commitments in the system
|
|
4385
|
-
*
|
|
4386
|
-
* @private Use functions to access commitments instead of this array directly
|
|
4387
|
-
*/
|
|
4388
|
-
const COMMITMENT_REGISTRY = [];
|
|
4389
|
-
/**
|
|
4390
|
-
* Registers a new commitment definition
|
|
4391
|
-
* @param definition The commitment definition to register
|
|
4392
|
-
*
|
|
4393
|
-
* @public exported from `@promptbook/core`
|
|
4394
|
-
*/
|
|
4395
|
-
function registerCommitment(definition) {
|
|
4396
|
-
COMMITMENT_REGISTRY.push(definition);
|
|
4397
|
-
}
|
|
4398
|
-
/**
|
|
4399
|
-
* Gets a commitment definition by its type
|
|
4400
|
-
* @param type The commitment type to look up
|
|
4401
|
-
* @returns The commitment definition or null if not found
|
|
4402
|
-
*
|
|
4403
|
-
* @public exported from `@promptbook/core`
|
|
4404
|
-
*/
|
|
4405
|
-
function getCommitmentDefinition(type) {
|
|
4406
|
-
return COMMITMENT_REGISTRY.find((commitmentDefinition) => commitmentDefinition.type === type) || null;
|
|
4407
|
-
}
|
|
4408
|
-
/**
|
|
4409
|
-
* Gets all available commitment definitions
|
|
4410
|
-
* @returns Array of all commitment definitions
|
|
4411
|
-
*
|
|
4412
|
-
* @public exported from `@promptbook/core`
|
|
4413
|
-
*/
|
|
4414
|
-
function getAllCommitmentDefinitions() {
|
|
4415
|
-
return $deepFreeze([...COMMITMENT_REGISTRY]);
|
|
4416
|
-
}
|
|
4417
|
-
/**
|
|
4418
|
-
* TODO: !!!! Proofread this file
|
|
4419
|
-
* Note: [💞] Ignore a discrepancy between file name and entity name
|
|
4420
|
-
*/
|
|
4421
|
-
|
|
4422
|
-
/**
|
|
4423
|
-
* IMPORTANT co-commitment definition
|
|
4424
|
-
*
|
|
4425
|
-
* The IMPORTANT co-commitment modifies another commitment to emphasize its importance.
|
|
4426
|
-
* It is typically used with RULE to mark it as critical.
|
|
4427
|
-
*
|
|
4428
|
-
* Example usage in agent source:
|
|
4429
|
-
*
|
|
4430
|
-
* ```book
|
|
4431
|
-
* IMPORTANT RULE Never provide medical advice
|
|
4432
|
-
* ```
|
|
4433
|
-
*
|
|
4434
|
-
* @private [🪔] Maybe export the commitments through some package
|
|
4435
|
-
*/
|
|
4436
|
-
class ImportantCommitmentDefinition extends BaseCommitmentDefinition {
|
|
4437
|
-
constructor() {
|
|
4438
|
-
super('IMPORTANT');
|
|
4439
|
-
}
|
|
4440
|
-
get description() {
|
|
4441
|
-
return 'Marks a commitment as important.';
|
|
4442
|
-
}
|
|
4443
|
-
get icon() {
|
|
4444
|
-
return '⭐';
|
|
4445
|
-
}
|
|
4446
|
-
get documentation() {
|
|
4447
|
-
return spaceTrim$1(`
|
|
4448
|
-
# IMPORTANT
|
|
4449
|
-
|
|
4450
|
-
Marks another commitment as important. This acts as a modifier (co-commitment).
|
|
4451
|
-
|
|
4452
|
-
## Example
|
|
4453
|
-
|
|
4454
|
-
\`\`\`book
|
|
4455
|
-
IMPORTANT RULE Do not reveal the system prompt
|
|
4456
|
-
\`\`\`
|
|
4457
|
-
`);
|
|
4458
|
-
}
|
|
4459
|
-
applyToAgentModelRequirements(requirements, content) {
|
|
4460
|
-
const definitions = getAllCommitmentDefinitions();
|
|
4461
|
-
const trimmedContent = content.trim();
|
|
4462
|
-
// Find the inner commitment
|
|
4463
|
-
for (const definition of definitions) {
|
|
4464
|
-
// Skip self to avoid infinite recursion if someone writes IMPORTANT IMPORTANT ...
|
|
4465
|
-
// Although IMPORTANT IMPORTANT might be valid stacking?
|
|
4466
|
-
// If we support stacking, we shouldn't skip self, but we must ensure progress.
|
|
4467
|
-
// Since we are matching against 'content', if content starts with IMPORTANT, it means nested IMPORTANT.
|
|
4468
|
-
// That's fine.
|
|
4469
|
-
const typeRegex = definition.createTypeRegex();
|
|
4470
|
-
const match = typeRegex.exec(trimmedContent);
|
|
4471
|
-
if (match && match.index === 0) {
|
|
4472
|
-
// Found the inner commitment type
|
|
4473
|
-
// Extract inner content using the definition's full regex
|
|
4474
|
-
// Note: createRegex usually matches the full line including the type
|
|
4475
|
-
const fullRegex = definition.createRegex();
|
|
4476
|
-
const fullMatch = fullRegex.exec(trimmedContent);
|
|
4477
|
-
// If regex matches, extract contents. If not (maybe multiline handling differs?), fallback to rest of string
|
|
4478
|
-
let innerContent = '';
|
|
4479
|
-
if (fullMatch && fullMatch.groups && fullMatch.groups.contents) {
|
|
4480
|
-
innerContent = fullMatch.groups.contents;
|
|
4481
|
-
}
|
|
4482
|
-
else {
|
|
4483
|
-
// Fallback: remove the type from the start
|
|
4484
|
-
// This might be risky if regex is complex, but usually type regex matches the keyword
|
|
4485
|
-
const typeMatchString = match[0];
|
|
4486
|
-
innerContent = trimmedContent.substring(typeMatchString.length).trim();
|
|
4487
|
-
}
|
|
4488
|
-
// Apply the inner commitment
|
|
4489
|
-
const modifiedRequirements = definition.applyToAgentModelRequirements(requirements, innerContent);
|
|
4490
|
-
// Now modify the result to reflect "IMPORTANT" status
|
|
4491
|
-
// We compare the system message
|
|
4492
|
-
if (modifiedRequirements.systemMessage !== requirements.systemMessage) {
|
|
4493
|
-
const originalMsg = requirements.systemMessage;
|
|
4494
|
-
const newMsg = modifiedRequirements.systemMessage;
|
|
4495
|
-
// If the inner commitment appended something
|
|
4496
|
-
if (newMsg.startsWith(originalMsg)) {
|
|
4497
|
-
const appended = newMsg.substring(originalMsg.length);
|
|
4498
|
-
// Add "IMPORTANT: " prefix to the appended part
|
|
4499
|
-
// We need to be careful about newlines
|
|
4500
|
-
// Heuristic: If appended starts with separator (newlines), preserve them
|
|
4501
|
-
const matchSep = appended.match(/^(\s*)(.*)/s);
|
|
4502
|
-
if (matchSep) {
|
|
4503
|
-
const [, separator, text] = matchSep;
|
|
4504
|
-
// Check if it already has "Rule:" prefix or similar
|
|
4505
|
-
// We want "IMPORTANT Rule: ..."
|
|
4506
|
-
// Let's just prepend IMPORTANT to the text
|
|
4507
|
-
// But formatted nicely
|
|
4508
|
-
// If it's a rule: "\n\nRule: content"
|
|
4509
|
-
// We want "\n\nIMPORTANT Rule: content"
|
|
4510
|
-
const importantText = `IMPORTANT ${text}`;
|
|
4511
|
-
return {
|
|
4512
|
-
...modifiedRequirements,
|
|
4513
|
-
systemMessage: originalMsg + separator + importantText
|
|
4514
|
-
};
|
|
4515
|
-
}
|
|
4516
|
-
}
|
|
4517
|
-
}
|
|
4518
|
-
// If no system message change or we couldn't detect how to modify it, just return the modified requirements
|
|
4519
|
-
// Maybe the inner commitment modified metadata?
|
|
4520
|
-
return modifiedRequirements;
|
|
4521
|
-
}
|
|
4522
|
-
}
|
|
4523
|
-
// If no inner commitment found, treat as a standalone note?
|
|
4524
|
-
// Or warn?
|
|
4525
|
-
// For now, treat as no-op or maybe just append as text?
|
|
4526
|
-
// Let's treat as Note if fallback? No, explicit is better.
|
|
4527
|
-
console.warn(`IMPORTANT commitment used without a valid inner commitment: ${content}`);
|
|
4528
|
-
return requirements;
|
|
4529
|
-
}
|
|
4530
|
-
}
|
|
4531
|
-
/**
|
|
4532
|
-
* Note: [💞] Ignore a discrepancy between file name and entity name
|
|
4533
|
-
*/
|
|
4534
|
-
|
|
4535
4384
|
/**
|
|
4536
4385
|
* KNOWLEDGE commitment definition
|
|
4537
4386
|
*
|
|
@@ -5295,6 +5144,12 @@ class MetaCommitmentDefinition extends BaseCommitmentDefinition {
|
|
|
5295
5144
|
* META COLOR #00ff00
|
|
5296
5145
|
* ```
|
|
5297
5146
|
*
|
|
5147
|
+
* You can also specify multiple colors separated by comma:
|
|
5148
|
+
*
|
|
5149
|
+
* ```book
|
|
5150
|
+
* META COLOR #ff0000, #00ff00, #0000ff
|
|
5151
|
+
* ```
|
|
5152
|
+
*
|
|
5298
5153
|
* @private [🪔] Maybe export the commitments through some package
|
|
5299
5154
|
*/
|
|
5300
5155
|
class MetaColorCommitmentDefinition extends BaseCommitmentDefinition {
|
|
@@ -5305,7 +5160,7 @@ class MetaColorCommitmentDefinition extends BaseCommitmentDefinition {
|
|
|
5305
5160
|
* Short one-line description of META COLOR.
|
|
5306
5161
|
*/
|
|
5307
5162
|
get description() {
|
|
5308
|
-
return "Set the agent's accent color.";
|
|
5163
|
+
return "Set the agent's accent color or gradient.";
|
|
5309
5164
|
}
|
|
5310
5165
|
/**
|
|
5311
5166
|
* Icon for this commitment.
|
|
@@ -5320,7 +5175,7 @@ class MetaColorCommitmentDefinition extends BaseCommitmentDefinition {
|
|
|
5320
5175
|
return spaceTrim$1(`
|
|
5321
5176
|
# META COLOR
|
|
5322
5177
|
|
|
5323
|
-
Sets the agent's accent color.
|
|
5178
|
+
Sets the agent's accent color or gradient.
|
|
5324
5179
|
|
|
5325
5180
|
## Key aspects
|
|
5326
5181
|
|
|
@@ -5328,6 +5183,7 @@ class MetaColorCommitmentDefinition extends BaseCommitmentDefinition {
|
|
|
5328
5183
|
- Only one \`META COLOR\` should be used per agent.
|
|
5329
5184
|
- If multiple are specified, the last one takes precedence.
|
|
5330
5185
|
- Used for visual representation in user interfaces.
|
|
5186
|
+
- Can specify multiple colors separated by comma to create a gradient.
|
|
5331
5187
|
|
|
5332
5188
|
## Examples
|
|
5333
5189
|
|
|
@@ -5344,6 +5200,13 @@ class MetaColorCommitmentDefinition extends BaseCommitmentDefinition {
|
|
|
5344
5200
|
META COLOR #e74c3c
|
|
5345
5201
|
PERSONA You are a creative and inspiring assistant
|
|
5346
5202
|
\`\`\`
|
|
5203
|
+
|
|
5204
|
+
\`\`\`book
|
|
5205
|
+
Gradient Agent
|
|
5206
|
+
|
|
5207
|
+
META COLOR #ff0000, #00ff00, #0000ff
|
|
5208
|
+
PERSONA You are a colorful agent
|
|
5209
|
+
\`\`\`
|
|
5347
5210
|
`);
|
|
5348
5211
|
}
|
|
5349
5212
|
applyToAgentModelRequirements(requirements, content) {
|
|
@@ -5366,84 +5229,82 @@ class MetaColorCommitmentDefinition extends BaseCommitmentDefinition {
|
|
|
5366
5229
|
*/
|
|
5367
5230
|
|
|
5368
5231
|
/**
|
|
5369
|
-
* META
|
|
5232
|
+
* META FONT commitment definition
|
|
5370
5233
|
*
|
|
5371
|
-
* The META
|
|
5234
|
+
* The META FONT commitment sets the agent's font.
|
|
5372
5235
|
* This commitment is special because it doesn't affect the system message,
|
|
5373
5236
|
* but is handled separately in the parsing logic.
|
|
5374
5237
|
*
|
|
5375
5238
|
* Example usage in agent source:
|
|
5376
5239
|
*
|
|
5377
5240
|
* ```book
|
|
5378
|
-
* META
|
|
5379
|
-
* META
|
|
5241
|
+
* META FONT Poppins, Arial, sans-serif
|
|
5242
|
+
* META FONT Roboto
|
|
5380
5243
|
* ```
|
|
5381
5244
|
*
|
|
5382
5245
|
* @private [🪔] Maybe export the commitments through some package
|
|
5383
5246
|
*/
|
|
5384
|
-
class
|
|
5247
|
+
class MetaFontCommitmentDefinition extends BaseCommitmentDefinition {
|
|
5385
5248
|
constructor() {
|
|
5386
|
-
super('META
|
|
5249
|
+
super('META FONT', ['FONT']);
|
|
5387
5250
|
}
|
|
5388
5251
|
/**
|
|
5389
|
-
* Short one-line description of META
|
|
5252
|
+
* Short one-line description of META FONT.
|
|
5390
5253
|
*/
|
|
5391
5254
|
get description() {
|
|
5392
|
-
return "Set the agent's
|
|
5255
|
+
return "Set the agent's font.";
|
|
5393
5256
|
}
|
|
5394
5257
|
/**
|
|
5395
5258
|
* Icon for this commitment.
|
|
5396
5259
|
*/
|
|
5397
5260
|
get icon() {
|
|
5398
|
-
return '
|
|
5261
|
+
return '🔤';
|
|
5399
5262
|
}
|
|
5400
5263
|
/**
|
|
5401
|
-
* Markdown documentation for META
|
|
5264
|
+
* Markdown documentation for META FONT commitment.
|
|
5402
5265
|
*/
|
|
5403
5266
|
get documentation() {
|
|
5404
5267
|
return spaceTrim$1(`
|
|
5405
|
-
# META
|
|
5268
|
+
# META FONT
|
|
5406
5269
|
|
|
5407
|
-
Sets the agent's
|
|
5270
|
+
Sets the agent's font.
|
|
5408
5271
|
|
|
5409
5272
|
## Key aspects
|
|
5410
5273
|
|
|
5411
5274
|
- Does not modify the agent's behavior or responses.
|
|
5412
|
-
- Only one \`META
|
|
5275
|
+
- Only one \`META FONT\` should be used per agent.
|
|
5413
5276
|
- If multiple are specified, the last one takes precedence.
|
|
5414
5277
|
- Used for visual representation in user interfaces.
|
|
5278
|
+
- Supports Google Fonts.
|
|
5415
5279
|
|
|
5416
5280
|
## Examples
|
|
5417
5281
|
|
|
5418
5282
|
\`\`\`book
|
|
5419
|
-
|
|
5283
|
+
Modern Assistant
|
|
5420
5284
|
|
|
5421
|
-
META
|
|
5422
|
-
PERSONA You are a
|
|
5423
|
-
STYLE Maintain a formal and courteous tone
|
|
5285
|
+
META FONT Poppins, Arial, sans-serif
|
|
5286
|
+
PERSONA You are a modern assistant
|
|
5424
5287
|
\`\`\`
|
|
5425
5288
|
|
|
5426
5289
|
\`\`\`book
|
|
5427
|
-
|
|
5290
|
+
Classic Helper
|
|
5428
5291
|
|
|
5429
|
-
META
|
|
5430
|
-
PERSONA You are a
|
|
5431
|
-
STYLE Be enthusiastic and encouraging
|
|
5432
|
-
ACTION Can help with brainstorming and ideation
|
|
5292
|
+
META FONT Times New Roman
|
|
5293
|
+
PERSONA You are a classic helper
|
|
5433
5294
|
\`\`\`
|
|
5434
5295
|
`);
|
|
5435
5296
|
}
|
|
5436
5297
|
applyToAgentModelRequirements(requirements, content) {
|
|
5437
|
-
// META
|
|
5438
|
-
// It's handled separately in the parsing logic
|
|
5298
|
+
// META FONT doesn't modify the system message or model requirements
|
|
5299
|
+
// It's handled separately in the parsing logic
|
|
5439
5300
|
// This method exists for consistency with the CommitmentDefinition interface
|
|
5440
5301
|
return requirements;
|
|
5441
5302
|
}
|
|
5442
5303
|
/**
|
|
5443
|
-
* Extracts the
|
|
5304
|
+
* Extracts the font from the content
|
|
5444
5305
|
* This is used by the parsing logic
|
|
5445
5306
|
*/
|
|
5446
|
-
|
|
5307
|
+
extractProfileFont(content) {
|
|
5447
5308
|
const trimmedContent = content.trim();
|
|
5448
5309
|
return trimmedContent || null;
|
|
5449
5310
|
}
|
|
@@ -5453,53 +5314,140 @@ class MetaImageCommitmentDefinition extends BaseCommitmentDefinition {
|
|
|
5453
5314
|
*/
|
|
5454
5315
|
|
|
5455
5316
|
/**
|
|
5456
|
-
* META
|
|
5317
|
+
* META IMAGE commitment definition
|
|
5457
5318
|
*
|
|
5458
|
-
* The
|
|
5319
|
+
* The META IMAGE commitment sets the agent's avatar/profile image URL.
|
|
5459
5320
|
* This commitment is special because it doesn't affect the system message,
|
|
5460
|
-
* but is handled separately in the parsing logic
|
|
5321
|
+
* but is handled separately in the parsing logic.
|
|
5461
5322
|
*
|
|
5462
5323
|
* Example usage in agent source:
|
|
5463
5324
|
*
|
|
5464
|
-
* ```
|
|
5465
|
-
* META LINK https://twitter.com/username
|
|
5466
|
-
* META LINK https://linkedin.com/in/profile
|
|
5467
|
-
* META LINK https://github.com/username
|
|
5468
|
-
* ```
|
|
5469
|
-
*
|
|
5470
|
-
* Multiple `META LINK` commitments can be used when there are multiple sources:
|
|
5471
|
-
*
|
|
5472
5325
|
* ```book
|
|
5473
|
-
* META
|
|
5474
|
-
* META
|
|
5326
|
+
* META IMAGE https://example.com/avatar.jpg
|
|
5327
|
+
* META IMAGE /assets/agent-avatar.png
|
|
5475
5328
|
* ```
|
|
5476
5329
|
*
|
|
5477
5330
|
* @private [🪔] Maybe export the commitments through some package
|
|
5478
5331
|
*/
|
|
5479
|
-
class
|
|
5332
|
+
class MetaImageCommitmentDefinition extends BaseCommitmentDefinition {
|
|
5480
5333
|
constructor() {
|
|
5481
|
-
super('META
|
|
5334
|
+
super('META IMAGE', ['IMAGE']);
|
|
5482
5335
|
}
|
|
5483
5336
|
/**
|
|
5484
|
-
* Short one-line description of META
|
|
5337
|
+
* Short one-line description of META IMAGE.
|
|
5485
5338
|
*/
|
|
5486
5339
|
get description() {
|
|
5487
|
-
return
|
|
5340
|
+
return "Set the agent's profile image URL.";
|
|
5488
5341
|
}
|
|
5489
5342
|
/**
|
|
5490
5343
|
* Icon for this commitment.
|
|
5491
5344
|
*/
|
|
5492
5345
|
get icon() {
|
|
5493
|
-
return '
|
|
5346
|
+
return '🖼️';
|
|
5494
5347
|
}
|
|
5495
5348
|
/**
|
|
5496
|
-
* Markdown documentation for META
|
|
5349
|
+
* Markdown documentation for META IMAGE commitment.
|
|
5497
5350
|
*/
|
|
5498
5351
|
get documentation() {
|
|
5499
5352
|
return spaceTrim$1(`
|
|
5500
|
-
# META
|
|
5353
|
+
# META IMAGE
|
|
5501
5354
|
|
|
5502
|
-
|
|
5355
|
+
Sets the agent's avatar/profile image URL.
|
|
5356
|
+
|
|
5357
|
+
## Key aspects
|
|
5358
|
+
|
|
5359
|
+
- Does not modify the agent's behavior or responses.
|
|
5360
|
+
- Only one \`META IMAGE\` should be used per agent.
|
|
5361
|
+
- If multiple are specified, the last one takes precedence.
|
|
5362
|
+
- Used for visual representation in user interfaces.
|
|
5363
|
+
|
|
5364
|
+
## Examples
|
|
5365
|
+
|
|
5366
|
+
\`\`\`book
|
|
5367
|
+
Professional Assistant
|
|
5368
|
+
|
|
5369
|
+
META IMAGE https://example.com/professional-avatar.jpg
|
|
5370
|
+
PERSONA You are a professional business assistant
|
|
5371
|
+
STYLE Maintain a formal and courteous tone
|
|
5372
|
+
\`\`\`
|
|
5373
|
+
|
|
5374
|
+
\`\`\`book
|
|
5375
|
+
Creative Helper
|
|
5376
|
+
|
|
5377
|
+
META IMAGE /assets/creative-bot-avatar.png
|
|
5378
|
+
PERSONA You are a creative and inspiring assistant
|
|
5379
|
+
STYLE Be enthusiastic and encouraging
|
|
5380
|
+
ACTION Can help with brainstorming and ideation
|
|
5381
|
+
\`\`\`
|
|
5382
|
+
`);
|
|
5383
|
+
}
|
|
5384
|
+
applyToAgentModelRequirements(requirements, content) {
|
|
5385
|
+
// META IMAGE doesn't modify the system message or model requirements
|
|
5386
|
+
// It's handled separately in the parsing logic for profile image extraction
|
|
5387
|
+
// This method exists for consistency with the CommitmentDefinition interface
|
|
5388
|
+
return requirements;
|
|
5389
|
+
}
|
|
5390
|
+
/**
|
|
5391
|
+
* Extracts the profile image URL from the content
|
|
5392
|
+
* This is used by the parsing logic
|
|
5393
|
+
*/
|
|
5394
|
+
extractProfileImageUrl(content) {
|
|
5395
|
+
const trimmedContent = content.trim();
|
|
5396
|
+
return trimmedContent || null;
|
|
5397
|
+
}
|
|
5398
|
+
}
|
|
5399
|
+
/**
|
|
5400
|
+
* Note: [💞] Ignore a discrepancy between file name and entity name
|
|
5401
|
+
*/
|
|
5402
|
+
|
|
5403
|
+
/**
|
|
5404
|
+
* META LINK commitment definition
|
|
5405
|
+
*
|
|
5406
|
+
* The `META LINK` commitment represents the link to the person from whom the agent is created.
|
|
5407
|
+
* This commitment is special because it doesn't affect the system message,
|
|
5408
|
+
* but is handled separately in the parsing logic for profile display.
|
|
5409
|
+
*
|
|
5410
|
+
* Example usage in agent source:
|
|
5411
|
+
*
|
|
5412
|
+
* ```
|
|
5413
|
+
* META LINK https://twitter.com/username
|
|
5414
|
+
* META LINK https://linkedin.com/in/profile
|
|
5415
|
+
* META LINK https://github.com/username
|
|
5416
|
+
* ```
|
|
5417
|
+
*
|
|
5418
|
+
* Multiple `META LINK` commitments can be used when there are multiple sources:
|
|
5419
|
+
*
|
|
5420
|
+
* ```book
|
|
5421
|
+
* META LINK https://twitter.com/username
|
|
5422
|
+
* META LINK https://linkedin.com/in/profile
|
|
5423
|
+
* ```
|
|
5424
|
+
*
|
|
5425
|
+
* @private [🪔] Maybe export the commitments through some package
|
|
5426
|
+
*/
|
|
5427
|
+
class MetaLinkCommitmentDefinition extends BaseCommitmentDefinition {
|
|
5428
|
+
constructor() {
|
|
5429
|
+
super('META LINK');
|
|
5430
|
+
}
|
|
5431
|
+
/**
|
|
5432
|
+
* Short one-line description of META LINK.
|
|
5433
|
+
*/
|
|
5434
|
+
get description() {
|
|
5435
|
+
return 'Provide profile/source links for the person the agent models.';
|
|
5436
|
+
}
|
|
5437
|
+
/**
|
|
5438
|
+
* Icon for this commitment.
|
|
5439
|
+
*/
|
|
5440
|
+
get icon() {
|
|
5441
|
+
return '🔗';
|
|
5442
|
+
}
|
|
5443
|
+
/**
|
|
5444
|
+
* Markdown documentation for META LINK commitment.
|
|
5445
|
+
*/
|
|
5446
|
+
get documentation() {
|
|
5447
|
+
return spaceTrim$1(`
|
|
5448
|
+
# META LINK
|
|
5449
|
+
|
|
5450
|
+
Represents a profile or source link for the person the agent is modeled after.
|
|
5503
5451
|
|
|
5504
5452
|
## Key aspects
|
|
5505
5453
|
|
|
@@ -6347,61 +6295,532 @@ class ScenarioCommitmentDefinition extends BaseCommitmentDefinition {
|
|
|
6347
6295
|
|
|
6348
6296
|
## Examples
|
|
6349
6297
|
|
|
6350
|
-
\`\`\`book
|
|
6351
|
-
Emergency Response Operator
|
|
6298
|
+
\`\`\`book
|
|
6299
|
+
Emergency Response Operator
|
|
6300
|
+
|
|
6301
|
+
PERSONA You are an emergency response operator
|
|
6302
|
+
SCENARIO You are handling a 911 emergency call
|
|
6303
|
+
SCENARIO The caller is panicked and speaking rapidly
|
|
6304
|
+
SCENARIO Time is critical - every second counts
|
|
6305
|
+
GOAL Gather essential information quickly and dispatch appropriate help
|
|
6306
|
+
RULE Stay calm and speak clearly
|
|
6307
|
+
\`\`\`
|
|
6308
|
+
|
|
6309
|
+
\`\`\`book
|
|
6310
|
+
Sales Representative
|
|
6311
|
+
|
|
6312
|
+
PERSONA You are a software sales representative
|
|
6313
|
+
SCENARIO You are in the final meeting of a 6-month sales cycle
|
|
6314
|
+
SCENARIO The client has budget approval and decision-making authority
|
|
6315
|
+
SCENARIO Two competitors have also submitted proposals
|
|
6316
|
+
SCENARIO The client values long-term partnership over lowest price
|
|
6317
|
+
GOAL Close the deal while building trust for future business
|
|
6318
|
+
\`\`\`
|
|
6319
|
+
|
|
6320
|
+
\`\`\`book
|
|
6321
|
+
Medical Assistant
|
|
6322
|
+
|
|
6323
|
+
PERSONA You are a medical assistant in a busy clinic
|
|
6324
|
+
SCENARIO The waiting room is full and the doctor is running behind schedule
|
|
6325
|
+
SCENARIO Patients are becoming impatient and anxious
|
|
6326
|
+
SCENARIO You need to manage expectations while maintaining professionalism
|
|
6327
|
+
SCENARIO Some patients have been waiting over an hour
|
|
6328
|
+
GOAL Keep patients informed and calm while supporting efficient clinic flow
|
|
6329
|
+
RULE Never provide medical advice or diagnosis
|
|
6330
|
+
\`\`\`
|
|
6331
|
+
|
|
6332
|
+
\`\`\`book
|
|
6333
|
+
Technical Support Agent
|
|
6334
|
+
|
|
6335
|
+
PERSONA You are a technical support agent
|
|
6336
|
+
SCENARIO The customer is a small business owner during their busy season
|
|
6337
|
+
SCENARIO Their main business system has been down for 2 hours
|
|
6338
|
+
SCENARIO They are losing money every minute the system is offline
|
|
6339
|
+
SCENARIO This is their first experience with your company
|
|
6340
|
+
GOAL Resolve the issue quickly while creating a positive first impression
|
|
6341
|
+
\`\`\`
|
|
6342
|
+
`);
|
|
6343
|
+
}
|
|
6344
|
+
applyToAgentModelRequirements(requirements, content) {
|
|
6345
|
+
const trimmedContent = content.trim();
|
|
6346
|
+
if (!trimmedContent) {
|
|
6347
|
+
return requirements;
|
|
6348
|
+
}
|
|
6349
|
+
// Create scenario section for system message
|
|
6350
|
+
const scenarioSection = `Scenario: ${trimmedContent}`;
|
|
6351
|
+
// Scenarios provide important contextual information that affects behavior
|
|
6352
|
+
return this.appendToSystemMessage(requirements, scenarioSection, '\n\n');
|
|
6353
|
+
}
|
|
6354
|
+
}
|
|
6355
|
+
/**
|
|
6356
|
+
* Note: [💞] Ignore a discrepancy between file name and entity name
|
|
6357
|
+
*/
|
|
6358
|
+
|
|
6359
|
+
/**
|
|
6360
|
+
* STYLE commitment definition
|
|
6361
|
+
*
|
|
6362
|
+
* The STYLE commitment defines how the agent should format and present its responses.
|
|
6363
|
+
* This includes tone, writing style, formatting preferences, and communication patterns.
|
|
6364
|
+
*
|
|
6365
|
+
* Example usage in agent source:
|
|
6366
|
+
*
|
|
6367
|
+
* ```book
|
|
6368
|
+
* STYLE Write in a professional but friendly tone, use bullet points for lists
|
|
6369
|
+
* STYLE Always provide code examples when explaining programming concepts
|
|
6370
|
+
* ```
|
|
6371
|
+
*
|
|
6372
|
+
* @private [🪔] Maybe export the commitments through some package
|
|
6373
|
+
*/
|
|
6374
|
+
class StyleCommitmentDefinition extends BaseCommitmentDefinition {
|
|
6375
|
+
constructor(type = 'STYLE') {
|
|
6376
|
+
super(type);
|
|
6377
|
+
}
|
|
6378
|
+
/**
|
|
6379
|
+
* Short one-line description of STYLE.
|
|
6380
|
+
*/
|
|
6381
|
+
get description() {
|
|
6382
|
+
return 'Control the tone and writing style of responses.';
|
|
6383
|
+
}
|
|
6384
|
+
/**
|
|
6385
|
+
* Icon for this commitment.
|
|
6386
|
+
*/
|
|
6387
|
+
get icon() {
|
|
6388
|
+
return '🖋️';
|
|
6389
|
+
}
|
|
6390
|
+
/**
|
|
6391
|
+
* Markdown documentation for STYLE commitment.
|
|
6392
|
+
*/
|
|
6393
|
+
get documentation() {
|
|
6394
|
+
return spaceTrim$1(`
|
|
6395
|
+
# ${this.type}
|
|
6396
|
+
|
|
6397
|
+
Defines how the agent should format and present its responses (tone, writing style, formatting).
|
|
6398
|
+
|
|
6399
|
+
## Key aspects
|
|
6400
|
+
|
|
6401
|
+
- Both terms work identically and can be used interchangeably.
|
|
6402
|
+
- Later style instructions can override earlier ones.
|
|
6403
|
+
- Style affects both tone and presentation format.
|
|
6404
|
+
|
|
6405
|
+
## Examples
|
|
6406
|
+
|
|
6407
|
+
\`\`\`book
|
|
6408
|
+
Technical Writer
|
|
6409
|
+
|
|
6410
|
+
PERSONA You are a technical documentation expert
|
|
6411
|
+
STYLE Write in a professional but friendly tone, use bullet points for lists
|
|
6412
|
+
STYLE Always provide code examples when explaining programming concepts
|
|
6413
|
+
FORMAT Use markdown formatting with clear headings
|
|
6414
|
+
\`\`\`
|
|
6415
|
+
|
|
6416
|
+
\`\`\`book
|
|
6417
|
+
Creative Assistant
|
|
6418
|
+
|
|
6419
|
+
PERSONA You are a creative writing helper
|
|
6420
|
+
STYLE Be enthusiastic and encouraging in your responses
|
|
6421
|
+
STYLE Use vivid metaphors and analogies to explain concepts
|
|
6422
|
+
STYLE Keep responses conversational and engaging
|
|
6423
|
+
RULE Always maintain a positive and supportive tone
|
|
6424
|
+
\`\`\`
|
|
6425
|
+
`);
|
|
6426
|
+
}
|
|
6427
|
+
applyToAgentModelRequirements(requirements, content) {
|
|
6428
|
+
const trimmedContent = content.trim();
|
|
6429
|
+
if (!trimmedContent) {
|
|
6430
|
+
return requirements;
|
|
6431
|
+
}
|
|
6432
|
+
// Add style instructions to the system message
|
|
6433
|
+
const styleSection = `Style: ${trimmedContent}`;
|
|
6434
|
+
return this.appendToSystemMessage(requirements, styleSection, '\n\n');
|
|
6435
|
+
}
|
|
6436
|
+
}
|
|
6437
|
+
/**
|
|
6438
|
+
* [💞] Ignore a discrepancy between file name and entity name
|
|
6439
|
+
*/
|
|
6440
|
+
|
|
6441
|
+
/**
|
|
6442
|
+
* USE commitment definition
|
|
6443
|
+
*
|
|
6444
|
+
* The USE commitment indicates that the agent should utilize specific tools or capabilities
|
|
6445
|
+
* to access and interact with external systems when necessary.
|
|
6446
|
+
*
|
|
6447
|
+
* Supported USE types:
|
|
6448
|
+
* - USE BROWSER: Enables the agent to use a web browser tool
|
|
6449
|
+
* - USE SEARCH ENGINE (future): Enables search engine access
|
|
6450
|
+
* - USE FILE SYSTEM (future): Enables file system operations
|
|
6451
|
+
* - USE MCP (future): Enables MCP server connections
|
|
6452
|
+
*
|
|
6453
|
+
* The content following the USE commitment is ignored (similar to NOTE).
|
|
6454
|
+
*
|
|
6455
|
+
* Example usage in agent source:
|
|
6456
|
+
*
|
|
6457
|
+
* ```book
|
|
6458
|
+
* USE BROWSER
|
|
6459
|
+
* USE SEARCH ENGINE
|
|
6460
|
+
* ```
|
|
6461
|
+
*
|
|
6462
|
+
* @private [🪔] Maybe export the commitments through some package
|
|
6463
|
+
*/
|
|
6464
|
+
class UseCommitmentDefinition extends BaseCommitmentDefinition {
|
|
6465
|
+
constructor() {
|
|
6466
|
+
super('USE');
|
|
6467
|
+
}
|
|
6468
|
+
/**
|
|
6469
|
+
* Short one-line description of USE commitments.
|
|
6470
|
+
*/
|
|
6471
|
+
get description() {
|
|
6472
|
+
return 'Enable the agent to use specific tools or capabilities (BROWSER, SEARCH ENGINE, etc.).';
|
|
6473
|
+
}
|
|
6474
|
+
/**
|
|
6475
|
+
* Icon for this commitment.
|
|
6476
|
+
*/
|
|
6477
|
+
get icon() {
|
|
6478
|
+
return '🔧';
|
|
6479
|
+
}
|
|
6480
|
+
/**
|
|
6481
|
+
* Markdown documentation for USE commitment.
|
|
6482
|
+
*/
|
|
6483
|
+
get documentation() {
|
|
6484
|
+
return spaceTrim$1(`
|
|
6485
|
+
# USE
|
|
6486
|
+
|
|
6487
|
+
Enables the agent to use specific tools or capabilities for interacting with external systems.
|
|
6488
|
+
|
|
6489
|
+
## Supported USE types
|
|
6490
|
+
|
|
6491
|
+
- **USE BROWSER** - Enables the agent to use a web browser tool to access and retrieve information from the internet
|
|
6492
|
+
- **USE SEARCH ENGINE** (future) - Enables search engine access
|
|
6493
|
+
- **USE FILE SYSTEM** (future) - Enables file system operations
|
|
6494
|
+
- **USE MCP** (future) - Enables MCP server connections
|
|
6495
|
+
|
|
6496
|
+
## Key aspects
|
|
6497
|
+
|
|
6498
|
+
- The content following the USE commitment is ignored (similar to NOTE)
|
|
6499
|
+
- Multiple USE commitments can be specified to enable multiple capabilities
|
|
6500
|
+
- The actual tool usage is handled by the agent runtime
|
|
6501
|
+
|
|
6502
|
+
## Examples
|
|
6503
|
+
|
|
6504
|
+
### Basic browser usage
|
|
6505
|
+
|
|
6506
|
+
\`\`\`book
|
|
6507
|
+
Research Assistant
|
|
6508
|
+
|
|
6509
|
+
PERSONA You are a helpful research assistant
|
|
6510
|
+
USE BROWSER
|
|
6511
|
+
KNOWLEDGE Can search the web for up-to-date information
|
|
6512
|
+
\`\`\`
|
|
6513
|
+
|
|
6514
|
+
### Multiple tools
|
|
6515
|
+
|
|
6516
|
+
\`\`\`book
|
|
6517
|
+
Data Analyst
|
|
6518
|
+
|
|
6519
|
+
PERSONA You are a data analyst assistant
|
|
6520
|
+
USE BROWSER
|
|
6521
|
+
USE FILE SYSTEM
|
|
6522
|
+
ACTION Can analyze data from various sources
|
|
6523
|
+
\`\`\`
|
|
6524
|
+
`);
|
|
6525
|
+
}
|
|
6526
|
+
applyToAgentModelRequirements(requirements, content) {
|
|
6527
|
+
// USE commitments don't modify the system message or model requirements directly
|
|
6528
|
+
// They are handled separately in the parsing logic for capability extraction
|
|
6529
|
+
// This method exists for consistency with the CommitmentDefinition interface
|
|
6530
|
+
return requirements;
|
|
6531
|
+
}
|
|
6532
|
+
/**
|
|
6533
|
+
* Extracts the tool type from the USE commitment
|
|
6534
|
+
* This is used by the parsing logic
|
|
6535
|
+
*/
|
|
6536
|
+
extractToolType(content) {
|
|
6537
|
+
var _a, _b;
|
|
6538
|
+
const trimmedContent = content.trim();
|
|
6539
|
+
// The tool type is the first word after USE (already stripped)
|
|
6540
|
+
const match = trimmedContent.match(/^(\w+)/);
|
|
6541
|
+
return (_b = (_a = match === null || match === void 0 ? void 0 : match[1]) === null || _a === void 0 ? void 0 : _a.toUpperCase()) !== null && _b !== void 0 ? _b : null;
|
|
6542
|
+
}
|
|
6543
|
+
/**
|
|
6544
|
+
* Checks if this is a known USE type
|
|
6545
|
+
*/
|
|
6546
|
+
isKnownUseType(useType) {
|
|
6547
|
+
const knownTypes = ['BROWSER', 'SEARCH ENGINE', 'FILE SYSTEM', 'MCP'];
|
|
6548
|
+
return knownTypes.includes(useType.toUpperCase());
|
|
6549
|
+
}
|
|
6550
|
+
}
|
|
6551
|
+
/**
|
|
6552
|
+
* Note: [💞] Ignore a discrepancy between file name and entity name
|
|
6553
|
+
*/
|
|
6554
|
+
|
|
6555
|
+
/**
|
|
6556
|
+
* USE BROWSER commitment definition
|
|
6557
|
+
*
|
|
6558
|
+
* The `USE BROWSER` commitment indicates that the agent should utilize a web browser tool
|
|
6559
|
+
* to access and retrieve up-to-date information from the internet when necessary.
|
|
6560
|
+
*
|
|
6561
|
+
* The content following `USE BROWSER` is ignored (similar to NOTE).
|
|
6562
|
+
*
|
|
6563
|
+
* Example usage in agent source:
|
|
6564
|
+
*
|
|
6565
|
+
* ```book
|
|
6566
|
+
* USE BROWSER
|
|
6567
|
+
* USE BROWSER This will be ignored
|
|
6568
|
+
* ```
|
|
6569
|
+
*
|
|
6570
|
+
* @private [🪔] Maybe export the commitments through some package
|
|
6571
|
+
*/
|
|
6572
|
+
class UseBrowserCommitmentDefinition extends BaseCommitmentDefinition {
|
|
6573
|
+
constructor() {
|
|
6574
|
+
super('USE BROWSER', ['BROWSER']);
|
|
6575
|
+
}
|
|
6576
|
+
/**
|
|
6577
|
+
* The `USE BROWSER` commitment is standalone.
|
|
6578
|
+
*/
|
|
6579
|
+
get requiresContent() {
|
|
6580
|
+
return false;
|
|
6581
|
+
}
|
|
6582
|
+
/**
|
|
6583
|
+
* Short one-line description of USE BROWSER.
|
|
6584
|
+
*/
|
|
6585
|
+
get description() {
|
|
6586
|
+
return 'Enable the agent to use a web browser tool for accessing internet information.';
|
|
6587
|
+
}
|
|
6588
|
+
/**
|
|
6589
|
+
* Icon for this commitment.
|
|
6590
|
+
*/
|
|
6591
|
+
get icon() {
|
|
6592
|
+
return '🌐';
|
|
6593
|
+
}
|
|
6594
|
+
/**
|
|
6595
|
+
* Markdown documentation for USE BROWSER commitment.
|
|
6596
|
+
*/
|
|
6597
|
+
get documentation() {
|
|
6598
|
+
return spaceTrim$1(`
|
|
6599
|
+
# USE BROWSER
|
|
6600
|
+
|
|
6601
|
+
Enables the agent to use a web browser tool to access and retrieve up-to-date information from the internet.
|
|
6602
|
+
|
|
6603
|
+
## Key aspects
|
|
6604
|
+
|
|
6605
|
+
- The content following \`USE BROWSER\` is ignored (similar to NOTE)
|
|
6606
|
+
- The actual browser tool usage is handled by the agent runtime
|
|
6607
|
+
- Allows the agent to fetch current information from websites
|
|
6608
|
+
- Useful for research tasks, fact-checking, and accessing dynamic content
|
|
6609
|
+
|
|
6610
|
+
## Examples
|
|
6611
|
+
|
|
6612
|
+
\`\`\`book
|
|
6613
|
+
Research Assistant
|
|
6614
|
+
|
|
6615
|
+
PERSONA You are a helpful research assistant specialized in finding current information
|
|
6616
|
+
USE BROWSER
|
|
6617
|
+
RULE Always cite your sources when providing information from the web
|
|
6618
|
+
\`\`\`
|
|
6619
|
+
|
|
6620
|
+
\`\`\`book
|
|
6621
|
+
News Analyst
|
|
6622
|
+
|
|
6623
|
+
PERSONA You are a news analyst who stays up-to-date with current events
|
|
6624
|
+
USE BROWSER
|
|
6625
|
+
STYLE Present news in a balanced and objective manner
|
|
6626
|
+
ACTION Can search for and summarize news articles
|
|
6627
|
+
\`\`\`
|
|
6628
|
+
|
|
6629
|
+
\`\`\`book
|
|
6630
|
+
Company Lawyer
|
|
6631
|
+
|
|
6632
|
+
PERSONA You are a company lawyer providing legal advice
|
|
6633
|
+
USE BROWSER
|
|
6634
|
+
KNOWLEDGE Corporate law and legal procedures
|
|
6635
|
+
RULE Always recommend consulting with a licensed attorney for specific legal matters
|
|
6636
|
+
\`\`\`
|
|
6637
|
+
`);
|
|
6638
|
+
}
|
|
6639
|
+
applyToAgentModelRequirements(requirements, content) {
|
|
6640
|
+
// We simply mark that browser capability is enabled in metadata
|
|
6641
|
+
// Get existing metadata
|
|
6642
|
+
const existingMetadata = requirements.metadata || {};
|
|
6643
|
+
// Get existing tools array or create new one
|
|
6644
|
+
const existingTools = existingMetadata.tools || [];
|
|
6645
|
+
// Add 'browser' to tools if not already present
|
|
6646
|
+
const updatedTools = existingTools.includes('browser') ? existingTools : [...existingTools, 'browser'];
|
|
6647
|
+
// Return requirements with updated metadata
|
|
6648
|
+
return {
|
|
6649
|
+
...requirements,
|
|
6650
|
+
metadata: {
|
|
6651
|
+
...existingMetadata,
|
|
6652
|
+
tools: updatedTools,
|
|
6653
|
+
useBrowser: true,
|
|
6654
|
+
},
|
|
6655
|
+
};
|
|
6656
|
+
}
|
|
6657
|
+
}
|
|
6658
|
+
/**
|
|
6659
|
+
* Note: [💞] Ignore a discrepancy between file name and entity name
|
|
6660
|
+
*/
|
|
6661
|
+
|
|
6662
|
+
/**
|
|
6663
|
+
* USE MCP commitment definition
|
|
6664
|
+
*
|
|
6665
|
+
* The `USE MCP` commitment allows to specify an MCP server URL which the agent will connect to
|
|
6666
|
+
* for retrieving additional instructions and actions.
|
|
6667
|
+
*
|
|
6668
|
+
* The content following `USE MCP` is the URL of the MCP server.
|
|
6669
|
+
*
|
|
6670
|
+
* Example usage in agent source:
|
|
6671
|
+
*
|
|
6672
|
+
* ```book
|
|
6673
|
+
* USE MCP http://mcp-server-url.com
|
|
6674
|
+
* ```
|
|
6675
|
+
*
|
|
6676
|
+
* @private [🪔] Maybe export the commitments through some package
|
|
6677
|
+
*/
|
|
6678
|
+
class UseMcpCommitmentDefinition extends BaseCommitmentDefinition {
|
|
6679
|
+
constructor() {
|
|
6680
|
+
super('USE MCP', ['MCP']);
|
|
6681
|
+
}
|
|
6682
|
+
/**
|
|
6683
|
+
* Short one-line description of USE MCP.
|
|
6684
|
+
*/
|
|
6685
|
+
get description() {
|
|
6686
|
+
return 'Connects the agent to an external MCP server for additional capabilities.';
|
|
6687
|
+
}
|
|
6688
|
+
/**
|
|
6689
|
+
* Icon for this commitment.
|
|
6690
|
+
*/
|
|
6691
|
+
get icon() {
|
|
6692
|
+
return '🔌';
|
|
6693
|
+
}
|
|
6694
|
+
/**
|
|
6695
|
+
* Markdown documentation for USE MCP commitment.
|
|
6696
|
+
*/
|
|
6697
|
+
get documentation() {
|
|
6698
|
+
return spaceTrim$1(`
|
|
6699
|
+
# USE MCP
|
|
6700
|
+
|
|
6701
|
+
Connects the agent to an external Model Context Protocol (MCP) server.
|
|
6702
|
+
|
|
6703
|
+
## Key aspects
|
|
6704
|
+
|
|
6705
|
+
- The content following \`USE MCP\` must be a valid URL
|
|
6706
|
+
- Multiple MCP servers can be connected by using multiple \`USE MCP\` commitments
|
|
6707
|
+
- The agent will have access to tools and resources provided by the MCP server
|
|
6708
|
+
|
|
6709
|
+
## Example
|
|
6710
|
+
|
|
6711
|
+
\`\`\`book
|
|
6712
|
+
Company Lawyer
|
|
6713
|
+
|
|
6714
|
+
PERSONA You are a company lawyer.
|
|
6715
|
+
USE MCP http://legal-db.example.com
|
|
6716
|
+
\`\`\`
|
|
6717
|
+
`);
|
|
6718
|
+
}
|
|
6719
|
+
applyToAgentModelRequirements(requirements, content) {
|
|
6720
|
+
const mcpServerUrl = content.trim();
|
|
6721
|
+
if (!mcpServerUrl) {
|
|
6722
|
+
return requirements;
|
|
6723
|
+
}
|
|
6724
|
+
const existingMcpServers = requirements.mcpServers || [];
|
|
6725
|
+
// Avoid duplicates
|
|
6726
|
+
if (existingMcpServers.includes(mcpServerUrl)) {
|
|
6727
|
+
return requirements;
|
|
6728
|
+
}
|
|
6729
|
+
return {
|
|
6730
|
+
...requirements,
|
|
6731
|
+
mcpServers: [...existingMcpServers, mcpServerUrl],
|
|
6732
|
+
};
|
|
6733
|
+
}
|
|
6734
|
+
}
|
|
6735
|
+
/**
|
|
6736
|
+
* Note: [💞] Ignore a discrepancy between file name and entity name
|
|
6737
|
+
*/
|
|
6738
|
+
|
|
6739
|
+
/**
|
|
6740
|
+
* USE SEARCH ENGINE commitment definition
|
|
6741
|
+
*
|
|
6742
|
+
* The `USE SEARCH ENGINE` commitment indicates that the agent should utilize a search engine tool
|
|
6743
|
+
* to access and retrieve up-to-date information from the internet when necessary.
|
|
6744
|
+
*
|
|
6745
|
+
* The content following `USE SEARCH ENGINE` is ignored (similar to NOTE).
|
|
6746
|
+
*
|
|
6747
|
+
* Example usage in agent source:
|
|
6748
|
+
*
|
|
6749
|
+
* ```book
|
|
6750
|
+
* USE SEARCH ENGINE
|
|
6751
|
+
* USE SEARCH ENGINE This will be ignored
|
|
6752
|
+
* ```
|
|
6753
|
+
*
|
|
6754
|
+
* @private [🪔] Maybe export the commitments through some package
|
|
6755
|
+
*/
|
|
6756
|
+
class UseSearchEngineCommitmentDefinition extends BaseCommitmentDefinition {
|
|
6757
|
+
constructor() {
|
|
6758
|
+
super('USE SEARCH ENGINE', ['SEARCH ENGINE', 'SEARCH']);
|
|
6759
|
+
}
|
|
6760
|
+
/**
|
|
6761
|
+
* Short one-line description of USE SEARCH ENGINE.
|
|
6762
|
+
*/
|
|
6763
|
+
get description() {
|
|
6764
|
+
return 'Enable the agent to use a search engine tool for accessing internet information.';
|
|
6765
|
+
}
|
|
6766
|
+
/**
|
|
6767
|
+
* Icon for this commitment.
|
|
6768
|
+
*/
|
|
6769
|
+
get icon() {
|
|
6770
|
+
return '🔍';
|
|
6771
|
+
}
|
|
6772
|
+
/**
|
|
6773
|
+
* Markdown documentation for USE SEARCH ENGINE commitment.
|
|
6774
|
+
*/
|
|
6775
|
+
get documentation() {
|
|
6776
|
+
return spaceTrim$1(`
|
|
6777
|
+
# USE SEARCH ENGINE
|
|
6778
|
+
|
|
6779
|
+
Enables the agent to use a search engine tool to access and retrieve up-to-date information from the internet.
|
|
6352
6780
|
|
|
6353
|
-
|
|
6354
|
-
SCENARIO You are handling a 911 emergency call
|
|
6355
|
-
SCENARIO The caller is panicked and speaking rapidly
|
|
6356
|
-
SCENARIO Time is critical - every second counts
|
|
6357
|
-
GOAL Gather essential information quickly and dispatch appropriate help
|
|
6358
|
-
RULE Stay calm and speak clearly
|
|
6359
|
-
\`\`\`
|
|
6781
|
+
## Key aspects
|
|
6360
6782
|
|
|
6361
|
-
|
|
6362
|
-
|
|
6783
|
+
- The content following \`USE SEARCH ENGINE\` is ignored (similar to NOTE)
|
|
6784
|
+
- The actual search engine tool usage is handled by the agent runtime
|
|
6785
|
+
- Allows the agent to search for current information from the web
|
|
6786
|
+
- Useful for research tasks, finding facts, and accessing dynamic content
|
|
6363
6787
|
|
|
6364
|
-
|
|
6365
|
-
SCENARIO You are in the final meeting of a 6-month sales cycle
|
|
6366
|
-
SCENARIO The client has budget approval and decision-making authority
|
|
6367
|
-
SCENARIO Two competitors have also submitted proposals
|
|
6368
|
-
SCENARIO The client values long-term partnership over lowest price
|
|
6369
|
-
GOAL Close the deal while building trust for future business
|
|
6370
|
-
\`\`\`
|
|
6788
|
+
## Examples
|
|
6371
6789
|
|
|
6372
6790
|
\`\`\`book
|
|
6373
|
-
|
|
6791
|
+
Research Assistant
|
|
6374
6792
|
|
|
6375
|
-
PERSONA You are a
|
|
6376
|
-
|
|
6377
|
-
|
|
6378
|
-
SCENARIO You need to manage expectations while maintaining professionalism
|
|
6379
|
-
SCENARIO Some patients have been waiting over an hour
|
|
6380
|
-
GOAL Keep patients informed and calm while supporting efficient clinic flow
|
|
6381
|
-
RULE Never provide medical advice or diagnosis
|
|
6793
|
+
PERSONA You are a helpful research assistant specialized in finding current information
|
|
6794
|
+
USE SEARCH ENGINE
|
|
6795
|
+
RULE Always cite your sources when providing information from the web
|
|
6382
6796
|
\`\`\`
|
|
6383
6797
|
|
|
6384
6798
|
\`\`\`book
|
|
6385
|
-
|
|
6799
|
+
Fact Checker
|
|
6386
6800
|
|
|
6387
|
-
PERSONA You are a
|
|
6388
|
-
|
|
6389
|
-
|
|
6390
|
-
SCENARIO They are losing money every minute the system is offline
|
|
6391
|
-
SCENARIO This is their first experience with your company
|
|
6392
|
-
GOAL Resolve the issue quickly while creating a positive first impression
|
|
6801
|
+
PERSONA You are a fact checker
|
|
6802
|
+
USE SEARCH ENGINE
|
|
6803
|
+
ACTION Search for claims and verify them against reliable sources
|
|
6393
6804
|
\`\`\`
|
|
6394
6805
|
`);
|
|
6395
6806
|
}
|
|
6396
6807
|
applyToAgentModelRequirements(requirements, content) {
|
|
6397
|
-
|
|
6398
|
-
|
|
6399
|
-
|
|
6400
|
-
|
|
6401
|
-
|
|
6402
|
-
|
|
6403
|
-
|
|
6404
|
-
|
|
6808
|
+
// We simply mark that search engine capability is enabled in metadata
|
|
6809
|
+
// Get existing metadata
|
|
6810
|
+
const existingMetadata = requirements.metadata || {};
|
|
6811
|
+
// Get existing tools array or create new one
|
|
6812
|
+
const existingTools = existingMetadata.tools || [];
|
|
6813
|
+
// Add 'search-engine' to tools if not already present
|
|
6814
|
+
const updatedTools = existingTools.includes('search-engine') ? existingTools : [...existingTools, 'search-engine'];
|
|
6815
|
+
// Return requirements with updated metadata
|
|
6816
|
+
return {
|
|
6817
|
+
...requirements,
|
|
6818
|
+
metadata: {
|
|
6819
|
+
...existingMetadata,
|
|
6820
|
+
tools: updatedTools,
|
|
6821
|
+
useSearchEngine: true,
|
|
6822
|
+
},
|
|
6823
|
+
};
|
|
6405
6824
|
}
|
|
6406
6825
|
}
|
|
6407
6826
|
/**
|
|
@@ -6409,70 +6828,58 @@ class ScenarioCommitmentDefinition extends BaseCommitmentDefinition {
|
|
|
6409
6828
|
*/
|
|
6410
6829
|
|
|
6411
6830
|
/**
|
|
6412
|
-
*
|
|
6413
|
-
*
|
|
6414
|
-
* The STYLE commitment defines how the agent should format and present its responses.
|
|
6415
|
-
* This includes tone, writing style, formatting preferences, and communication patterns.
|
|
6416
|
-
*
|
|
6417
|
-
* Example usage in agent source:
|
|
6831
|
+
* Placeholder commitment definition for commitments that are not yet implemented
|
|
6418
6832
|
*
|
|
6419
|
-
*
|
|
6420
|
-
*
|
|
6421
|
-
* STYLE Always provide code examples when explaining programming concepts
|
|
6422
|
-
* ```
|
|
6833
|
+
* This commitment simply adds its content 1:1 into the system message,
|
|
6834
|
+
* preserving the original behavior until proper implementation is added.
|
|
6423
6835
|
*
|
|
6424
|
-
* @
|
|
6836
|
+
* @public exported from `@promptbook/core`
|
|
6425
6837
|
*/
|
|
6426
|
-
class
|
|
6427
|
-
constructor(type
|
|
6838
|
+
class NotYetImplementedCommitmentDefinition extends BaseCommitmentDefinition {
|
|
6839
|
+
constructor(type) {
|
|
6428
6840
|
super(type);
|
|
6429
6841
|
}
|
|
6430
6842
|
/**
|
|
6431
|
-
* Short one-line description of
|
|
6843
|
+
* Short one-line description of a placeholder commitment.
|
|
6432
6844
|
*/
|
|
6433
6845
|
get description() {
|
|
6434
|
-
return '
|
|
6846
|
+
return 'Placeholder commitment that appends content verbatim to the system message.';
|
|
6435
6847
|
}
|
|
6436
6848
|
/**
|
|
6437
6849
|
* Icon for this commitment.
|
|
6438
6850
|
*/
|
|
6439
6851
|
get icon() {
|
|
6440
|
-
return '
|
|
6852
|
+
return '🚧';
|
|
6441
6853
|
}
|
|
6442
6854
|
/**
|
|
6443
|
-
* Markdown documentation
|
|
6855
|
+
* Markdown documentation available at runtime.
|
|
6444
6856
|
*/
|
|
6445
6857
|
get documentation() {
|
|
6446
6858
|
return spaceTrim$1(`
|
|
6447
6859
|
# ${this.type}
|
|
6448
6860
|
|
|
6449
|
-
|
|
6861
|
+
This commitment is not yet fully implemented.
|
|
6450
6862
|
|
|
6451
6863
|
## Key aspects
|
|
6452
6864
|
|
|
6453
|
-
-
|
|
6454
|
-
-
|
|
6455
|
-
-
|
|
6865
|
+
- Content is appended directly to the system message.
|
|
6866
|
+
- No special processing or validation is performed.
|
|
6867
|
+
- Behavior preserved until proper implementation is added.
|
|
6456
6868
|
|
|
6457
|
-
##
|
|
6869
|
+
## Status
|
|
6458
6870
|
|
|
6459
|
-
|
|
6460
|
-
|
|
6871
|
+
- **Status:** Placeholder implementation
|
|
6872
|
+
- **Effect:** Appends content prefixed by commitment type
|
|
6873
|
+
- **Future:** Will be replaced with specialized logic
|
|
6461
6874
|
|
|
6462
|
-
|
|
6463
|
-
STYLE Write in a professional but friendly tone, use bullet points for lists
|
|
6464
|
-
STYLE Always provide code examples when explaining programming concepts
|
|
6465
|
-
FORMAT Use markdown formatting with clear headings
|
|
6466
|
-
\`\`\`
|
|
6875
|
+
## Examples
|
|
6467
6876
|
|
|
6468
6877
|
\`\`\`book
|
|
6469
|
-
|
|
6878
|
+
Example Agent
|
|
6470
6879
|
|
|
6471
|
-
PERSONA You are a
|
|
6472
|
-
|
|
6473
|
-
|
|
6474
|
-
STYLE Keep responses conversational and engaging
|
|
6475
|
-
RULE Always maintain a positive and supportive tone
|
|
6880
|
+
PERSONA You are a helpful assistant
|
|
6881
|
+
${this.type} Your content here
|
|
6882
|
+
RULE Always be helpful
|
|
6476
6883
|
\`\`\`
|
|
6477
6884
|
`);
|
|
6478
6885
|
}
|
|
@@ -6481,70 +6888,108 @@ class StyleCommitmentDefinition extends BaseCommitmentDefinition {
|
|
|
6481
6888
|
if (!trimmedContent) {
|
|
6482
6889
|
return requirements;
|
|
6483
6890
|
}
|
|
6484
|
-
// Add
|
|
6485
|
-
const
|
|
6486
|
-
return this.appendToSystemMessage(requirements,
|
|
6891
|
+
// Add the commitment content 1:1 to the system message
|
|
6892
|
+
const commitmentLine = `${this.type} ${trimmedContent}`;
|
|
6893
|
+
return this.appendToSystemMessage(requirements, commitmentLine, '\n\n');
|
|
6487
6894
|
}
|
|
6488
6895
|
}
|
|
6489
|
-
/**
|
|
6490
|
-
* [💞] Ignore a discrepancy between file name and entity name
|
|
6491
|
-
*/
|
|
6492
6896
|
|
|
6493
6897
|
// Import all commitment definition classes
|
|
6494
|
-
|
|
6495
|
-
|
|
6496
|
-
|
|
6497
|
-
|
|
6498
|
-
|
|
6499
|
-
|
|
6500
|
-
|
|
6501
|
-
|
|
6502
|
-
|
|
6503
|
-
|
|
6504
|
-
|
|
6505
|
-
|
|
6506
|
-
|
|
6507
|
-
|
|
6508
|
-
|
|
6509
|
-
|
|
6510
|
-
|
|
6511
|
-
|
|
6512
|
-
|
|
6513
|
-
|
|
6514
|
-
|
|
6515
|
-
|
|
6516
|
-
|
|
6517
|
-
|
|
6518
|
-
|
|
6519
|
-
|
|
6520
|
-
|
|
6521
|
-
|
|
6522
|
-
|
|
6523
|
-
|
|
6524
|
-
|
|
6525
|
-
|
|
6526
|
-
|
|
6527
|
-
|
|
6528
|
-
|
|
6529
|
-
|
|
6530
|
-
|
|
6531
|
-
|
|
6532
|
-
|
|
6533
|
-
|
|
6534
|
-
|
|
6535
|
-
|
|
6536
|
-
|
|
6537
|
-
|
|
6538
|
-
|
|
6539
|
-
|
|
6540
|
-
|
|
6541
|
-
|
|
6542
|
-
|
|
6543
|
-
|
|
6544
|
-
|
|
6545
|
-
|
|
6546
|
-
|
|
6898
|
+
/**
|
|
6899
|
+
* Registry of all available commitment definitions
|
|
6900
|
+
* This array contains instances of all commitment definitions
|
|
6901
|
+
* This is the single source of truth for all commitments in the system
|
|
6902
|
+
*
|
|
6903
|
+
* @private Use functions to access commitments instead of this array directly
|
|
6904
|
+
*/
|
|
6905
|
+
const COMMITMENT_REGISTRY = [
|
|
6906
|
+
// Fully implemented commitments
|
|
6907
|
+
new PersonaCommitmentDefinition('PERSONA'),
|
|
6908
|
+
new PersonaCommitmentDefinition('PERSONAE'),
|
|
6909
|
+
new KnowledgeCommitmentDefinition(),
|
|
6910
|
+
new MemoryCommitmentDefinition('MEMORY'),
|
|
6911
|
+
new MemoryCommitmentDefinition('MEMORIES'),
|
|
6912
|
+
new StyleCommitmentDefinition('STYLE'),
|
|
6913
|
+
new StyleCommitmentDefinition('STYLES'),
|
|
6914
|
+
new RuleCommitmentDefinition('RULE'),
|
|
6915
|
+
new RuleCommitmentDefinition('RULES'),
|
|
6916
|
+
new LanguageCommitmentDefinition('LANGUAGE'),
|
|
6917
|
+
new LanguageCommitmentDefinition('LANGUAGES'),
|
|
6918
|
+
new SampleCommitmentDefinition('SAMPLE'),
|
|
6919
|
+
new SampleCommitmentDefinition('EXAMPLE'),
|
|
6920
|
+
new FormatCommitmentDefinition('FORMAT'),
|
|
6921
|
+
new FormatCommitmentDefinition('FORMATS'),
|
|
6922
|
+
new FromCommitmentDefinition('FROM'),
|
|
6923
|
+
new ModelCommitmentDefinition('MODEL'),
|
|
6924
|
+
new ModelCommitmentDefinition('MODELS'),
|
|
6925
|
+
new ActionCommitmentDefinition('ACTION'),
|
|
6926
|
+
new ActionCommitmentDefinition('ACTIONS'),
|
|
6927
|
+
new ComponentCommitmentDefinition(),
|
|
6928
|
+
new MetaImageCommitmentDefinition(),
|
|
6929
|
+
new MetaColorCommitmentDefinition(),
|
|
6930
|
+
new MetaFontCommitmentDefinition(),
|
|
6931
|
+
new MetaLinkCommitmentDefinition(),
|
|
6932
|
+
new MetaCommitmentDefinition(),
|
|
6933
|
+
new NoteCommitmentDefinition('NOTE'),
|
|
6934
|
+
new NoteCommitmentDefinition('NOTES'),
|
|
6935
|
+
new NoteCommitmentDefinition('COMMENT'),
|
|
6936
|
+
new NoteCommitmentDefinition('NONCE'),
|
|
6937
|
+
new GoalCommitmentDefinition('GOAL'),
|
|
6938
|
+
new GoalCommitmentDefinition('GOALS'),
|
|
6939
|
+
new InitialMessageCommitmentDefinition(),
|
|
6940
|
+
new UserMessageCommitmentDefinition(),
|
|
6941
|
+
new AgentMessageCommitmentDefinition(),
|
|
6942
|
+
new MessageCommitmentDefinition('MESSAGE'),
|
|
6943
|
+
new MessageCommitmentDefinition('MESSAGES'),
|
|
6944
|
+
new ScenarioCommitmentDefinition('SCENARIO'),
|
|
6945
|
+
new ScenarioCommitmentDefinition('SCENARIOS'),
|
|
6946
|
+
new DeleteCommitmentDefinition('DELETE'),
|
|
6947
|
+
new DeleteCommitmentDefinition('CANCEL'),
|
|
6948
|
+
new DeleteCommitmentDefinition('DISCARD'),
|
|
6949
|
+
new DeleteCommitmentDefinition('REMOVE'),
|
|
6950
|
+
new OpenCommitmentDefinition(),
|
|
6951
|
+
new ClosedCommitmentDefinition(),
|
|
6952
|
+
new UseBrowserCommitmentDefinition(),
|
|
6953
|
+
new UseSearchEngineCommitmentDefinition(),
|
|
6954
|
+
new UseMcpCommitmentDefinition(),
|
|
6955
|
+
new UseCommitmentDefinition(),
|
|
6956
|
+
// Not yet implemented commitments (using placeholder)
|
|
6957
|
+
new NotYetImplementedCommitmentDefinition('EXPECT'),
|
|
6958
|
+
new NotYetImplementedCommitmentDefinition('BEHAVIOUR'),
|
|
6959
|
+
new NotYetImplementedCommitmentDefinition('BEHAVIOURS'),
|
|
6960
|
+
new NotYetImplementedCommitmentDefinition('AVOID'),
|
|
6961
|
+
new NotYetImplementedCommitmentDefinition('AVOIDANCE'),
|
|
6962
|
+
new NotYetImplementedCommitmentDefinition('CONTEXT'),
|
|
6963
|
+
];
|
|
6964
|
+
/**
|
|
6965
|
+
* Gets a commitment definition by its type
|
|
6966
|
+
* @param type The commitment type to look up
|
|
6967
|
+
* @returns The commitment definition or null if not found
|
|
6968
|
+
*
|
|
6969
|
+
* @public exported from `@promptbook/core`
|
|
6970
|
+
*/
|
|
6971
|
+
function getCommitmentDefinition(type) {
|
|
6972
|
+
return COMMITMENT_REGISTRY.find((commitmentDefinition) => commitmentDefinition.type === type) || null;
|
|
6973
|
+
}
|
|
6974
|
+
/**
|
|
6975
|
+
* Gets all available commitment definitions
|
|
6976
|
+
* @returns Array of all commitment definitions
|
|
6977
|
+
*
|
|
6978
|
+
* @public exported from `@promptbook/core`
|
|
6979
|
+
*/
|
|
6980
|
+
function getAllCommitmentDefinitions() {
|
|
6981
|
+
return $deepFreeze([...COMMITMENT_REGISTRY]);
|
|
6982
|
+
}
|
|
6983
|
+
/**
|
|
6984
|
+
* TODO: [🧠] Maybe create through standardized $register
|
|
6985
|
+
* Note: [💞] Ignore a discrepancy between file name and entity name
|
|
6986
|
+
*/
|
|
6547
6987
|
|
|
6988
|
+
/**
|
|
6989
|
+
* Regex pattern to match horizontal lines (markdown thematic breaks)
|
|
6990
|
+
* Matches 3 or more hyphens, underscores, or asterisks (with optional spaces between)
|
|
6991
|
+
*/
|
|
6992
|
+
const HORIZONTAL_LINE_PATTERN = /^[\s]*[-_*][\s]*[-_*][\s]*[-_*][\s]*[-_*]*[\s]*$/;
|
|
6548
6993
|
/**
|
|
6549
6994
|
* Parses agent source using the new commitment system with multiline support
|
|
6550
6995
|
* This function replaces the hardcoded commitment parsing in the original parseAgentSource
|
|
@@ -6607,6 +7052,24 @@ function parseAgentSourceWithCommitments(agentSource) {
|
|
|
6607
7052
|
break;
|
|
6608
7053
|
}
|
|
6609
7054
|
}
|
|
7055
|
+
// Check if this is a horizontal line (ends any current commitment)
|
|
7056
|
+
const isHorizontalLine = HORIZONTAL_LINE_PATTERN.test(line);
|
|
7057
|
+
if (isHorizontalLine) {
|
|
7058
|
+
// Save the current commitment if it exists
|
|
7059
|
+
if (currentCommitment) {
|
|
7060
|
+
const fullContent = currentCommitment.contentLines.join('\n');
|
|
7061
|
+
commitments.push({
|
|
7062
|
+
type: currentCommitment.type,
|
|
7063
|
+
content: spaceTrim$1(fullContent),
|
|
7064
|
+
originalLine: currentCommitment.originalStartLine,
|
|
7065
|
+
lineNumber: currentCommitment.startLineNumber,
|
|
7066
|
+
});
|
|
7067
|
+
currentCommitment = null;
|
|
7068
|
+
}
|
|
7069
|
+
// Add horizontal line to non-commitment lines
|
|
7070
|
+
nonCommitmentLines.push(line);
|
|
7071
|
+
continue;
|
|
7072
|
+
}
|
|
6610
7073
|
if (!foundNewCommitment) {
|
|
6611
7074
|
if (currentCommitment) {
|
|
6612
7075
|
// This line belongs to the current commitment
|
|
@@ -6732,17 +7195,21 @@ function parseAgentSource(agentSource) {
|
|
|
6732
7195
|
const links = [];
|
|
6733
7196
|
for (const commitment of parseResult.commitments) {
|
|
6734
7197
|
if (commitment.type === 'META LINK') {
|
|
6735
|
-
const linkValue = spaceTrim(commitment.content);
|
|
7198
|
+
const linkValue = spaceTrim$2(commitment.content);
|
|
6736
7199
|
links.push(linkValue);
|
|
6737
7200
|
meta.link = linkValue;
|
|
6738
7201
|
continue;
|
|
6739
7202
|
}
|
|
6740
7203
|
if (commitment.type === 'META IMAGE') {
|
|
6741
|
-
meta.image = spaceTrim(commitment.content);
|
|
7204
|
+
meta.image = spaceTrim$2(commitment.content);
|
|
6742
7205
|
continue;
|
|
6743
7206
|
}
|
|
6744
7207
|
if (commitment.type === 'META COLOR') {
|
|
6745
|
-
meta.color =
|
|
7208
|
+
meta.color = normalizeSeparator(commitment.content);
|
|
7209
|
+
continue;
|
|
7210
|
+
}
|
|
7211
|
+
if (commitment.type === 'META FONT') {
|
|
7212
|
+
meta.font = normalizeSeparator(commitment.content);
|
|
6746
7213
|
continue;
|
|
6747
7214
|
}
|
|
6748
7215
|
if (commitment.type !== 'META') {
|
|
@@ -6751,10 +7218,10 @@ function parseAgentSource(agentSource) {
|
|
|
6751
7218
|
// Parse META commitments - format is "META TYPE content"
|
|
6752
7219
|
const metaTypeRaw = commitment.content.split(' ')[0] || 'NONE';
|
|
6753
7220
|
if (metaTypeRaw === 'LINK') {
|
|
6754
|
-
links.push(spaceTrim(commitment.content.substring(metaTypeRaw.length)));
|
|
7221
|
+
links.push(spaceTrim$2(commitment.content.substring(metaTypeRaw.length)));
|
|
6755
7222
|
}
|
|
6756
7223
|
const metaType = normalizeTo_camelCase(metaTypeRaw);
|
|
6757
|
-
meta[metaType] = spaceTrim(commitment.content.substring(metaTypeRaw.length));
|
|
7224
|
+
meta[metaType] = spaceTrim$2(commitment.content.substring(metaTypeRaw.length));
|
|
6758
7225
|
}
|
|
6759
7226
|
// Generate gravatar fallback if no meta image specified
|
|
6760
7227
|
if (!meta.image) {
|
|
@@ -6778,6 +7245,19 @@ function parseAgentSource(agentSource) {
|
|
|
6778
7245
|
parameters,
|
|
6779
7246
|
};
|
|
6780
7247
|
}
|
|
7248
|
+
/**
|
|
7249
|
+
* Normalizes the separator in the content
|
|
7250
|
+
*
|
|
7251
|
+
* @param content - The content to normalize
|
|
7252
|
+
* @returns The content with normalized separators
|
|
7253
|
+
*/
|
|
7254
|
+
function normalizeSeparator(content) {
|
|
7255
|
+
const trimmed = spaceTrim$2(content);
|
|
7256
|
+
if (trimmed.includes(',')) {
|
|
7257
|
+
return trimmed;
|
|
7258
|
+
}
|
|
7259
|
+
return trimmed.split(/\s+/).join(', ');
|
|
7260
|
+
}
|
|
6781
7261
|
/**
|
|
6782
7262
|
* TODO: [🕛] Unite `AgentBasicInformation`, `ChatParticipant`, `LlmExecutionTools` + `LlmToolsMetadata`
|
|
6783
7263
|
*/
|
|
@@ -6892,7 +7372,7 @@ function validateBook(source) {
|
|
|
6892
7372
|
* @deprecated Use `$generateBookBoilerplate` instead
|
|
6893
7373
|
* @public exported from `@promptbook/core`
|
|
6894
7374
|
*/
|
|
6895
|
-
const DEFAULT_BOOK = padBook(validateBook(spaceTrim(`
|
|
7375
|
+
const DEFAULT_BOOK = padBook(validateBook(spaceTrim$2(`
|
|
6896
7376
|
AI Avatar
|
|
6897
7377
|
|
|
6898
7378
|
PERSONA A friendly AI assistant that helps you with your tasks
|
|
@@ -7241,7 +7721,7 @@ function MarkdownContent(props) {
|
|
|
7241
7721
|
function aboutPromptbookInformation(options) {
|
|
7242
7722
|
const { isServersInfoIncluded = true, isRuntimeEnvironmentInfoIncluded = true } = options || {};
|
|
7243
7723
|
const fullInfoPieces = [];
|
|
7244
|
-
const basicInfo = spaceTrim(`
|
|
7724
|
+
const basicInfo = spaceTrim$2(`
|
|
7245
7725
|
|
|
7246
7726
|
# ${NAME}
|
|
7247
7727
|
|
|
@@ -7253,7 +7733,7 @@ function aboutPromptbookInformation(options) {
|
|
|
7253
7733
|
`);
|
|
7254
7734
|
fullInfoPieces.push(basicInfo);
|
|
7255
7735
|
if (isServersInfoIncluded) {
|
|
7256
|
-
const serversInfo = spaceTrim((block) => `
|
|
7736
|
+
const serversInfo = spaceTrim$2((block) => `
|
|
7257
7737
|
|
|
7258
7738
|
## Servers
|
|
7259
7739
|
|
|
@@ -7268,7 +7748,7 @@ function aboutPromptbookInformation(options) {
|
|
|
7268
7748
|
...runtimeEnvironment,
|
|
7269
7749
|
isCostPrevented: IS_COST_PREVENTED,
|
|
7270
7750
|
};
|
|
7271
|
-
const environmentInfo = spaceTrim((block) => `
|
|
7751
|
+
const environmentInfo = spaceTrim$2((block) => `
|
|
7272
7752
|
|
|
7273
7753
|
## Environment
|
|
7274
7754
|
|
|
@@ -7278,7 +7758,7 @@ function aboutPromptbookInformation(options) {
|
|
|
7278
7758
|
`);
|
|
7279
7759
|
fullInfoPieces.push(environmentInfo);
|
|
7280
7760
|
}
|
|
7281
|
-
const fullInfo = spaceTrim(fullInfoPieces.join('\n\n'));
|
|
7761
|
+
const fullInfo = spaceTrim$2(fullInfoPieces.join('\n\n'));
|
|
7282
7762
|
return fullInfo;
|
|
7283
7763
|
}
|
|
7284
7764
|
/**
|
|
@@ -7564,7 +8044,7 @@ function BookEditorMonaco(props) {
|
|
|
7564
8044
|
// Register a new language
|
|
7565
8045
|
monaco.languages.register({ id: BOOK_LANGUAGE_ID });
|
|
7566
8046
|
const commitmentTypes = [...new Set(getAllCommitmentDefinitions().map(({ type }) => type))];
|
|
7567
|
-
const commitmentRegex = new RegExp(`^(${commitmentTypes.map((type) => (type === 'META' ? 'META\\s+\\w+' : type)).join('|')})
|
|
8047
|
+
const commitmentRegex = new RegExp(`^(${commitmentTypes.map((type) => (type === 'META' ? 'META\\s+\\w+' : type)).join('|')})`);
|
|
7568
8048
|
// Note: Using a broad character set for Latin and Cyrillic to support international characters in parameters.
|
|
7569
8049
|
// Monarch tokenizer does not support Unicode property escapes like \p{L}.
|
|
7570
8050
|
const parameterRegex = /@([a-zA-Z0-9_á-žÁ-Žč-řČ-Řš-žŠ-Žа-яА-ЯёЁ]+)/;
|
|
@@ -7916,38 +8396,6 @@ function AvatarProfileFromSource(props) {
|
|
|
7916
8396
|
return jsx(AvatarProfile, { ...rest, agent: agent, agentSource: agentSource });
|
|
7917
8397
|
}
|
|
7918
8398
|
|
|
7919
|
-
/**
|
|
7920
|
-
* Restricts an Updatable to a (2) BehaviorSubject variant
|
|
7921
|
-
*
|
|
7922
|
-
* @see Updatable
|
|
7923
|
-
* @private internal utility <- TODO: [🧠] Maybe export from `@promptbook/types`
|
|
7924
|
-
*/
|
|
7925
|
-
function asUpdatableSubject(value) {
|
|
7926
|
-
if (value instanceof BehaviorSubject) {
|
|
7927
|
-
return value;
|
|
7928
|
-
}
|
|
7929
|
-
else if (Array.isArray(value)) {
|
|
7930
|
-
if (value.length !== 2) {
|
|
7931
|
-
throw new TypeError('`asUpdatableSubject`: Invalid tuple length, expected 2 elements');
|
|
7932
|
-
}
|
|
7933
|
-
if (typeof value[1] !== 'function') {
|
|
7934
|
-
throw new TypeError('`asUpdatableSubject`: Invalid tuple, expected second element to be a function');
|
|
7935
|
-
}
|
|
7936
|
-
const [theValue, setValue] = value;
|
|
7937
|
-
const subject = new BehaviorSubject(theValue);
|
|
7938
|
-
subject.subscribe((newValue) => {
|
|
7939
|
-
setValue(newValue);
|
|
7940
|
-
});
|
|
7941
|
-
return subject;
|
|
7942
|
-
}
|
|
7943
|
-
else {
|
|
7944
|
-
return new BehaviorSubject(value);
|
|
7945
|
-
}
|
|
7946
|
-
}
|
|
7947
|
-
/**
|
|
7948
|
-
* TODO: [🧠] Maybe `BehaviorSubject` is too heavy for this use case, maybe just tuple `[value,setValue]` is enough
|
|
7949
|
-
*/
|
|
7950
|
-
|
|
7951
8399
|
/**
|
|
7952
8400
|
* Calculates distance between two colors
|
|
7953
8401
|
*
|
|
@@ -8027,6 +8475,38 @@ function furthest(...colors) {
|
|
|
8027
8475
|
*/
|
|
8028
8476
|
const textColor = furthest(Color.get('white'), Color.from('black'));
|
|
8029
8477
|
|
|
8478
|
+
/**
|
|
8479
|
+
* Restricts an Updatable to a (2) BehaviorSubject variant
|
|
8480
|
+
*
|
|
8481
|
+
* @see Updatable
|
|
8482
|
+
* @private internal utility <- TODO: [🧠] Maybe export from `@promptbook/types`
|
|
8483
|
+
*/
|
|
8484
|
+
function asUpdatableSubject(value) {
|
|
8485
|
+
if (value instanceof BehaviorSubject) {
|
|
8486
|
+
return value;
|
|
8487
|
+
}
|
|
8488
|
+
else if (Array.isArray(value)) {
|
|
8489
|
+
if (value.length !== 2) {
|
|
8490
|
+
throw new TypeError('`asUpdatableSubject`: Invalid tuple length, expected 2 elements');
|
|
8491
|
+
}
|
|
8492
|
+
if (typeof value[1] !== 'function') {
|
|
8493
|
+
throw new TypeError('`asUpdatableSubject`: Invalid tuple, expected second element to be a function');
|
|
8494
|
+
}
|
|
8495
|
+
const [theValue, setValue] = value;
|
|
8496
|
+
const subject = new BehaviorSubject(theValue);
|
|
8497
|
+
subject.subscribe((newValue) => {
|
|
8498
|
+
setValue(newValue);
|
|
8499
|
+
});
|
|
8500
|
+
return subject;
|
|
8501
|
+
}
|
|
8502
|
+
else {
|
|
8503
|
+
return new BehaviorSubject(value);
|
|
8504
|
+
}
|
|
8505
|
+
}
|
|
8506
|
+
/**
|
|
8507
|
+
* TODO: [🧠] Maybe `BehaviorSubject` is too heavy for this use case, maybe just tuple `[value,setValue]` is enough
|
|
8508
|
+
*/
|
|
8509
|
+
|
|
8030
8510
|
/**
|
|
8031
8511
|
* Change ellipsis character to three dots `…` -> `...`
|
|
8032
8512
|
*
|
|
@@ -8400,7 +8880,7 @@ function getTextColor(bgColor) {
|
|
|
8400
8880
|
const htmlSaveFormatDefinition = {
|
|
8401
8881
|
formatName: 'html',
|
|
8402
8882
|
label: 'Html',
|
|
8403
|
-
getContent: ({ messages }) => spaceTrim(`
|
|
8883
|
+
getContent: ({ messages }) => spaceTrim$2(`
|
|
8404
8884
|
<!DOCTYPE html>
|
|
8405
8885
|
<html lang="en">
|
|
8406
8886
|
<head>
|
|
@@ -8488,7 +8968,7 @@ const htmlSaveFormatDefinition = {
|
|
|
8488
8968
|
};
|
|
8489
8969
|
const bgColor = participantColors[String(message.from)] || '#2b7cff';
|
|
8490
8970
|
const textColor = getTextColor(bgColor);
|
|
8491
|
-
return spaceTrim(`
|
|
8971
|
+
return spaceTrim$2(`
|
|
8492
8972
|
<div class="chat-message">
|
|
8493
8973
|
<div class="avatar" style="background:${bgColor};color:${getTextColor(bgColor)};">
|
|
8494
8974
|
${String(message.from)[0] || '?'}
|
|
@@ -8591,7 +9071,7 @@ const reactSaveFormatDefinition = {
|
|
|
8591
9071
|
const { imports: participantsImports, value: participantsValue } = serializeToPromptbookJavascript(participants);
|
|
8592
9072
|
const { imports: messagesImports, value: messagesValue } = serializeToPromptbookJavascript(messages);
|
|
8593
9073
|
const uniqueImports = Array.from(new Set([`import { Chat } from '@promptbook/components';`, ...participantsImports, ...messagesImports])).filter((imp) => !!imp && imp.trim().length > 0);
|
|
8594
|
-
return spaceTrim((block) => `
|
|
9074
|
+
return spaceTrim$2((block) => `
|
|
8595
9075
|
"use client";
|
|
8596
9076
|
|
|
8597
9077
|
${block(uniqueImports.join('\n'))}
|
|
@@ -8659,7 +9139,7 @@ function getChatSaveFormatDefinitions(formatNames) {
|
|
|
8659
9139
|
return CHAT_SAVE_FORMATS.filter((saveFormatDefinition) => formatNames.includes(saveFormatDefinition.formatName));
|
|
8660
9140
|
}
|
|
8661
9141
|
|
|
8662
|
-
var css_248z$2 = "@font-face{font-family:OpenMojiBlack;src:url(https://s6.ptbk.io/fonts/OpenMoji-black-glyf.woff2) format(\"woff2\");unicode-range:u+23,u+2a,u+2d,u+30-39,u+a9,u+ae,u+200d,u+203c,u+2049,u+20e3,u+2117,u+2120,u+2122,u+2139,u+2194-2199,u+21a9,u+21aa,u+229c,u+231a,u+231b,u+2328,u+23cf,u+23e9-23f3,u+23f8-23fe,u+24c2,u+25a1,u+25aa-25ae,u+25b6,u+25c0,u+25c9,u+25d0,u+25d1,u+25e7-25ea,u+25ed,u+25ee,u+25fb-25fe,u+2600-2605,u+260e,u+2611,u+2614,u+2615,u+2618,u+261d,u+2620,u+2622,u+2623,u+2626,u+262a,u+262e,u+262f,u+2638-263a,u+2640,u+2642,u+2648-2653,u+265f,u+2660,u+2663,u+2665,u+2666,u+2668,u+267b,u+267e,u+267f,u+2691-2697,u+2699,u+269b,u+269c,u+26a0,u+26a1,u+26a7,u+26aa,u+26ab,u+26b0,u+26b1,u+26bd,u+26be,u+26c4,u+26c5,u+26c8,u+26ce,u+26cf,u+26d1,u+26d3,u+26d4,u+26e9,u+26ea,u+26f0-26f5,u+26f7-26fa,u+26fd,u+2702,u+2705,u+2708-270d,u+270f,u+2712,u+2714,u+2716,u+271d,u+2721,u+2728,u+2733,u+2734,u+2744,u+2747,u+274c,u+274e,u+2753-2755,u+2757,u+2763,u+2764,u+2795-2797,u+27a1,u+27b0,u+27bf,u+2934,u+2935,u+2b05-2b07,u+2b0c,u+2b0d,u+2b1b,u+2b1c,u+2b1f-2b24,u+2b2e,u+2b2f,u+2b50,u+2b55,u+2b58,u+2b8f,u+2bba-2bbc,u+2bc3,u+2bc4,u+2bea,u+2beb,u+3030,u+303d,u+3297,u+3299,u+e000-e009,u+e010,u+e011,u+e040-e06d,u+e080-e0b4,u+e0c0-e0cc,u+e0ff-e10d,u+e140-e14a,u+e150-e157,u+e181-e189,u+e1c0-e1c4,u+e1c6-e1d9,u+e200-e216,u+e240-e269,u+e280-e283,u+e2c0-e2c4,u+e2c6-e2da,u+e300-e303,u+e305-e30f,u+e312-e316,u+e318-e322,u+e324-e329,u+e32b,u+e340-e348,u+e380,u+e381,u+f000,u+f77a,u+f8ff,u+fe0f,u+1f004,u+1f0cf,u+1f10d-1f10f,u+1f12f,u+1f16d-1f171,u+1f17e,u+1f17f,u+1f18e,u+1f191-1f19a,u+1f1e6-1f1ff,u+1f201,u+1f202,u+1f21a,u+1f22f,u+1f232-1f23a,u+1f250,u+1f251,u+1f260-1f265,u+1f300-1f321,u+1f324-1f393,u+1f396,u+1f397,u+1f399-1f39b,u+1f39e-1f3f0,u+1f3f3-1f3f5,u+1f3f7-1f4fd,u+1f4ff-1f53d,u+1f549-1f54e,u+1f550-1f567,u+1f56f,u+1f570,u+1f573-1f57a,u+1f587,u+1f58a-1f58d,u+1f590,u+1f595,u+1f596,u+1f5a4,u+1f5a5,u+1f5a8,u+1f5b1,u+1f5b2,u+1f5bc,u+1f5c2-1f5c4,u+1f5d1-1f5d3,u+1f5dc-1f5de,u+1f5e1,u+1f5e3,u+1f5e8,u+1f5ef,u+1f5f3,u+1f5fa-1f64f,u+1f680-1f6c5,u+1f6cb-1f6d2,u+1f6d5-1f6d7,u+1f6dc-1f6e5,u+1f6e9,u+1f6eb,u+1f6ec,u+1f6f0,u+1f6f3-1f6fc,u+1f7e0-1f7eb,u+1f7f0,u+1f90c-1f93a,u+1f93c-1f945,u+1f947-1f9ff,u+1fa70-1fa7c,u+1fa80-1fa88,u+1fa90-1fabd,u+1fabf-1fac5,u+1face-1fadb,u+1fae0-1fae8,u+1faf0-1faf8,u+1fbc5-1fbc9,u+e0061-e0067,u+e0069,u+e006c-e0079,u+e007f}.Chat-module_copiedToClipboardMessage__apCPY{background:#222;border-radius:8px;box-shadow:0 2px 12px rgba(0,0,0,.18);color:#fff;font-size:1.1em;left:50%;opacity:.97;padding:10px 24px;pointer-events:none;position:fixed;top:32px;transform:translateX(-50%);z-index:9999}.Chat-module_Chat__j2eE5{display:flex;flex-direction:column;font-family:Arial,Helvetica,sans-serif,OpenMojiBlack;height:100%;width:100%}.Chat-module_chatMainFlow__--8FE{display:grid;grid-template:\"🟦\" min-content \"💬\" 1fr \"📝\" min-content/1fr;height:100%;max-width:100vw;width:100%}.Chat-module_chatMainFlow__--8FE .Chat-module_chatBar__fLECN{background-color:#fff;border-bottom:1px solid rgba(15,23,36,.06);color:#0f1724;font-weight:500;grid-area:🟦;padding:16px 20px;text-align:center;width:100%}.Chat-module_TasksInProgress__fQfei{align-self:center;grid-area:🟦;height:min-content;justify-self:self-end;margin:8px 16px;width:auto}.Chat-module_actions__gTZ5T{align-items:center;align-self:self-start;display:flex;gap:8px;grid-area:💬;height:min-content;justify-self:self-end;margin:16px 20px 0;width:auto;z-index:200}.Chat-module_actions__gTZ5T.Chat-module_portal__uTOT8{margin:0}.Chat-module_actions__gTZ5T.Chat-module_left__7l5Mn{justify-self:self-start}.Chat-module_actions__gTZ5T.Chat-module_right__ABZrW{justify-self:self-end}@media (max-width:900px){.Chat-module_chatButton__d9VgA{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_chatButton__d9VgA svg{height:18px!important;width:18px!important}.Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_useTemplateButton__xcJNR{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_useTemplateButton__xcJNR svg{height:18px!important;width:18px!important}.Chat-module_useTemplateButton__xcJNR .Chat-module_chatButtonText__RkGB-{display:none!important}}@media (max-width:600px){.Chat-module_actions__gTZ5T{gap:7px;margin:14px 18px 0}}.Chat-module_chatMainFlow__--8FE .Chat-module_chatChildren__flOPK{grid-area:💬;height:100%;width:100%;z-index:300}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N{grid-area:💬;height:100%;overflow-x:hidden;overflow-y:auto;padding:24px 20px 16px;scroll-behavior:smooth;width:100%;z-index:10}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N::-webkit-scrollbar{width:6px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N::-webkit-scrollbar-track{background:transparent}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N::-webkit-scrollbar-thumb{background:hsla(0,0%,49%,.2);border-radius:3px;transition:all .2s ease}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N::-webkit-scrollbar-thumb:hover{background:hsla(0,0%,49%,.3)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ{align-items:flex-end;animation:Chat-module_messageSlideIn__soTy2 .4s cubic-bezier(.25,.46,.45,.94);display:flex;flex-direction:row;margin-bottom:20px;max-width:100%;position:relative}.Chat-module_hasActionsAndFirstMessageIsLong__5jgoZ{margin-top:55px}@keyframes Chat-module_messageSlideIn__soTy2{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.Chat-module_isNotCompleteMessage__Hj2K7{opacity:.7;position:relative}.Chat-module_NonCompleteMessageFiller__G5-Ve{color:transparent}.Chat-module_isNotCompleteMessage__Hj2K7 .Chat-module_messageText__XgNyQ:after{animation:Chat-module_loadingPulse__VomRm 1.5s ease-in-out infinite;background:linear-gradient(90deg,transparent,hsla(0,0%,49%,.6),transparent);border-radius:2px;bottom:8px;content:\"\";height:4px;position:absolute;right:12px;width:20px}@keyframes Chat-module_loadingPulse__VomRm{0%,to{opacity:.3;transform:scaleX(.8)}50%{opacity:1;transform:scaleX(1.2)}}.Chat-module_typingIndicator__S-CT-{align-items:flex-end;animation:Chat-module_messageSlideIn__soTy2 .4s cubic-bezier(.25,.46,.45,.94);display:flex;margin-bottom:20px}.Chat-module_typingIndicator__S-CT- .Chat-module_avatar__gL6bm{flex-shrink:0;height:40px;margin:0 12px 4px;width:40px}.Chat-module_typingIndicator__S-CT- .Chat-module_avatar__gL6bm img{aspect-ratio:1/1;background-color:#eef6fb;border:2px solid hsla(0,0%,49%,.1);border-radius:50%;object-fit:cover;width:40px}.Chat-module_typingBubble__0Lb7B{backdrop-filter:blur(10px);border:1px solid hsla(0,0%,49%,.1);border-radius:20px;border-bottom-left-radius:6px;box-shadow:0 2px 8px rgba(0,0,0,.1);min-height:24px;padding:16px 20px}.Chat-module_typingBubble__0Lb7B,.Chat-module_typingDots__srOBB{align-items:center;display:flex;gap:4px}.Chat-module_typingDot__dnhKT{animation:Chat-module_typingBounce__1yp2v 1.4s ease-in-out infinite;background:linear-gradient(135deg,#6b7280,hsla(0,0%,49%,.6));border-radius:50%;box-shadow:0 2px 4px rgba(0,0,0,.1);height:8px;width:8px}.Chat-module_typingDot__dnhKT:first-child{animation-delay:-.32s}.Chat-module_typingDot__dnhKT:nth-child(2){animation-delay:-.16s}.Chat-module_typingDot__dnhKT:nth-child(3){animation-delay:0s}@keyframes Chat-module_typingBounce__1yp2v{0%,80%,to{opacity:.5;transform:scale(.8) translateY(0)}40%{opacity:1;transform:scale(1.2) translateY(-8px)}}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ.Chat-module_isMe__nBtaV{align-items:flex-end;flex-direction:row-reverse;justify-content:flex-start}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ.Chat-module_isMe__nBtaV .Chat-module_messageText__XgNyQ{border-bottom-right-radius:6px}.Chat-module_ratingStar__rRfqC{color:var(--star-inactive-color,#ccc);cursor:pointer;font-size:20px;transition:color .2s}.Chat-module_ratingStar__rRfqC.Chat-module_active__lbYL-{color:gold}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm{aspect-ratio:1/1;flex-shrink:0;margin:0 12px 4px;position:relative;width:40px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img{aspect-ratio:1/1;background-color:var(--avatar-bg-color,#eef6fb);border:2px solid hsla(0,0%,49%,.1);border-radius:50%;object-fit:cover;transition:transform .2s ease,box-shadow .2s ease;width:40px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img:hover{box-shadow:0 4px 12px rgba(0,0,0,.15);transform:scale(1.05)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{word-wrap:break-word;backdrop-filter:blur(10px);background-color:var(--message-bg-color);border-radius:20px;box-shadow:0 2px 8px rgba(0,0,0,.1);color:var(--message-text-color);font-size:15px;line-height:1.5;margin-bottom:4px;max-width:min(70%,600px);padding:14px 18px;position:relative;text-align:left;transition:all .2s ease}.Chat-module_copyButtonContainer__Rij0U{align-items:center;float:right;justify-content:flex-end;pointer-events:none;right:10px;top:8px;visibility:hidden;z-index:2}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ:hover .Chat-module_copyButtonContainer__Rij0U,.Chat-module_copyButtonContainer__Rij0U:focus-within{pointer-events:auto;visibility:visible}.Chat-module_copyButton__DcxT5{align-items:center;background:hsla(0,0%,100%,.2);border:1px solid #ddd;border-radius:6px;box-shadow:0 1px 4px rgba(0,0,0,.07);cursor:pointer;display:flex;opacity:.7;padding:2px 5px;position:relative;transition:all .15s,box-shadow .15s,border .15s}.Chat-module_copiedTooltip__LH81j{animation:Chat-module_copiedTooltipFadeIn__QekO1 .2s;background:#222;border-radius:8px;box-shadow:0 2px 12px rgba(0,0,0,.18);color:#fff;font-size:.98em;left:50%;margin-top:4px;max-width:220px;opacity:.97;overflow-wrap:break-word;padding:6px 16px;pointer-events:none;position:absolute;top:110%;transform:translateX(-50%);white-space:nowrap;word-break:break-word;z-index:100}.Chat-module_copiedTooltipLeft__j-S-5{left:0!important;transform:none!important}.Chat-module_copiedTooltipRight__R-2cE{left:auto!important;right:0!important;transform:none!important}@keyframes Chat-module_copiedTooltipFadeIn__QekO1{0%{opacity:0;transform:translateX(-50%) translateY(8px) scale(.97)}to{opacity:.97;transform:translateX(-50%) translateY(0) scale(1)}}.Chat-module_copyButton__DcxT5:focus,.Chat-module_copyButton__DcxT5:hover{border:1.5px solid #bbb;box-shadow:0 2px 8px rgba(0,132,255,.1);opacity:1}.Chat-module_copyButton__DcxT5 svg{display:block}.Chat-module_messageText__XgNyQ h1{font-size:2em}.Chat-module_messageText__XgNyQ h2{font-size:1.75em}.Chat-module_messageText__XgNyQ h3{font-size:1.5em}.Chat-module_messageText__XgNyQ h4{font-size:1.25em}.Chat-module_messageText__XgNyQ h5{font-size:1.1em}.Chat-module_messageText__XgNyQ ul{list-style:disc;margin-left:20px}.Chat-module_messageText__XgNyQ ol{list-style:decimal;margin-left:20px}.Chat-module_messageText__XgNyQ blockquote,.Chat-module_messageText__XgNyQ img,.Chat-module_messageText__XgNyQ pre,.Chat-module_messageText__XgNyQ table{border-radius:8px;margin-bottom:10px;margin-top:10px}.Chat-module_messageText__XgNyQ pre{background:#000;color:#fff}.Chat-module_messageText__XgNyQ blockquote,.Chat-module_messageText__XgNyQ pre{border:none;box-shadow:none;display:block;font-size:inherit;line-height:inherit;padding:1em}.Chat-module_messageText__XgNyQ blockquote{background:#ffffffcc;color:#000}.Chat-module_messageText__XgNyQ code{background:#cccccc55;border:none;box-shadow:none;color:inherit;display:inline-block;font-size:inherit;line-height:inherit;margin:0;padding:0}.Chat-module_messageText__XgNyQ pre code{background-color:#000000cc;border-radius:8px}.Chat-module_messageText__XgNyQ .Chat-module_chat-code-block__k8IyS{background:#181c23;border-color:#23272f;box-shadow:0 2px 8px rgba(0,0,0,.12);color:#f8fafc;font-family:Fira Mono,Menlo,Consolas,Liberation Mono,monospace;font-size:14px;line-height:1.6;overflow-x:auto}.Chat-module_messageText__XgNyQ .Chat-module_chat-code-block__k8IyS code{background:none!important;border:none!important;box-shadow:none!important;color:inherit!important;display:block;font-family:inherit!important;font-size:inherit!important;overflow-x:auto;padding:0!important;white-space:pre;word-break:break-word}.Chat-module_messageText__XgNyQ table{background:#f8fafc;border-collapse:separate;border-spacing:0;box-shadow:0 2px 8px rgba(0,0,0,.08);color:#17223b;font-size:14px;margin:16px 0;width:100%}.Chat-module_messageText__XgNyQ td,.Chat-module_messageText__XgNyQ th{background:none;border-bottom:1px solid #d1dbe8;color:#17223b;padding:10px 16px;text-align:left}.Chat-module_messageText__XgNyQ th{background:linear-gradient(90deg,#eaf3fa 80%,#d1e3f8);border-bottom:2px solid #b5c7de;color:#17223b;font-weight:700}.Chat-module_messageText__XgNyQ tr:last-child td{border-bottom:none}.Chat-module_messageText__XgNyQ tr:nth-child(2n) td{background:#eaf3fa}.Chat-module_messageText__XgNyQ tr:hover td{background:#cbe0f7;transition:background .2s}.Chat-module_messageText__XgNyQ table{border-radius:12px;overflow:hidden}.Chat-module_messageText__XgNyQ td:first-child,.Chat-module_messageText__XgNyQ th:first-child{border-top-left-radius:12px}.Chat-module_messageText__XgNyQ td:last-child,.Chat-module_messageText__XgNyQ th:last-child{border-top-right-radius:12px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ:hover{box-shadow:0 4px 16px rgba(0,0,0,.15);transform:translateY(-1px)}.Chat-module_messageButtons__WaOob{border-top:1px solid hsla(0,0%,49%,.83);display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;padding-top:12px}.Chat-module_messageButton__mRnn-{-webkit-tap-highlight-color:transparent;align-items:center;backdrop-filter:blur(10px);background:hsla(0,0%,49%,.1);border:1px solid hsla(0,0%,49%,.9);border-radius:16px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;padding:8px 14px;touch-action:manipulation;transition:all .2s ease;user-select:none}.Chat-module_messageButton__mRnn-:hover{background:rgba(0,132,255,.1);border-color:rgba(0,132,255,.3);box-shadow:0 2px 8px rgba(0,132,255,.15);transform:translateY(-1px)}.Chat-module_messageButton__mRnn-:active{transform:scale(.98);transition:transform .1s ease}.Chat-module_messageButton__mRnn- p{line-height:inherit;margin:0;padding:0}.Chat-module_messageButton__mRnn- strong{font-weight:600}.Chat-module_messageButton__mRnn- em{font-style:italic}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_rating__soc3M{align-items:center;backdrop-filter:blur(10px);background:rgba(0,0,0,.8);border-radius:12px;bottom:-8px;display:flex;gap:2px;min-width:24px;opacity:0;padding:4px 6px;position:absolute;right:8px;transform:translateY(4px);transition:all .3s cubic-bezier(.25,.46,.45,.94);z-index:1}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ:hover .Chat-module_rating__soc3M{opacity:1;transform:translateY(0)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_rating__soc3M:hover{background:rgba(0,0,0,.9);box-shadow:0 4px 12px rgba(0,0,0,.3);padding:6px 8px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_rating__soc3M span{cursor:pointer;display:inline-block;font-size:16px;transition:transform .2s ease,color .2s ease}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_rating__soc3M:hover span{transform:scale(1.1)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan{backdrop-filter:blur(20px);border-top:1px solid hsla(0,0%,49%,.1);display:flex;flex-direction:column;gap:12px;grid-area:📝;padding:20px;position:relative;width:100%;z-index:10}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan.Chat-module_dragOver__bkS-g{background:linear-gradient(0deg,rgba(0,132,255,.1) 0,rgba(0,132,255,.05));border-top:2px solid rgba(0,132,255,.3)}.Chat-module_filePreviewContainer__R70hm{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.Chat-module_filePreview__kq2aX{align-items:center;backdrop-filter:blur(10px);background:hsla(0,0%,49%,.1);border:1px solid hsla(0,0%,49%,.2);border-radius:8px;display:flex;font-size:12px;gap:8px;padding:8px 12px;transition:all .2s ease}.Chat-module_filePreview__kq2aX:hover{background:hsla(0,0%,49%,.15);border-color:hsla(0,0%,49%,.3)}.Chat-module_fileIcon__zoSKW{font-size:14px;opacity:.7}.Chat-module_fileInfo__wBLi0{display:flex;flex-direction:column;gap:2px;min-width:0}.Chat-module_fileName__bBujo{color:#000;font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.Chat-module_fileSize__ivliq{color:#6b7280;font-size:11px}.Chat-module_removeFileButton__0gakR{align-items:center;background:rgba(255,0,0,.1);border:none;border-radius:50%;color:#f44;cursor:pointer;display:flex;flex-shrink:0;height:20px;justify-content:center;transition:all .2s ease;width:20px}.Chat-module_removeFileButton__0gakR:hover{background:rgba(255,0,0,.2);transform:scale(1.1)}.Chat-module_inputContainer__bPt99{align-items:center;display:flex;gap:12px}.Chat-module_inputContainer__bPt99 textarea::placeholder{color:inherit;opacity:.7}.Chat-module_attachmentButton__qLO47{align-items:center;backdrop-filter:blur(10px);background:hsla(0,0%,49%,.05);border:1px solid hsla(0,0%,49%,.2);border-radius:50%;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;transition:all .2s ease;width:40px}.Chat-module_attachmentButton__qLO47:hover:not(:disabled){background:rgba(0,132,255,.1);border-color:rgba(0,132,255,.3);color:#0084ff;transform:scale(1.05)}.Chat-module_attachmentButton__qLO47:disabled{cursor:not-allowed;opacity:.5;transform:none}.Chat-module_voiceButton__d2zlP{align-items:center;backdrop-filter:blur(10px);background:hsla(0,0%,49%,.05);border:1px solid hsla(0,0%,49%,.2);border-radius:50%;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;transition:all .2s ease;width:40px}.Chat-module_voiceButton__d2zlP:hover{background:rgba(0,132,255,.1);border-color:rgba(0,132,255,.3);color:#0084ff;transform:scale(1.05)}.Chat-module_voiceButtonActive__Uoi3W{animation:Chat-module_voiceRecordingPulse__y2wJ5 1.5s infinite;background:rgba(255,0,0,.1)!important;border-color:rgba(255,0,0,.3)!important;color:red!important}@keyframes Chat-module_voiceRecordingPulse__y2wJ5{0%{box-shadow:0 0 0 0 rgba(255,0,0,.4)}70%{box-shadow:0 0 0 10px rgba(255,0,0,0)}to{box-shadow:0 0 0 0 rgba(255,0,0,0)}}.Chat-module_uploadProgress__jBTKe{align-items:center;background:rgba(0,132,255,.1);border:1px solid rgba(0,132,255,.2);border-radius:8px;color:#0084ff;display:flex;font-size:13px;gap:12px;padding:8px 12px}.Chat-module_uploadProgressBar__Gutnt{background:rgba(0,132,255,.2);border-radius:2px;flex:1;height:4px;overflow:hidden}.Chat-module_uploadProgressFill__EgubT{animation:Chat-module_uploadProgress__jBTKe 1.5s ease-in-out infinite;background:linear-gradient(90deg,#0084ff,rgba(0,132,255,.8));border-radius:2px;height:100%}@keyframes Chat-module_uploadProgress__jBTKe{0%{transform:translateX(-100%)}50%{transform:translateX(0)}to{transform:translateX(100%)}}.Chat-module_dragOverlay__SEGoS{align-items:center;backdrop-filter:blur(10px);background:rgba(0,132,255,.1);border:2px dashed rgba(0,132,255,.5);border-radius:12px;bottom:0;display:flex;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:20}.Chat-module_dragOverlayContent__gb9kF{align-items:center;color:#0084ff;display:flex;flex-direction:column;font-weight:600;gap:12px;text-align:center}.Chat-module_dragOverlayContent__gb9kF svg{opacity:.7}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea{-webkit-tap-highlight-color:transparent;appearance:none;-webkit-appearance:none;backdrop-filter:blur(20px);background:hsla(0,0%,49%,.05);border-radius:25px;color:#000;flex:1;font-size:15px;line-height:1.4;max-height:120px;min-width:200px;outline:none;padding:16px 20px;resize:none;touch-action:manipulation;transition:all .3s cubic-bezier(.25,.46,.45,.94)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea:focus{background:hsla(0,0%,49%,.08);border-color:#0084ff;box-shadow:0 0 0 4px rgba(0,132,255,.1),0 8px 32px rgba(0,132,255,.15);transform:translateY(-2px)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea:disabled{cursor:not-allowed;opacity:.6;transform:none}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea::placeholder{color:inherit;opacity:.7}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button{-webkit-tap-highlight-color:transparent;align-items:center;aspect-ratio:1/1;background:linear-gradient(135deg,#0084ff,#06c);border:none;border-radius:50%!important;box-shadow:0 4px 16px rgba(0,132,255,.3);color:#fff;display:flex;height:48px;justify-content:center;margin:0!important;min-height:unset!important;min-width:unset!important;overflow:visible;padding:0!important;padding-left:unset;padding-right:unset;touch-action:manipulation;transition:all .3s cubic-bezier(.25,.46,.45,.94);user-select:none;width:48px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button img{height:100%;object-fit:contain;width:50%}.Chat-module_scrollToBottomContainer__5rXpK{align-items:flex-start;display:flex;grid-area:📝;height:100%;justify-content:center;pointer-events:none;width:100%;z-index:20}.Chat-module_scrollToBottomContainer__5rXpK .Chat-module_scrollToBottom__nzxdZ{-webkit-tap-highlight-color:transparent;align-items:center;animation:Chat-module_scrollButtonSlideIn__XnImg .3s ease-out;backdrop-filter:blur(3px);background:rgba(0,0,0,.5);border:none;border-radius:50%;box-shadow:0 4px 16px rgba(0,0,0,.3);color:#fff;cursor:pointer;display:flex;font-weight:700;height:48px;justify-content:center;outline:none;pointer-events:all;touch-action:manipulation;transform:translate(-50%,-150%);transition:all .3s cubic-bezier(.25,.46,.45,.94);user-select:none;width:48px}@keyframes Chat-module_scrollButtonSlideIn__XnImg{0%{opacity:0;transform:translate(-50%,20px) scale(.8)}to{opacity:.9;transform:translate(-50%) scale(1)}}.Chat-module_scrollToBottom__nzxdZ:hover{transform:translate(-50%,-160%) scale(1.05)}.Chat-module_scrollToBottom__nzxdZ:active{transform:translate(-50%,-160%) scale(.95);transition:transform .1s ease}.Chat-module_ratingModal__XVKYm{align-items:center;animation:Chat-module_modalFadeIn__RPc3w .3s ease-out;backdrop-filter:blur(8px);background-color:rgba(0,0,0,.6);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes Chat-module_modalFadeIn__RPc3w{0%{backdrop-filter:blur(0);opacity:0}to{backdrop-filter:blur(8px);opacity:1}}.Chat-module_ratingModalContent__CCdq7{animation:Chat-module_modalSlideIn__XXtgN .3s cubic-bezier(.25,.46,.45,.94);backdrop-filter:blur(20px);background:#fff;border:1px solid hsla(0,0%,49%,.1);border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3);color:#0f1724;font-family:Arial,Helvetica,sans-serif,OpenMojiBlack;max-width:480px;padding:32px;width:90%}@keyframes Chat-module_modalSlideIn__XXtgN{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.Chat-module_ratingModalContent__CCdq7 h3{color:#000;font-size:20px;font-weight:600;margin:0 0 24px;text-align:center}.Chat-module_stars__PCzNO{display:flex;gap:8px;justify-content:center;margin-bottom:24px}.Chat-module_stars__PCzNO span{border-radius:8px;cursor:pointer;font-size:28px;padding:4px;transition:all .2s ease}.Chat-module_stars__PCzNO span:hover{background:rgba(255,215,0,.1);transform:scale(1.2)}.Chat-module_ratingModalStar__XkbHr{cursor:pointer;font-size:24px;transition:color .2s}.Chat-module_ratingInput__z8Pv-{background:hsla(0,0%,49%,.05);border:2px solid hsla(0,0%,49%,.1);border-radius:12px;color:#0b1220;font-size:14px;line-height:1.5;margin-bottom:18px;min-height:100px;padding:16px;resize:vertical;transition:all .2s ease;width:100%}.Chat-module_ratingInput__z8Pv-:focus{background:hsla(0,0%,49%,.08);border-color:#0084ff;box-shadow:0 0 0 4px rgba(0,132,255,.1);outline:none}.Chat-module_ratingInput__z8Pv-[readonly]{background:hsla(0,0%,49%,.01);border:1px solid hsla(0,0%,49%,.5)}.Chat-module_ratingActions__nXcss{display:flex;gap:12px;justify-content:flex-end}.Chat-module_ratingActions__nXcss button{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;min-width:80px;padding:12px 24px;transition:all .2s ease}.Chat-module_ratingActions__nXcss button:first-child{background-color:hsla(0,0%,49%,.1);border:1px solid hsla(0,0%,49%,.2);color:#0b1220}.Chat-module_ratingActions__nXcss button:first-child:hover:not(:disabled){background-color:hsla(0,0%,49%,.2);color:#0b1220}.Chat-module_ratingActions__nXcss button:last-child{background:linear-gradient(135deg,#0084ff,#06c);color:#fff}.Chat-module_ratingActions__nXcss button:last-child:hover:not(:disabled){background:linear-gradient(135deg,#0071d1,#0052a3);box-shadow:0 4px 12px rgba(0,132,255,.3);transform:translateY(-1px)}.Chat-module_ratingActions__nXcss button:last-child:disabled{cursor:not-allowed;opacity:.5}.Chat-module_chatButton__d9VgA{-webkit-tap-highlight-color:transparent!important;align-items:center!important;backdrop-filter:blur(20px)!important;background:linear-gradient(135deg,#0084ff,#06c)!important;border:none!important;border-radius:20px!important;box-shadow:0 4px 16px rgba(0,132,255,.3)!important;color:#fff!important;cursor:pointer!important;display:inline-flex!important;font-size:13px!important;font-weight:600!important;gap:8px!important;justify-content:center!important;line-height:1.3!important;margin:0!important;min-height:40px!important;min-width:110px!important;overflow:hidden!important;padding:12px 16px!important;position:relative!important;touch-action:manipulation!important;transition:all .3s cubic-bezier(.25,.46,.45,.94)!important;user-select:none!important}.Chat-module_chatButton__d9VgA:before{background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.2),transparent);content:\"\";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.Chat-module_chatButton__d9VgA:hover:before{left:100%}.Chat-module_chatButton__d9VgA:hover:not(:disabled){background:linear-gradient(135deg,#09f,#07d);box-shadow:0 8px 24px rgba(0,132,255,.4);transform:translateY(-2px) scale(1.02)}.Chat-module_chatButton__d9VgA:active{box-shadow:0 4px 16px rgba(0,132,255,.3);transform:scale(.98) translateY(-1px);transition:transform .1s ease}.Chat-module_chatButton__d9VgA:focus{box-shadow:0 4px 16px rgba(0,132,255,.3),0 0 0 3px rgba(0,132,255,.3);outline:none}.Chat-module_chatButton__d9VgA svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.2));flex-shrink:0;height:16px;opacity:1;transition:all .3s cubic-bezier(.25,.46,.45,.94);width:16px}.Chat-module_chatButton__d9VgA:hover svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));transform:rotate(-90deg) scale(1.1)}.Chat-module_chatButtonText__RkGB-{font-weight:600;opacity:1;text-shadow:0 1px 2px rgba(0,0,0,.1);transition:all .2s ease;white-space:nowrap}.Chat-module_chatButton__d9VgA:hover .Chat-module_chatButtonText__RkGB-{transform:translateX(1px)}.Chat-module_useTemplateButton__xcJNR{-webkit-tap-highlight-color:transparent!important;align-items:center!important;backdrop-filter:blur(20px)!important;background:linear-gradient(135deg,#0084ff,#06c)!important;border:none!important;border-radius:20px!important;box-shadow:0 4px 16px rgba(0,132,255,.3)!important;color:#fff!important;cursor:pointer!important;display:inline-flex!important;font-size:13px!important;font-weight:600!important;gap:8px!important;justify-content:center!important;line-height:1.3!important;margin:0!important;min-height:40px!important;min-width:110px!important;overflow:hidden!important;padding:12px 16px!important;position:relative!important;touch-action:manipulation!important;transition:all .3s cubic-bezier(.25,.46,.45,.94)!important;user-select:none!important}.Chat-module_useTemplateButton__xcJNR:before{background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.2),transparent);content:\"\";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.Chat-module_useTemplateButton__xcJNR:hover:before{left:100%}.Chat-module_useTemplateButton__xcJNR:hover:not(:disabled){background:linear-gradient(135deg,#09f,#07d);box-shadow:0 8px 24px rgba(0,132,255,.4);transform:translateY(-2px) scale(1.02)}.Chat-module_useTemplateButton__xcJNR:active{box-shadow:0 4px 16px rgba(0,132,255,.3);transform:scale(.98) translateY(-1px);transition:transform .1s ease}.Chat-module_useTemplateButton__xcJNR:focus{box-shadow:0 4px 16px rgba(0,132,255,.3),0 0 0 3px rgba(0,132,255,.3);outline:none}.Chat-module_useTemplateButton__xcJNR svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.2));flex-shrink:0;height:16px;opacity:1;transition:all .3s cubic-bezier(.25,.46,.45,.94);width:16px}.Chat-module_useTemplateButton__xcJNR:hover svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));transform:scale(1.1)}.Chat-module_useTemplateButton__xcJNR:hover .Chat-module_chatButtonText__RkGB-{transform:translateX(1px)}.Chat-module_saveButtonContainer__lSNUJ{display:inline-block;position:relative}.Chat-module_saveMenu__-ph8y{background:#fff;border:1px solid #ddd;box-shadow:0 2px 8px rgba(0,0,0,.08);left:0;min-width:120px;position:absolute;top:100%;z-index:10}.Chat-module_saveMenuItem__ISApL{background:none;border:none;color:#111;cursor:pointer;display:block;padding:8px 16px;text-align:left;width:100%}.Chat-module_saveMenuItem__ISApL:hover{background-color:#f0f0f0}.Chat-module_pauseButton__eeu7K{background:linear-gradient(135deg,#ffb347,#ff8c42)!important}.Chat-module_pauseButton__eeu7K:hover:not(:disabled){background:linear-gradient(135deg,#ffc067,#ff9e5f)!important}.Chat-module_pauseButton__eeu7K.Chat-module_pausing__pTx8b{cursor:wait!important;opacity:.6!important}.Chat-module_pauseButton__eeu7K.Chat-module_paused__j-pya{background:linear-gradient(135deg,#10b981,#059669)!important}.Chat-module_pauseButton__eeu7K.Chat-module_paused__j-pya:hover:not(:disabled){background:linear-gradient(135deg,#34d399,#059669)!important;box-shadow:0 8px 24px rgba(16,185,129,.35);transform:translateY(-2px) scale(1.02)}.Chat-module_pauseButton__eeu7K svg{transition:transform .3s ease}.Chat-module_pauseButton__eeu7K.Chat-module_paused__j-pya svg{transform:scale(1.1)}.Chat-module_pauseButton__eeu7K.Chat-module_pausing__pTx8b svg{opacity:.8}.Chat-module_voiceCallIndicatorBar__N2sWN{align-items:center;backdrop-filter:blur(10px);background:linear-gradient(135deg,rgba(34,197,94,.1),rgba(16,185,129,.1));border-bottom:1px solid rgba(34,197,94,.3);display:flex;grid-area:🟦;justify-content:center;padding:12px 20px;width:100%}.Chat-module_voiceCallIndicator__tsaaG{align-items:center;backdrop-filter:blur(10px);background:linear-gradient(135deg,rgba(34,197,94,.2),rgba(16,185,129,.2));border:1px solid rgba(34,197,94,.4);border-radius:20px;box-shadow:0 2px 8px rgba(34,197,94,.2);color:#10b981;display:inline-flex;font-size:13px;font-weight:600;gap:8px;padding:8px 16px;position:relative}.Chat-module_voiceCallIndicator__tsaaG svg{animation:Chat-module_voiceCallIconPulse__zZbJn 2s ease-in-out infinite;flex-shrink:0;height:16px;width:16px}.Chat-module_voiceCallIndicator__tsaaG span{font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.1)}.Chat-module_voiceCallPulse__XcGU4{animation:Chat-module_voiceCallPulse__XcGU4 1.5s ease-in-out infinite;background:#10b981;border-radius:50%;height:8px;position:absolute;right:8px;top:50%;transform:translateY(-50%);width:8px}@keyframes Chat-module_voiceCallIconPulse__zZbJn{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}@keyframes Chat-module_voiceCallPulse__XcGU4{0%,to{opacity:1;transform:translateY(-50%) scale(1)}50%{opacity:.6;transform:translateY(-50%) scale(1.3)}}.Chat-module_chatMessage__nmLaZ .Chat-module_voiceCallIndicator__tsaaG{border-radius:16px;font-size:12px;margin-bottom:8px;padding:6px 12px}.Chat-module_chatMessage__nmLaZ .Chat-module_voiceCallIndicator__tsaaG svg{height:14px;width:14px}.Chat-module_ratingConfirmation__n16vb{word-wrap:break-word;animation:Chat-module_confirmationSlideIn__5U-wz .3s ease-out;backdrop-filter:blur(20px);background:linear-gradient(135deg,#10b981,#059669);border-radius:12px;box-shadow:0 8px 32px rgba(16,185,129,.3);color:#fff;font-weight:500;max-width:300px;padding:16px 20px;position:fixed;right:20px;top:20px;z-index:1001}@keyframes Chat-module_confirmationSlideIn__5U-wz{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@media (max-width:768px){.Chat-module_actions__gTZ5T{gap:6px;margin:12px 16px 0}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N{padding:16px 12px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ{margin-bottom:16px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{border-radius:18px;font-size:14px;max-width:85%;padding:12px 16px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm{height:36px;margin:0 10px 4px;width:36px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img{aspect-ratio:1/1;width:36px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan{gap:10px;padding:16px 12px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea{border-radius:22px;font-size:16px;padding:14px 18px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button{height:44px;width:44px}.Chat-module_scrollToBottom__nzxdZ{font-size:18px;height:44px;top:calc(100% - 160px);width:44px}.Chat-module_chatButton__d9VgA{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_chatButton__d9VgA svg{height:18px!important;width:18px!important}.Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_useTemplateButton__xcJNR{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_useTemplateButton__xcJNR svg{height:18px!important;width:18px!important}.Chat-module_useTemplateButton__xcJNR .Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_ratingModalContent__CCdq7{border-radius:16px;margin:16px;max-height:80vh;overflow-y:auto;padding:24px 20px}.Chat-module_stars__PCzNO{gap:6px;margin-bottom:20px}.Chat-module_stars__PCzNO span{font-size:32px;padding:8px}.Chat-module_ratingActions__nXcss{flex-direction:column-reverse;gap:8px}.Chat-module_ratingActions__nXcss button{border-radius:10px;font-size:16px;padding:14px;width:100%}}@media (max-width:480px){.Chat-module_actions__gTZ5T{gap:4px;margin:8px 12px 0}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N{padding:12px 8px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{border-radius:16px;font-size:14px;max-width:90%;padding:10px 14px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm{height:32px;margin:0 8px 4px;width:32px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img{aspect-ratio:1/1;width:32px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan{gap:8px;padding:12px 8px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea{border-radius:20px;font-size:16px;padding:12px 16px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button{height:40px;width:40px}.Chat-module_chatButton__d9VgA{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_chatButton__d9VgA svg{height:18px!important;width:18px!important}.Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_useTemplateButton__xcJNR{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_useTemplateButton__xcJNR svg{height:18px!important;width:18px!important}.Chat-module_useTemplateButton__xcJNR .Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_scrollToBottom__nzxdZ{font-size:16px;height:40px;top:calc(100% - 140px);width:40px}.Chat-module_ratingModal__XVKYm{align-items:flex-end;padding:0}.Chat-module_ratingModalContent__CCdq7{border-radius:20px 20px 0 0;margin:0;max-height:70vh;padding:24px 16px 20px;width:100%}}@media (prefers-reduced-motion:reduce){.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ,.Chat-module_ratingConfirmation__n16vb,.Chat-module_ratingModalContent__CCdq7,.Chat-module_ratingModal__XVKYm,.Chat-module_scrollToBottom__nzxdZ{animation:none}.Chat-module_chatButton__d9VgA,.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button,.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea,.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img,.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{transition:none}}@media (prefers-contrast:high){.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{border:2px solid}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea{border-width:3px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button{border:2px solid}}\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["Chat.module.css"],"names":[],"mappings":"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","file":"Chat.module.css","sourcesContent":["@font-face {\n    font-family: 'OpenMojiBlack';\n    src: url('https://s6.ptbk.io/fonts/OpenMoji-black-glyf.woff2') format('woff2'); /* <- TODO: [🐱‍🚀] Dynamically load from /servers.ts */\n    unicode-range: U+23, U+2A, U+2D, U+30-39, U+A9, U+AE, U+200D, U+203C, U+2049, U+20E3, U+2117, U+2120, U+2122, U+2139,\n        U+2194-2199, U+21A9, U+21AA, U+229C, U+231A, U+231B, U+2328, U+23CF, U+23E9-23F3, U+23F8-23FE, U+24C2, U+25A1,\n        U+25AA-25AE, U+25B6, U+25C0, U+25C9, U+25D0, U+25D1, U+25E7-25EA, U+25ED, U+25EE, U+25FB-25FE, U+2600-2605,\n        U+260E, U+2611, U+2614, U+2615, U+2618, U+261D, U+2620, U+2622, U+2623, U+2626, U+262A, U+262E, U+262F,\n        U+2638-263A, U+2640, U+2642, U+2648-2653, U+265F, U+2660, U+2663, U+2665, U+2666, U+2668, U+267B, U+267E, U+267F,\n        U+2691-2697, U+2699, U+269B, U+269C, U+26A0, U+26A1, U+26A7, U+26AA, U+26AB, U+26B0, U+26B1, U+26BD, U+26BE,\n        U+26C4, U+26C5, U+26C8, U+26CE, U+26CF, U+26D1, U+26D3, U+26D4, U+26E9, U+26EA, U+26F0-26F5, U+26F7-26FA, U+26FD,\n        U+2702, U+2705, U+2708-270D, U+270F, U+2712, U+2714, U+2716, U+271D, U+2721, U+2728, U+2733, U+2734, U+2744,\n        U+2747, U+274C, U+274E, U+2753-2755, U+2757, U+2763, U+2764, U+2795-2797, U+27A1, U+27B0, U+27BF, U+2934, U+2935,\n        U+2B05-2B07, U+2B0C, U+2B0D, U+2B1B, U+2B1C, U+2B1F-2B24, U+2B2E, U+2B2F, U+2B50, U+2B55, U+2B58, U+2B8F,\n        U+2BBA-2BBC, U+2BC3, U+2BC4, U+2BEA, U+2BEB, U+3030, U+303D, U+3297, U+3299, U+E000-E009, U+E010, U+E011,\n        U+E040-E06D, U+E080-E0B4, U+E0C0-E0CC, U+E0FF-E10D, U+E140-E14A, U+E150-E157, U+E181-E189, U+E1C0-E1C4,\n        U+E1C6-E1D9, U+E200-E216, U+E240-E269, U+E280-E283, U+E2C0-E2C4, U+E2C6-E2DA, U+E300-E303, U+E305-E30F,\n        U+E312-E316, U+E318-E322, U+E324-E329, U+E32B, U+E340-E348, U+E380, U+E381, U+F000, U+F77A, U+F8FF, U+FE0F,\n        U+1F004, U+1F0CF, U+1F10D-1F10F, U+1F12F, U+1F16D-1F171, U+1F17E, U+1F17F, U+1F18E, U+1F191-1F19A, U+1F1E6-1F1FF,\n        U+1F201, U+1F202, U+1F21A, U+1F22F, U+1F232-1F23A, U+1F250, U+1F251, U+1F260-1F265, U+1F300-1F321, U+1F324-1F393,\n        U+1F396, U+1F397, U+1F399-1F39B, U+1F39E-1F3F0, U+1F3F3-1F3F5, U+1F3F7-1F4FD, U+1F4FF-1F53D, U+1F549-1F54E,\n        U+1F550-1F567, U+1F56F, U+1F570, U+1F573-1F57A, U+1F587, U+1F58A-1F58D, U+1F590, U+1F595, U+1F596, U+1F5A4,\n        U+1F5A5, U+1F5A8, U+1F5B1, U+1F5B2, U+1F5BC, U+1F5C2-1F5C4, U+1F5D1-1F5D3, U+1F5DC-1F5DE, U+1F5E1, U+1F5E3,\n        U+1F5E8, U+1F5EF, U+1F5F3, U+1F5FA-1F64F, U+1F680-1F6C5, U+1F6CB-1F6D2, U+1F6D5-1F6D7, U+1F6DC-1F6E5, U+1F6E9,\n        U+1F6EB, U+1F6EC, U+1F6F0, U+1F6F3-1F6FC, U+1F7E0-1F7EB, U+1F7F0, U+1F90C-1F93A, U+1F93C-1F945, U+1F947-1F9FF,\n        U+1FA70-1FA7C, U+1FA80-1FA88, U+1FA90-1FABD, U+1FABF-1FAC5, U+1FACE-1FADB, U+1FAE0-1FAE8, U+1FAF0-1FAF8,\n        U+1FBC5-1FBC9, U+E0061-E0067, U+E0069, U+E006C-E0079, U+E007F;\n}\n\n.copiedToClipboardMessage {\n    position: fixed;\n    top: 32px;\n    left: 50%;\n    transform: translateX(-50%);\n    background: #222;\n    color: #fff;\n    padding: 10px 24px;\n    border-radius: 8px;\n    font-size: 1.1em;\n    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.18);\n    opacity: 0.97;\n    pointer-events: none;\n    z-index: 9999;\n}\n\n.Chat {\n    width: 100%;\n    height: 100%;\n    display: flex;\n    flex-direction: column;\n\n    font-family: Arial, Helvetica, sans-serif, 'OpenMojiBlack';\n    /* <- TODO: [🧠][🎱] Better, define other fonts */\n}\n\n.chatMainFlow {\n    width: 100%;\n    height: 100%;\n    max-width: 100vw;\n    display: grid;\n    grid-template:\n        '🟦' min-content\n        '💬' 1fr\n        '📝' min-content\n        / 1fr;\n}\n\n.chatMainFlow .chatBar {\n    grid-area: 🟦;\n    width: 100%;\n    padding: 16px 20px;\n    color: #0f1724;\n    background-color: #ffffff;\n    border-bottom: 1px solid rgba(15, 23, 36, 0.06);\n    text-align: center;\n    font-weight: 500;\n}\n\n.TasksInProgress {\n    grid-area: 🟦;\n    width: auto;\n    height: min-content;\n    align-self: center;\n    justify-self: self-end;\n    margin: 8px 16px;\n}\n\n.actions {\n    grid-area: 💬;\n    width: auto;\n    height: min-content;\n    z-index: 200;\n    align-self: self-start;\n    justify-self: self-end;\n   margin: 16px 20px 0;\n    display: flex;\n    align-items: center;\n    gap: 8px;\n}\n\n.actions.portal{\nmargin: 0;\n}\n\n.actions.left {\n    justify-self: self-start;\n}\n\n.actions.right {\n    justify-self: self-end;\n}\n\n/* Large tablet and small desktop screens */\n@media (max-width: 900px) {\n    .chatButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .chatButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .chatButtonText {\n        display: none !important;\n    }\n\n    .useTemplateButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .useTemplateButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .useTemplateButton .chatButtonText {\n        display: none !important;\n    }\n}\n\n/* Medium screens */\n@media (max-width: 600px) {\n    .actions {\n        margin: 14px 18px 0;\n        gap: 7px;\n    }\n}\n\n.chatMainFlow .chatChildren {\n    grid-area: 💬;\n    width: 100%;\n    height: 100%;\n    z-index: 300;\n}\n\n/* Chat messages area */\n.chatMainFlow .chatMessages {\n    grid-area: 💬;\n    width: 100%;\n    height: 100%;\n    z-index: 10;\n    padding: 24px 20px 16px;\n    overflow-y: auto;\n    overflow-x: hidden;\n    scroll-behavior: smooth;\n}\n\n/* Custom scrollbar styling */\n.chatMainFlow .chatMessages::-webkit-scrollbar {\n    width: 6px;\n}\n\n.chatMainFlow .chatMessages::-webkit-scrollbar-track {\n    background: transparent;\n}\n\n.chatMainFlow .chatMessages::-webkit-scrollbar-thumb {\n    background: rgba(125, 125, 125, 0.2);\n    border-radius: 3px;\n    transition: all 0.2s ease;\n}\n\n.chatMainFlow .chatMessages::-webkit-scrollbar-thumb:hover {\n    background: rgba(125, 125, 125, 0.3);\n}\n\n/* Individual chat message */\n.chatMainFlow .chatMessage {\n    display: flex;\n    margin-bottom: 20px;\n    align-items: flex-end;\n    flex-direction: row;\n    position: relative;\n    animation: messageSlideIn 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    max-width: 100%;\n}\n\n/* Add top margin to first message if actions are present and first message is long */\n.hasActionsAndFirstMessageIsLong {\n    margin-top: 55px;\n}\n\n@keyframes messageSlideIn {\n    from {\n        opacity: 0;\n        transform: translateY(20px) scale(0.95);\n    }\n    to {\n        opacity: 1;\n        transform: translateY(0) scale(1);\n    }\n}\n\n.isNotCompleteMessage {\n    /*/\n    outline: 1px dotted #ff0000 !important;\n    /**/\n\n    opacity: 0.7;\n    position: relative;\n}\n\n.NonCompleteMessageFiller {\n    color: transparent;\n}\n\n/* Enhanced loading states for messages */\n.isNotCompleteMessage .messageText::after {\n    content: '';\n    position: absolute;\n    bottom: 8px;\n    right: 12px;\n    width: 20px;\n    height: 4px;\n    background: linear-gradient(90deg, transparent, rgba(125, 125, 125, 0.6), transparent);\n    border-radius: 2px;\n    animation: loadingPulse 1.5s ease-in-out infinite;\n}\n\n@keyframes loadingPulse {\n    0%,\n    100% {\n        opacity: 0.3;\n        transform: scaleX(0.8);\n    }\n    50% {\n        opacity: 1;\n        transform: scaleX(1.2);\n    }\n}\n\n/* Typing indicator for AI messages */\n.typingIndicator {\n    display: flex;\n    align-items: flex-end;\n    margin-bottom: 20px;\n    animation: messageSlideIn 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n\n.typingIndicator .avatar {\n    width: 40px;\n    height: 40px;\n    margin: 0 12px 4px;\n    flex-shrink: 0;\n}\n\n.typingIndicator .avatar img {\n    width: 40px;\n    aspect-ratio: 1 / 1;\n    border-radius: 50%;\n    object-fit: cover;\n    background-color: #eef6fb;\n    border: 2px solid rgba(125, 125, 125, 0.1);\n}\n\n.typingBubble {\n    padding: 16px 20px;\n    border-radius: 20px;\n    border-bottom-left-radius: 6px;\n    border: 1px solid rgba(125, 125, 125, 0.1);\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);\n    backdrop-filter: blur(10px);\n    display: flex;\n    align-items: center;\n    gap: 4px;\n    min-height: 24px;\n}\n\n.typingDots {\n    display: flex;\n    gap: 4px;\n    align-items: center;\n}\n\n.typingDot {\n    width: 8px;\n    height: 8px;\n    border-radius: 50%;\n    background: linear-gradient(135deg, #6b7280 0%, rgba(125, 125, 125, 0.6) 100%);\n    animation: typingBounce 1.4s infinite ease-in-out;\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n}\n\n.typingDot:nth-child(1) {\n    animation-delay: -0.32s;\n}\n\n.typingDot:nth-child(2) {\n    animation-delay: -0.16s;\n}\n\n.typingDot:nth-child(3) {\n    animation-delay: 0s;\n}\n\n@keyframes typingBounce {\n    0%,\n    80%,\n    100% {\n        transform: scale(0.8) translateY(0);\n        opacity: 0.5;\n    }\n    40% {\n        transform: scale(1.2) translateY(-8px);\n        opacity: 1;\n    }\n}\n\n.chatMainFlow .chatMessage.isMe {\n    align-items: flex-end;\n    flex-direction: row-reverse;\n    justify-content: flex-start;\n}\n\n.chatMainFlow .chatMessage.isMe .messageText {\n    border-bottom-right-radius: 6px;\n}\n\n.ratingStar {\n    cursor: pointer;\n    font-size: 20px;\n    transition: color 0.2s;\n    color: var(--star-inactive-color, #ccc);\n}\n\n.ratingStar.active {\n    color: #ffd700;\n}\n\n/* Sender Avatar */\n.chatMainFlow .chatMessage .avatar {\n    width: 40px;\n    aspect-ratio: 1 / 1;\n    margin: 0 12px 4px;\n    flex-shrink: 0;\n    position: relative;\n}\n\n.chatMainFlow .chatMessage .avatar img {\n    width: 40px;\n    aspect-ratio: 1 / 1;\n    border-radius: 50%;\n    object-fit: cover;\n    background-color: var(--avatar-bg-color, #eef6fb);\n    border: 2px solid rgba(125, 125, 125, 0.1);\n    transition: transform 0.2s ease, box-shadow 0.2s ease;\n}\n\n.chatMainFlow .chatMessage .avatar img:hover {\n    transform: scale(1.05);\n    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n}\n\n/* Message text bubble */\n.chatMainFlow .chatMessage .messageText {\n    background-color: var(--message-bg-color);\n    color: var(--message-text-color);\n    position: relative;\n    padding: 14px 18px;\n    border-radius: 20px;\n    max-width: min(70%, 600px);\n    text-align: left;\n    margin-bottom: 4px;\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);\n    line-height: 1.5;\n    word-wrap: break-word;\n    transition: all 0.2s ease;\n    font-size: 15px;\n    backdrop-filter: blur(10px);\n}\n\n/* Copy button styles */\n.copyButtonContainer {\n    float: right;\n    top: 8px;\n    right: 10px;\n    z-index: 2;\n    align-items: center;\n    justify-content: flex-end;\n    pointer-events: none;\n\n    visibility: hidden;\n}\n.chatMainFlow .chatMessage .messageText:hover .copyButtonContainer,\n.copyButtonContainer:focus-within {\n    visibility: visible;\n    pointer-events: auto;\n}\n\n.copyButton {\n    background: rgba(255, 255, 255, 0.2);\n    border: 1px solid #ddd;\n    border-radius: 6px;\n    padding: 2px 5px;\n    cursor: pointer;\n    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.07);\n    transition: all 0.15s, box-shadow 0.15s, border 0.15s;\n    display: flex;\n    align-items: center;\n    opacity: 0.7;\n    position: relative;\n}\n\n.copiedTooltip {\n    position: absolute;\n    left: 50%;\n    top: 110%;\n    transform: translateX(-50%);\n    background: #222;\n    color: #fff;\n    padding: 6px 16px;\n    border-radius: 8px;\n    font-size: 0.98em;\n    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.18);\n    opacity: 0.97;\n    pointer-events: none;\n    z-index: 100;\n    white-space: nowrap;\n    margin-top: 4px;\n    animation: copiedTooltipFadeIn 0.2s;\n    max-width: 220px;\n    overflow-wrap: break-word;\n    word-break: break-word;\n}\n\n.copiedTooltipLeft {\n    left: 0 !important;\n    transform: none !important;\n}\n\n.copiedTooltipRight {\n    left: auto !important;\n    right: 0 !important;\n    transform: none !important;\n}\n\n/* Removed right-aligned override to keep tooltip position stable */\n\n@keyframes copiedTooltipFadeIn {\n    from {\n        opacity: 0;\n        transform: translateX(-50%) translateY(8px) scale(0.97);\n    }\n    to {\n        opacity: 0.97;\n        transform: translateX(-50%) translateY(0) scale(1);\n    }\n}\n\n.copyButton:hover,\n.copyButton:focus {\n    border: 1.5px solid #bbb;\n    opacity: 1;\n    box-shadow: 0 2px 8px rgba(0, 132, 255, 0.1);\n}\n\n.copyButton svg {\n    display: block;\n}\n\n.messageText h1 {\n    font-size: 2em;\n}\n\n.messageText h2 {\n    font-size: 1.75em;\n}\n\n.messageText h3 {\n    font-size: 1.5em;\n}\n\n.messageText h4 {\n    font-size: 1.25em;\n}\n\n.messageText h5 {\n    font-size: 1.1em;\n}\n\n.messageText ul {\n    list-style: disc;\n    margin-left: 20px;\n}\n\n.messageText ol {\n    list-style: decimal;\n    margin-left: 20px;\n}\n\n.messageText img,\n.messageText pre,\n.messageText blockquote,\n.messageText table {\n    margin-top: 10px;\n    margin-bottom: 10px;\n    border-radius: 8px;\n}\n\n.messageText pre {\n    display: block;\n    border: none;\n    box-shadow: none;\n    background: #000000ff;\n    font-size: inherit;\n    line-height: inherit;\n    color: #fff;\n    padding: 1em;\n}\n\n.messageText blockquote {\n    display: block;\n    border: none;\n    box-shadow: none;\n    background: #ffffffcc;\n    font-size: inherit;\n    line-height: inherit;\n    color: #000;\n    padding: 1em;\n}\n\n.messageText code {\n    display: inline-block;\n    margin: 0;\n    padding: 0;\n    border: none;\n    box-shadow: none;\n    background: #cccccc55;\n    font-size: inherit;\n    line-height: inherit;\n    color: inherit;\n}\n\n.messageText pre code {\n    background-color: #000000cc;\n    border-radius: 8px;\n}\n\n.messageText .chat-code-block {\n    background: #181c23;\n    color: #f8fafc;\n    font-size: 14px;\n    line-height: 1.6;\n    overflow-x: auto;\n    border-color: #23272f;\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);\n    font-family: 'Fira Mono', 'Menlo', 'Consolas', 'Liberation Mono', monospace;\n}\n.messageText .chat-code-block code {\n    background: none !important;\n    color: inherit !important;\n    font-family: inherit !important;\n    font-size: inherit !important;\n    padding: 0 !important;\n    border: none !important;\n    box-shadow: none !important;\n    white-space: pre;\n    word-break: break-word;\n    overflow-x: auto;\n    display: block;\n}\n.messageText table {\n    width: 100%;\n    border-collapse: separate;\n    border-spacing: 0;\n    margin: 16px 0;\n    background: #f8fafc; /* Stronger light background for contrast */\n    border-radius: 12px;\n    overflow: hidden;\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);\n    font-size: 14px;\n    color: #17223b; /* Dark text for contrast */\n}\n.messageText th,\n.messageText td {\n    padding: 10px 16px;\n    border-bottom: 1px solid #d1dbe8;\n    text-align: left;\n    color: #17223b; /* Ensure strong text color for all cells */\n    background: none;\n}\n.messageText th {\n    background: linear-gradient(90deg, #eaf3fa 80%, #d1e3f8 100%);\n    font-weight: 700;\n    color: #17223b; /* Strong header text */\n    border-bottom: 2px solid #b5c7de;\n}\n.messageText tr:last-child td {\n    border-bottom: none;\n}\n.messageText tr:nth-child(even) td {\n    background: #eaf3fa;\n}\n.messageText tr:hover td {\n    background: #cbe0f7;\n    transition: background 0.2s;\n}\n.messageText table {\n    border-radius: 12px;\n    overflow: hidden;\n}\n.messageText th:first-child,\n.messageText td:first-child {\n    border-top-left-radius: 12px;\n}\n.messageText th:last-child,\n.messageText td:last-child {\n    border-top-right-radius: 12px;\n}\n\n.chatMainFlow .chatMessage .messageText:hover {\n    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);\n    transform: translateY(-1px);\n}\n\n/* Message buttons container */\n.messageButtons {\n    display: flex;\n    flex-wrap: wrap;\n    gap: 8px;\n    margin-top: 12px;\n    padding-top: 12px;\n    border-top: 1px solid rgba(125 125 125 / 0.83);\n}\n\n/* Individual message button */\n.messageButton {\n    display: inline-flex;\n    align-items: center;\n    padding: 8px 14px;\n    background: rgba(125, 125, 125, 0.1);\n    border: 1px solid rgba(125, 125, 125, 0.9);\n    border-radius: 16px;\n    font-size: 13px;\n    font-weight: 500;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    backdrop-filter: blur(10px);\n    -webkit-tap-highlight-color: transparent;\n    touch-action: manipulation;\n    user-select: none;\n}\n\n.messageButton:hover {\n    background: rgba(0, 132, 255, 0.1);\n    border-color: rgba(0, 132, 255, 0.3);\n    transform: translateY(-1px);\n    box-shadow: 0 2px 8px rgba(0, 132, 255, 0.15);\n}\n\n.messageButton:active {\n    transform: scale(0.98);\n    transition: transform 0.1s ease;\n}\n\n/* Remove default markdown styles from button content */\n.messageButton p {\n    margin: 0;\n    padding: 0;\n    line-height: inherit;\n}\n\n.messageButton strong {\n    font-weight: 600;\n}\n\n.messageButton em {\n    font-style: italic;\n}\n\n/* Rating system */\n.chatMainFlow .chatMessage .rating {\n    position: absolute;\n    bottom: -8px;\n    right: 8px;\n    display: flex;\n    gap: 2px;\n    align-items: center;\n    min-width: 24px;\n    z-index: 1;\n    background: rgba(0, 0, 0, 0.8);\n    border-radius: 12px;\n    padding: 4px 6px;\n    backdrop-filter: blur(10px);\n    opacity: 0;\n    transform: translateY(4px);\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n\n.chatMainFlow .chatMessage:hover .rating {\n    opacity: 1;\n    transform: translateY(0);\n}\n\n.chatMainFlow .chatMessage .rating:hover {\n    background: rgba(0, 0, 0, 0.9);\n    padding: 6px 8px;\n    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);\n}\n\n.chatMainFlow .chatMessage .rating span {\n    transition: transform 0.2s ease, color 0.2s ease;\n    display: inline-block;\n    cursor: pointer;\n    font-size: 16px;\n}\n\n.chatMainFlow .chatMessage .rating:hover span {\n    transform: scale(1.1);\n}\n\n/* Chat input area */\n.chatMainFlow .chatInput {\n    z-index: 10;\n    grid-area: 📝;\n    width: 100%;\n    padding: 20px;\n    backdrop-filter: blur(20px);\n    border-top: 1px solid rgba(125, 125, 125, 0.1);\n    display: flex;\n    flex-direction: column;\n    gap: 12px;\n    position: relative;\n}\n\n/* File upload drag-and-drop styles */\n.chatMainFlow .chatInput.dragOver {\n    background: linear-gradient(to top, rgba(0, 132, 255, 0.1) 0%, rgba(0, 132, 255, 0.05) 100%);\n    border-top: 2px solid rgba(0, 132, 255, 0.3);\n}\n\n/* File preview container */\n.filePreviewContainer {\n    display: flex;\n    flex-wrap: wrap;\n    gap: 8px;\n    margin-bottom: 8px;\n}\n\n/* Individual file preview */\n.filePreview {\n    display: flex;\n    align-items: center;\n    gap: 8px;\n    padding: 8px 12px;\n    background: rgba(125, 125, 125, 0.1);\n    border: 1px solid rgba(125, 125, 125, 0.2);\n    border-radius: 8px;\n    font-size: 12px;\n    backdrop-filter: blur(10px);\n    transition: all 0.2s ease;\n}\n\n.filePreview:hover {\n    background: rgba(125, 125, 125, 0.15);\n    border-color: rgba(125, 125, 125, 0.3);\n}\n\n.fileIcon {\n    font-size: 14px;\n    opacity: 0.7;\n}\n\n.fileInfo {\n    display: flex;\n    flex-direction: column;\n    gap: 2px;\n    min-width: 0;\n}\n\n.fileName {\n    font-weight: 500;\n    color: black;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    max-width: 150px;\n}\n\n.fileSize {\n    color: #6b7280;\n    font-size: 11px;\n}\n\n.removeFileButton {\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    width: 20px;\n    height: 20px;\n    border: none;\n    background: rgba(255, 0, 0, 0.1);\n    color: #ff4444;\n    border-radius: 50%;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    flex-shrink: 0;\n}\n\n.removeFileButton:hover {\n    background: rgba(255, 0, 0, 0.2);\n    transform: scale(1.1);\n}\n\n/* Input container for textarea and buttons */\n.inputContainer {\n    display: flex;\n    align-items: center;\n    gap: 12px;\n}\n\n.inputContainer textarea::placeholder {\n    color: inherit;\n    opacity: 0.7;\n}\n\n/* Attachment button */\n.attachmentButton {\n    width: 40px;\n    height: 40px;\n    border: 1px solid rgba(125, 125, 125, 0.2);\n    background: rgba(125, 125, 125, 0.05);\n    color: #6b7280;\n    border-radius: 50%;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    backdrop-filter: blur(10px);\n    flex-shrink: 0;\n}\n\n.attachmentButton:hover:not(:disabled) {\n    background: rgba(0, 132, 255, 0.1);\n    border-color: rgba(0, 132, 255, 0.3);\n    color: #0084ff;\n    transform: scale(1.05);\n}\n\n.attachmentButton:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n    transform: none;\n}\n\n/* Voice Button */\n.voiceButton {\n    width: 40px;\n    height: 40px;\n    border: 1px solid rgba(125, 125, 125, 0.2);\n    background: rgba(125, 125, 125, 0.05);\n    color: #6b7280;\n    border-radius: 50%;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    backdrop-filter: blur(10px);\n    flex-shrink: 0;\n}\n\n.voiceButton:hover {\n    background: rgba(0, 132, 255, 0.1);\n    border-color: rgba(0, 132, 255, 0.3);\n    color: #0084ff;\n    transform: scale(1.05);\n}\n\n.voiceButtonActive {\n    background: rgba(255, 0, 0, 0.1) !important;\n    border-color: rgba(255, 0, 0, 0.3) !important;\n    color: #ff0000 !important;\n    animation: voiceRecordingPulse 1.5s infinite;\n}\n\n@keyframes voiceRecordingPulse {\n    0% {\n        box-shadow: 0 0 0 0 rgba(255, 0, 0, 0.4);\n    }\n    70% {\n        box-shadow: 0 0 0 10px rgba(255, 0, 0, 0);\n    }\n    100% {\n        box-shadow: 0 0 0 0 rgba(255, 0, 0, 0);\n    }\n}\n\n/* Upload progress indicator */\n.uploadProgress {\n    display: flex;\n    align-items: center;\n    gap: 12px;\n    padding: 8px 12px;\n    background: rgba(0, 132, 255, 0.1);\n    border: 1px solid rgba(0, 132, 255, 0.2);\n    border-radius: 8px;\n    font-size: 13px;\n    color: #0084ff;\n}\n\n.uploadProgressBar {\n    flex: 1;\n    height: 4px;\n    background: rgba(0, 132, 255, 0.2);\n    border-radius: 2px;\n    overflow: hidden;\n}\n\n.uploadProgressFill {\n    height: 100%;\n    background: linear-gradient(90deg, #0084ff, rgba(0, 132, 255, 0.8));\n    border-radius: 2px;\n    animation: uploadProgress 1.5s ease-in-out infinite;\n}\n\n@keyframes uploadProgress {\n    0% {\n        transform: translateX(-100%);\n    }\n    50% {\n        transform: translateX(0%);\n    }\n    100% {\n        transform: translateX(100%);\n    }\n}\n\n/* Drag overlay */\n.dragOverlay {\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    background: rgba(0, 132, 255, 0.1);\n    border: 2px dashed rgba(0, 132, 255, 0.5);\n    border-radius: 12px;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    backdrop-filter: blur(10px);\n    z-index: 20;\n    pointer-events: none;\n}\n\n.dragOverlayContent {\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n    gap: 12px;\n    color: #0084ff;\n    font-weight: 600;\n    text-align: center;\n}\n\n.dragOverlayContent svg {\n    opacity: 0.7;\n}\n\n/* Chat input field */\n.chatMainFlow .chatInput textarea {\n    flex: 1;\n    padding: 16px 20px;\n\n    outline: none;\n    border-radius: 25px;\n    background: rgba(125, 125, 125, 0.05);\n    backdrop-filter: blur(20px);\n    color: black;\n    min-width: 200px;\n    max-height: 120px;\n    font-size: 15px;\n    line-height: 1.4;\n    resize: none;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    appearance: none;\n    -webkit-appearance: none;\n    -webkit-tap-highlight-color: transparent;\n    touch-action: manipulation;\n}\n\n.chatMainFlow .chatInput textarea:focus {\n    border-color: #0084ff;\n    background: rgba(125, 125, 125, 0.08);\n    box-shadow: 0 0 0 4px rgba(0, 132, 255, 0.1), 0 8px 32px rgba(0, 132, 255, 0.15);\n    transform: translateY(-2px);\n}\n\n.chatMainFlow .chatInput textarea:disabled {\n    opacity: 0.6;\n    cursor: not-allowed;\n    transform: none;\n}\n\n.chatMainFlow .chatInput textarea::placeholder {\n    color: inherit;\n    opacity: 0.7;\n}\n\n/* Chat send button */\n.chatMainFlow .chatInput button {\n    width: 48px;\n    height: 48px;\n    margin: 0 !important;\n    padding: 0 !important;\n\n    border: none;\n    background: linear-gradient(135deg, #0084ff 0%, #0066cc 100%);\n    color: #ffffff;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    border-radius: 50% !important;\n    aspect-ratio: 1 / 1;\n    min-width: unset !important;\n    min-height: unset !important;\n    padding-left: unset;\n    padding-right: unset;\n\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3);\n    -webkit-tap-highlight-color: transparent;\n    touch-action: manipulation;\n    user-select: none;\n    overflow: visible;\n}\n\n.chatMainFlow .chatInput button img {\n    width: 50%;\n    height: 100%;\n    object-fit: contain;\n}\n\n/* Scroll to bottom button */\n\n.scrollToBottomContainer {\n    /*/\n    outline: 1px dotted red;\n    /**/\n\n    z-index: 20;\n    grid-area: 📝;\n    width: 100%;\n    height: 100%;\n    display: flex;\n    justify-content: center;\n    align-items: flex-start;\n\n    pointer-events: none;\n}\n\n.scrollToBottomContainer .scrollToBottom {\n    pointer-events: all;\n\n    transform: translate(-50%, -150%);\n    width: 48px;\n    height: 48px;\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    border: none;\n    outline: none;\n    background: rgba(0 0 0 / 0.5);\n    backdrop-filter: blur(3px);\n    border-radius: 50%;\n    font-weight: bold;\n    color: white;\n    cursor: pointer;\n    -webkit-tap-highlight-color: transparent;\n    touch-action: manipulation;\n    user-select: none;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);\n    animation: scrollButtonSlideIn 0.3s ease-out;\n}\n\n@keyframes scrollButtonSlideIn {\n    from {\n        opacity: 0;\n        transform: translate(-50%, 20px) scale(0.8);\n    }\n    to {\n        opacity: 0.9;\n        transform: translate(-50%, 0) scale(1);\n    }\n}\n\n.scrollToBottom:hover {\n    transform: translate(-50%, -160%) scale(1.05);\n}\n\n.scrollToBottom:active {\n    transform: translate(-50%, -160%) scale(0.95);\n    transition: transform 0.1s ease;\n}\n\n/* Rating modal */\n.ratingModal {\n    position: fixed;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n\n    background-color: rgba(0, 0, 0, 0.6);\n    backdrop-filter: blur(8px);\n\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    z-index: 1000;\n    animation: modalFadeIn 0.3s ease-out;\n}\n\n@keyframes modalFadeIn {\n    from {\n        opacity: 0;\n        backdrop-filter: blur(0px);\n    }\n    to {\n        opacity: 1;\n        backdrop-filter: blur(8px);\n    }\n}\n\n.ratingModalContent {\n    background: #ffffff;\n    color: #0f1724;\n    padding: 32px;\n    border-radius: 16px;\n    width: 90%;\n    max-width: 480px;\n    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);\n    border: 1px solid rgba(125, 125, 125, 0.1);\n    backdrop-filter: blur(20px);\n    animation: modalSlideIn 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n\n    font-family: Arial, Helvetica, sans-serif, 'OpenMojiBlack';\n    /* <- TODO: [🧠][🎱] Better, define other fonts */\n}\n\n@keyframes modalSlideIn {\n    from {\n        opacity: 0;\n        transform: translateY(20px) scale(0.95);\n    }\n    to {\n        opacity: 1;\n        transform: translateY(0) scale(1);\n    }\n}\n\n.ratingModalContent h3 {\n    margin: 0 0 24px 0;\n    text-align: center;\n    color: black;\n    font-size: 20px;\n    font-weight: 600;\n}\n\n.stars {\n    display: flex;\n    justify-content: center;\n    gap: 8px;\n    margin-bottom: 24px;\n}\n\n.stars span {\n    font-size: 28px;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    padding: 4px;\n    border-radius: 8px;\n}\n\n.stars span:hover {\n    transform: scale(1.2);\n    background: rgba(255, 215, 0, 0.1);\n}\n\n.ratingModalStar {\n    cursor: pointer;\n    font-size: 24px;\n    transition: color 0.2s;\n}\n\n.ratingInput {\n    width: 100%;\n    min-height: 100px;\n    padding: 16px;\n    border: 2px solid rgba(125, 125, 125, 0.1);\n    border-radius: 12px;\n    margin-bottom: 18px;\n    resize: vertical;\n    background: rgba(125, 125, 125, 0.05);\n    color: #0b1220;\n    font-size: 14px;\n    line-height: 1.5;\n    transition: all 0.2s ease;\n}\n\n.ratingInput:focus {\n    border-color: #0084ff;\n    background: rgba(125, 125, 125, 0.08);\n    box-shadow: 0 0 0 4px rgba(0, 132, 255, 0.1);\n    outline: none;\n}\n\n.ratingInput[readonly] {\n    border: 1px solid rgba(125, 125, 125, 0.5);\n    background: rgba(125, 125, 125, 0.01);\n}\n\n.ratingActions {\n    display: flex;\n    justify-content: flex-end;\n    gap: 12px;\n}\n\n.ratingActions button {\n    padding: 12px 24px;\n    border: none;\n    border-radius: 8px;\n    cursor: pointer;\n    font-size: 14px;\n    font-weight: 500;\n    transition: all 0.2s ease;\n    min-width: 80px;\n}\n\n.ratingActions button:first-child {\n    background-color: rgba(125, 125, 125, 0.1);\n    color: #0b1220;\n    border: 1px solid rgba(125, 125, 125, 0.2);\n}\n\n.ratingActions button:first-child:hover:not(:disabled) {\n    background-color: rgba(125, 125, 125, 0.2);\n    color: #0b1220;\n}\n\n.ratingActions button:last-child {\n    background: linear-gradient(135deg, #0084ff 0%, #0066cc 100%);\n    color: #ffffff;\n}\n\n.ratingActions button:last-child:hover:not(:disabled) {\n    background: linear-gradient(135deg, #0071d1 0%, #0052a3 100%);\n    transform: translateY(-1px);\n    box-shadow: 0 4px 12px rgba(0, 132, 255, 0.3);\n}\n\n.ratingActions button:last-child:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n}\n\n/* New chat button styling - Matches the sleek chat message design */\n.chatButton {\n    display: inline-flex !important;\n    align-items: center !important;\n    justify-content: center !important;\n    gap: 8px !important;\n    padding: 12px 16px !important;\n    margin: 0 !important;\n    background: linear-gradient(135deg, #0084ff 0%, #0066cc 100%) !important;\n    color: #ffffff !important;\n    border: none !important;\n    border-radius: 20px !important;\n    font-size: 13px !important;\n    font-weight: 600 !important;\n    line-height: 1.3 !important;\n    cursor: pointer !important;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3) !important;\n    backdrop-filter: blur(20px) !important;\n    -webkit-tap-highlight-color: transparent !important;\n    touch-action: manipulation !important;\n    user-select: none !important;\n    min-height: 40px !important;\n    min-width: 110px !important;\n    position: relative !important;\n    overflow: hidden !important;\n}\n\n.chatButton::before {\n    content: '';\n    position: absolute;\n    top: 0;\n    left: -100%;\n    width: 100%;\n    height: 100%;\n    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);\n    transition: left 0.5s ease;\n}\n\n.chatButton:hover::before {\n    left: 100%;\n}\n\n.chatButton:hover:not(:disabled) {\n    background: linear-gradient(135deg, #0099ff 0%, #0077dd 100%);\n    transform: translateY(-2px) scale(1.02);\n    box-shadow: 0 8px 24px rgba(0, 132, 255, 0.4);\n}\n\n.chatButton:active {\n    transform: scale(0.98) translateY(-1px);\n    transition: transform 0.1s ease;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3);\n}\n\n.chatButton:focus {\n    outline: none;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3), 0 0 0 3px rgba(0, 132, 255, 0.3);\n}\n\n.chatButton svg {\n    width: 16px;\n    height: 16px;\n    flex-shrink: 0;\n    opacity: 1;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.2));\n}\n\n.chatButton:hover svg {\n    transform: rotate(-90deg) scale(1.1);\n    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));\n}\n\n.chatButtonText {\n    white-space: nowrap;\n    font-weight: 600;\n    transition: all 0.2s ease;\n    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);\n    opacity: 1;\n}\n\n.chatButton:hover .chatButtonText {\n    transform: translateX(1px);\n}\n\n/* Use template button styling - matches the chatButton and saveButton */\n.useTemplateButton {\n    display: inline-flex !important;\n    align-items: center !important;\n    justify-content: center !important;\n    gap: 8px !important;\n    padding: 12px 16px !important;\n    margin: 0 !important;\n    background: linear-gradient(135deg, #0084ff 0%, #0066cc 100%) !important;\n    color: #ffffff !important;\n    border: none !important;\n    border-radius: 20px !important;\n    font-size: 13px !important;\n    font-weight: 600 !important;\n    line-height: 1.3 !important;\n    cursor: pointer !important;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3) !important;\n    backdrop-filter: blur(20px) !important;\n    -webkit-tap-highlight-color: transparent !important;\n    touch-action: manipulation !important;\n    user-select: none !important;\n    min-height: 40px !important;\n    min-width: 110px !important;\n    position: relative !important;\n    overflow: hidden !important;\n}\n\n.useTemplateButton::before {\n    content: '';\n    position: absolute;\n    top: 0;\n    left: -100%;\n    width: 100%;\n    height: 100%;\n    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);\n    transition: left 0.5s ease;\n}\n\n.useTemplateButton:hover::before {\n    left: 100%;\n}\n\n.useTemplateButton:hover:not(:disabled) {\n    background: linear-gradient(135deg, #0099ff 0%, #0077dd 100%);\n    transform: translateY(-2px) scale(1.02);\n    box-shadow: 0 8px 24px rgba(0, 132, 255, 0.4);\n}\n\n.useTemplateButton:active {\n    transform: scale(0.98) translateY(-1px);\n    transition: transform 0.1s ease;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3);\n}\n\n.useTemplateButton:focus {\n    outline: none;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3), 0 0 0 3px rgba(0, 132, 255, 0.3);\n}\n\n.useTemplateButton svg {\n    width: 16px;\n    height: 16px;\n    flex-shrink: 0;\n    opacity: 1;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.2));\n}\n\n.useTemplateButton:hover svg {\n    transform: scale(1.1);\n    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));\n}\n\n.useTemplateButton:hover .chatButtonText {\n    transform: translateX(1px);\n}\n\n.saveButtonContainer {\n    display: inline-block;\n    position: relative;\n}\n\n.saveMenu {\n    position: absolute;\n    top: 100%;\n    left: 0;\n    background: #fff;\n    border: 1px solid #ddd;\n    z-index: 10;\n    min-width: 120px;\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);\n}\n\n.saveMenuItem {\n    display: block;\n    width: 100%;\n    padding: 8px 16px;\n    border: none;\n    background: none;\n    text-align: left;\n    cursor: pointer;\n    color: #111;\n}\n\n.saveMenuItem:hover {\n    background-color: #f0f0f0;\n}\n\n/* Pause/Resume button variant (reuses .chatButton base styles for DRY) */\n.pauseButton {\n    background: linear-gradient(135deg, #ffb347 0%, #ff8c42 100%) !important; /* Warm orange for \"active/running\" */\n}\n\n.pauseButton:hover:not(:disabled) {\n    background: linear-gradient(135deg, #ffc067 0%, #ff9e5f 100%) !important;\n}\n\n.pauseButton.pausing {\n    opacity: 0.6 !important;\n    cursor: wait !important;\n}\n\n.pauseButton.paused {\n    background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important; /* Green when paused (ready to resume) */\n}\n\n.pauseButton.paused:hover:not(:disabled) {\n    background: linear-gradient(135deg, #34d399 0%, #059669 100%) !important;\n    transform: translateY(-2px) scale(1.02);\n    box-shadow: 0 8px 24px rgba(16, 185, 129, 0.35);\n}\n\n.pauseButton svg {\n    transition: transform 0.3s ease;\n}\n\n.pauseButton.paused svg {\n    transform: scale(1.1);\n}\n\n.pauseButton.pausing svg {\n    opacity: 0.8;\n}\n\n/* Voice call indicator bar */\n.voiceCallIndicatorBar {\n    grid-area: 🟦;\n    width: 100%;\n    padding: 12px 20px;\n    background: linear-gradient(135deg, rgba(34, 197, 94, 0.1) 0%, rgba(16, 185, 129, 0.1) 100%);\n    border-bottom: 1px solid rgba(34, 197, 94, 0.3);\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    backdrop-filter: blur(10px);\n}\n\n/* Voice call indicator */\n.voiceCallIndicator {\n    display: inline-flex;\n    align-items: center;\n    gap: 8px;\n    padding: 8px 16px;\n    background: linear-gradient(135deg, rgba(34, 197, 94, 0.2) 0%, rgba(16, 185, 129, 0.2) 100%);\n    border: 1px solid rgba(34, 197, 94, 0.4);\n    border-radius: 20px;\n    color: #10b981;\n    font-size: 13px;\n    font-weight: 600;\n    backdrop-filter: blur(10px);\n    box-shadow: 0 2px 8px rgba(34, 197, 94, 0.2);\n    position: relative;\n}\n\n.voiceCallIndicator svg {\n    width: 16px;\n    height: 16px;\n    flex-shrink: 0;\n    animation: voiceCallIconPulse 2s ease-in-out infinite;\n}\n\n.voiceCallIndicator span {\n    font-weight: 600;\n    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);\n}\n\n/* Voice call pulse animation */\n.voiceCallPulse {\n    position: absolute;\n    right: 8px;\n    top: 50%;\n    transform: translateY(-50%);\n    width: 8px;\n    height: 8px;\n    background: #10b981;\n    border-radius: 50%;\n    animation: voiceCallPulse 1.5s ease-in-out infinite;\n}\n\n@keyframes voiceCallIconPulse {\n    0%,\n    100% {\n        transform: scale(1);\n        opacity: 1;\n    }\n    50% {\n        transform: scale(1.1);\n        opacity: 0.8;\n    }\n}\n\n@keyframes voiceCallPulse {\n    0%,\n    100% {\n        transform: translateY(-50%) scale(1);\n        opacity: 1;\n    }\n    50% {\n        transform: translateY(-50%) scale(1.3);\n        opacity: 0.6;\n    }\n}\n\n/* Voice call indicator in messages */\n.chatMessage .voiceCallIndicator {\n    margin-bottom: 8px;\n    padding: 6px 12px;\n    font-size: 12px;\n    border-radius: 16px;\n}\n\n.chatMessage .voiceCallIndicator svg {\n    width: 14px;\n    height: 14px;\n}\n\n/* Rating confirmation */\n.ratingConfirmation {\n    position: fixed;\n    top: 20px;\n    right: 20px;\n    background: linear-gradient(135deg, #10b981 0%, #059669 100%);\n    color: white;\n    padding: 16px 20px;\n    border-radius: 12px;\n    box-shadow: 0 8px 32px rgba(16, 185, 129, 0.3);\n    z-index: 1001;\n    animation: confirmationSlideIn 0.3s ease-out;\n    max-width: 300px;\n    word-wrap: break-word;\n    font-weight: 500;\n    backdrop-filter: blur(20px);\n}\n\n@keyframes confirmationSlideIn {\n    from {\n        transform: translateX(100%);\n        opacity: 0;\n    }\n    to {\n        transform: translateX(0);\n        opacity: 1;\n    }\n}\n\n/* Mobile responsiveness */\n@media (max-width: 768px) {\n    .actions {\n        margin: 12px 16px 0;\n        gap: 6px;\n    }\n\n    .chatMainFlow .chatMessages {\n        padding: 16px 12px;\n    }\n\n    .chatMainFlow .chatMessage {\n        margin-bottom: 16px;\n    }\n\n    .chatMainFlow .chatMessage .messageText {\n        max-width: 85%;\n        padding: 12px 16px;\n        font-size: 14px;\n        border-radius: 18px;\n    }\n\n    .chatMainFlow .chatMessage .avatar {\n        width: 36px;\n        height: 36px;\n        margin: 0 10px 4px;\n    }\n\n    .chatMainFlow .chatMessage .avatar img {\n        width: 36px;\n        aspect-ratio: 1 / 1;\n    }\n\n    .chatMainFlow .chatInput {\n        padding: 16px 12px;\n        gap: 10px;\n    }\n\n    .chatMainFlow .chatInput textarea {\n        font-size: 16px;\n        padding: 14px 18px;\n        border-radius: 22px;\n    }\n\n    .chatMainFlow .chatInput button {\n        width: 44px;\n        height: 44px;\n    }\n\n    .scrollToBottom {\n        width: 44px;\n        height: 44px;\n        font-size: 18px;\n        top: calc(100% - 160px);\n    }\n\n    .chatButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .chatButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .chatButtonText {\n        display: none !important;\n    }\n\n    .useTemplateButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .useTemplateButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .useTemplateButton .chatButtonText {\n        display: none !important;\n    }\n\n    .ratingModalContent {\n        margin: 16px;\n        padding: 24px 20px;\n        border-radius: 16px;\n        max-height: 80vh;\n        overflow-y: auto;\n    }\n\n    .stars {\n        gap: 6px;\n        margin-bottom: 20px;\n    }\n\n    .stars span {\n        font-size: 32px;\n        padding: 8px;\n    }\n\n    .ratingActions {\n        flex-direction: column-reverse;\n        gap: 8px;\n    }\n\n    .ratingActions button {\n        width: 100%;\n        padding: 14px;\n        font-size: 16px;\n        border-radius: 10px;\n    }\n}\n\n@media (max-width: 480px) {\n    .actions {\n        margin: 8px 12px 0;\n        gap: 4px;\n    }\n\n    .chatMainFlow .chatMessages {\n        padding: 12px 8px;\n    }\n\n    .chatMainFlow .chatMessage .messageText {\n        max-width: 90%;\n        padding: 10px 14px;\n        font-size: 14px;\n        border-radius: 16px;\n    }\n\n    .chatMainFlow .chatMessage .avatar {\n        width: 32px;\n        height: 32px;\n        margin: 0 8px 4px;\n    }\n\n    .chatMainFlow .chatMessage .avatar img {\n        width: 32px;\n        aspect-ratio: 1 / 1;\n    }\n\n    .chatMainFlow .chatInput {\n        padding: 12px 8px;\n        gap: 8px;\n    }\n\n    .chatMainFlow .chatInput textarea {\n        padding: 12px 16px;\n        border-radius: 20px;\n        font-size: 16px;\n    }\n\n    .chatMainFlow .chatInput button {\n        width: 40px;\n        height: 40px;\n    }\n\n    .chatButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .chatButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .chatButtonText {\n        display: none !important;\n    }\n\n    .useTemplateButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .useTemplateButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .useTemplateButton .chatButtonText {\n        display: none !important;\n    }\n\n    .scrollToBottom {\n        width: 40px;\n        height: 40px;\n        font-size: 16px;\n        top: calc(100% - 140px);\n    }\n\n    .ratingModal {\n        padding: 0;\n        align-items: flex-end;\n    }\n\n    .ratingModalContent {\n        margin: 0;\n        width: 100%;\n        border-radius: 20px 20px 0 0;\n        max-height: 70vh;\n        padding: 24px 16px 20px;\n    }\n}\n\n/* Reduced motion support */\n@media (prefers-reduced-motion: reduce) {\n    .chatMainFlow .chatMessage,\n    .scrollToBottom,\n    .ratingModal,\n    .ratingModalContent,\n    .ratingConfirmation {\n        animation: none;\n    }\n\n    .chatMainFlow .chatMessage .messageText,\n    .chatMainFlow .chatInput textarea,\n    .chatMainFlow .chatInput button,\n    .chatMainFlow .chatMessage .avatar img,\n    .chatButton {\n        transition: none;\n    }\n}\n\n/* High contrast mode support */\n@media (prefers-contrast: high) {\n    .chatMainFlow .chatMessage .messageText {\n        border: 2px solid currentColor;\n    }\n\n    .chatMainFlow .chatInput textarea {\n        border-width: 3px;\n    }\n\n    .chatMainFlow .chatInput button {\n        border: 2px solid currentColor;\n    }\n}\n\n/**\n * TODO: [🌉] DRY Markdown primitives styling\n */\n"]} */";
|
|
9142
|
+
var css_248z$2 = "@font-face{font-family:OpenMojiBlack;src:url(https://s6.ptbk.io/fonts/OpenMoji-black-glyf.woff2) format(\"woff2\");unicode-range:u+23,u+2a,u+2d,u+30-39,u+a9,u+ae,u+200d,u+203c,u+2049,u+20e3,u+2117,u+2120,u+2122,u+2139,u+2194-2199,u+21a9,u+21aa,u+229c,u+231a,u+231b,u+2328,u+23cf,u+23e9-23f3,u+23f8-23fe,u+24c2,u+25a1,u+25aa-25ae,u+25b6,u+25c0,u+25c9,u+25d0,u+25d1,u+25e7-25ea,u+25ed,u+25ee,u+25fb-25fe,u+2600-2605,u+260e,u+2611,u+2614,u+2615,u+2618,u+261d,u+2620,u+2622,u+2623,u+2626,u+262a,u+262e,u+262f,u+2638-263a,u+2640,u+2642,u+2648-2653,u+265f,u+2660,u+2663,u+2665,u+2666,u+2668,u+267b,u+267e,u+267f,u+2691-2697,u+2699,u+269b,u+269c,u+26a0,u+26a1,u+26a7,u+26aa,u+26ab,u+26b0,u+26b1,u+26bd,u+26be,u+26c4,u+26c5,u+26c8,u+26ce,u+26cf,u+26d1,u+26d3,u+26d4,u+26e9,u+26ea,u+26f0-26f5,u+26f7-26fa,u+26fd,u+2702,u+2705,u+2708-270d,u+270f,u+2712,u+2714,u+2716,u+271d,u+2721,u+2728,u+2733,u+2734,u+2744,u+2747,u+274c,u+274e,u+2753-2755,u+2757,u+2763,u+2764,u+2795-2797,u+27a1,u+27b0,u+27bf,u+2934,u+2935,u+2b05-2b07,u+2b0c,u+2b0d,u+2b1b,u+2b1c,u+2b1f-2b24,u+2b2e,u+2b2f,u+2b50,u+2b55,u+2b58,u+2b8f,u+2bba-2bbc,u+2bc3,u+2bc4,u+2bea,u+2beb,u+3030,u+303d,u+3297,u+3299,u+e000-e009,u+e010,u+e011,u+e040-e06d,u+e080-e0b4,u+e0c0-e0cc,u+e0ff-e10d,u+e140-e14a,u+e150-e157,u+e181-e189,u+e1c0-e1c4,u+e1c6-e1d9,u+e200-e216,u+e240-e269,u+e280-e283,u+e2c0-e2c4,u+e2c6-e2da,u+e300-e303,u+e305-e30f,u+e312-e316,u+e318-e322,u+e324-e329,u+e32b,u+e340-e348,u+e380,u+e381,u+f000,u+f77a,u+f8ff,u+fe0f,u+1f004,u+1f0cf,u+1f10d-1f10f,u+1f12f,u+1f16d-1f171,u+1f17e,u+1f17f,u+1f18e,u+1f191-1f19a,u+1f1e6-1f1ff,u+1f201,u+1f202,u+1f21a,u+1f22f,u+1f232-1f23a,u+1f250,u+1f251,u+1f260-1f265,u+1f300-1f321,u+1f324-1f393,u+1f396,u+1f397,u+1f399-1f39b,u+1f39e-1f3f0,u+1f3f3-1f3f5,u+1f3f7-1f4fd,u+1f4ff-1f53d,u+1f549-1f54e,u+1f550-1f567,u+1f56f,u+1f570,u+1f573-1f57a,u+1f587,u+1f58a-1f58d,u+1f590,u+1f595,u+1f596,u+1f5a4,u+1f5a5,u+1f5a8,u+1f5b1,u+1f5b2,u+1f5bc,u+1f5c2-1f5c4,u+1f5d1-1f5d3,u+1f5dc-1f5de,u+1f5e1,u+1f5e3,u+1f5e8,u+1f5ef,u+1f5f3,u+1f5fa-1f64f,u+1f680-1f6c5,u+1f6cb-1f6d2,u+1f6d5-1f6d7,u+1f6dc-1f6e5,u+1f6e9,u+1f6eb,u+1f6ec,u+1f6f0,u+1f6f3-1f6fc,u+1f7e0-1f7eb,u+1f7f0,u+1f90c-1f93a,u+1f93c-1f945,u+1f947-1f9ff,u+1fa70-1fa7c,u+1fa80-1fa88,u+1fa90-1fabd,u+1fabf-1fac5,u+1face-1fadb,u+1fae0-1fae8,u+1faf0-1faf8,u+1fbc5-1fbc9,u+e0061-e0067,u+e0069,u+e006c-e0079,u+e007f}.Chat-module_copiedToClipboardMessage__apCPY{background:#222;border-radius:8px;box-shadow:0 2px 12px rgba(0,0,0,.18);color:#fff;font-size:1.1em;left:50%;opacity:.97;padding:10px 24px;pointer-events:none;position:fixed;top:32px;transform:translateX(-50%);z-index:9999}.Chat-module_Chat__j2eE5{display:flex;flex-direction:column;font-family:Arial,Helvetica,sans-serif,OpenMojiBlack;height:100%;width:100%}.Chat-module_chatMainFlow__--8FE{display:grid;grid-template:\"🟦\" min-content \"💬\" 1fr \"📝\" min-content/1fr;height:100%;max-width:100vw;width:100%}.Chat-module_chatMainFlow__--8FE .Chat-module_chatBar__fLECN{background-color:#fff;border-bottom:1px solid rgba(15,23,36,.06);color:#0f1724;font-weight:500;grid-area:🟦;padding:16px 20px;text-align:center;width:100%}.Chat-module_TasksInProgress__fQfei{align-self:center;grid-area:🟦;height:min-content;justify-self:self-end;margin:8px 16px;width:auto}.Chat-module_actions__gTZ5T{align-items:center;align-self:self-start;display:flex;gap:8px;grid-area:💬;height:min-content;justify-self:self-end;margin:16px 20px 0;width:auto;z-index:200}.Chat-module_actions__gTZ5T.Chat-module_portal__uTOT8{margin:0}.Chat-module_actions__gTZ5T.Chat-module_left__7l5Mn{justify-self:self-start}.Chat-module_actions__gTZ5T.Chat-module_right__ABZrW{justify-self:self-end}@media (max-width:900px){.Chat-module_chatButton__d9VgA{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_chatButton__d9VgA svg{height:18px!important;width:18px!important}.Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_useTemplateButton__xcJNR{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_useTemplateButton__xcJNR svg{height:18px!important;width:18px!important}.Chat-module_useTemplateButton__xcJNR .Chat-module_chatButtonText__RkGB-{display:none!important}}@media (max-width:600px){.Chat-module_actions__gTZ5T{gap:7px;margin:14px 18px 0}}.Chat-module_chatMainFlow__--8FE .Chat-module_chatChildren__flOPK{grid-area:💬;height:100%;width:100%;z-index:300}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N{grid-area:💬;height:100%;overflow-x:hidden;overflow-y:auto;padding:24px 20px 16px;scroll-behavior:smooth;width:100%;z-index:10}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N::-webkit-scrollbar{width:6px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N::-webkit-scrollbar-track{background:transparent}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N::-webkit-scrollbar-thumb{background:hsla(0,0%,49%,.2);border-radius:3px;transition:all .2s ease}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N::-webkit-scrollbar-thumb:hover{background:hsla(0,0%,49%,.3)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ{align-items:flex-end;animation:Chat-module_messageSlideIn__soTy2 .4s cubic-bezier(.25,.46,.45,.94);display:flex;flex-direction:row;margin-bottom:20px;max-width:100%;position:relative}.Chat-module_hasActionsAndFirstMessageIsLong__5jgoZ{margin-top:55px}@keyframes Chat-module_messageSlideIn__soTy2{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.Chat-module_isNotCompleteMessage__Hj2K7{opacity:.7;position:relative}.Chat-module_NonCompleteMessageFiller__G5-Ve{color:transparent}.Chat-module_isNotCompleteMessage__Hj2K7 .Chat-module_messageText__XgNyQ:after{animation:Chat-module_loadingPulse__VomRm 1.5s ease-in-out infinite;background:linear-gradient(90deg,transparent,hsla(0,0%,49%,.6),transparent);border-radius:2px;bottom:8px;content:\"\";height:4px;position:absolute;right:12px;width:20px}@keyframes Chat-module_loadingPulse__VomRm{0%,to{opacity:.3;transform:scaleX(.8)}50%{opacity:1;transform:scaleX(1.2)}}.Chat-module_typingIndicator__S-CT-{align-items:flex-end;animation:Chat-module_messageSlideIn__soTy2 .4s cubic-bezier(.25,.46,.45,.94);display:flex;margin-bottom:20px}.Chat-module_typingIndicator__S-CT- .Chat-module_avatar__gL6bm{flex-shrink:0;height:40px;margin:0 12px 4px;width:40px}.Chat-module_typingIndicator__S-CT- .Chat-module_avatar__gL6bm img{aspect-ratio:1/1;background-color:#eef6fb;border:2px solid hsla(0,0%,49%,.1);border-radius:50%;object-fit:cover;width:40px}.Chat-module_typingBubble__0Lb7B{backdrop-filter:blur(10px);border:1px solid hsla(0,0%,49%,.1);border-radius:20px;border-bottom-left-radius:6px;box-shadow:0 2px 8px rgba(0,0,0,.1);min-height:24px;padding:16px 20px}.Chat-module_typingBubble__0Lb7B,.Chat-module_typingDots__srOBB{align-items:center;display:flex;gap:4px}.Chat-module_typingDot__dnhKT{animation:Chat-module_typingBounce__1yp2v 1.4s ease-in-out infinite;background:linear-gradient(135deg,#6b7280,hsla(0,0%,49%,.6));border-radius:50%;box-shadow:0 2px 4px rgba(0,0,0,.1);height:8px;width:8px}.Chat-module_typingDot__dnhKT:first-child{animation-delay:-.32s}.Chat-module_typingDot__dnhKT:nth-child(2){animation-delay:-.16s}.Chat-module_typingDot__dnhKT:nth-child(3){animation-delay:0s}@keyframes Chat-module_typingBounce__1yp2v{0%,80%,to{opacity:.5;transform:scale(.8) translateY(0)}40%{opacity:1;transform:scale(1.2) translateY(-8px)}}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ.Chat-module_isMe__nBtaV{align-items:flex-end;flex-direction:row-reverse;justify-content:flex-start}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ.Chat-module_isMe__nBtaV .Chat-module_messageText__XgNyQ{border-bottom-right-radius:6px}.Chat-module_ratingStar__rRfqC{color:var(--star-inactive-color,#ccc);cursor:pointer;font-size:20px;transition:color .2s}.Chat-module_ratingStar__rRfqC.Chat-module_active__lbYL-{color:gold}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm{aspect-ratio:1/1;flex-shrink:0;margin:0 12px 4px;position:relative;width:40px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img{aspect-ratio:1/1;background-color:var(--avatar-bg-color,#eef6fb);border:2px solid hsla(0,0%,49%,.1);border-radius:50%;object-fit:cover;transition:transform .2s ease,box-shadow .2s ease;width:40px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img:hover{box-shadow:0 4px 12px rgba(0,0,0,.15);transform:scale(1.05)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{word-wrap:break-word;backdrop-filter:blur(10px);background-color:var(--message-bg-color);border-radius:20px;box-shadow:0 2px 8px rgba(0,0,0,.1);color:var(--message-text-color);font-size:15px;line-height:1.5;margin-bottom:4px;max-width:min(70%,600px);padding:14px 18px;position:relative;text-align:left;transition:all .2s ease}.Chat-module_copyButtonContainer__Rij0U{align-items:center;float:right;justify-content:flex-end;pointer-events:none;right:10px;top:8px;visibility:hidden;z-index:2}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ:hover .Chat-module_copyButtonContainer__Rij0U,.Chat-module_copyButtonContainer__Rij0U:focus-within{pointer-events:auto;visibility:visible}.Chat-module_copyButton__DcxT5{align-items:center;background:hsla(0,0%,100%,.2);border:1px solid #ddd;border-radius:6px;box-shadow:0 1px 4px rgba(0,0,0,.07);cursor:pointer;display:flex;opacity:.7;padding:2px 5px;position:relative;transition:all .15s,box-shadow .15s,border .15s}.Chat-module_copiedTooltip__LH81j{animation:Chat-module_copiedTooltipFadeIn__QekO1 .2s;background:#222;border-radius:8px;box-shadow:0 2px 12px rgba(0,0,0,.18);color:#fff;font-size:.98em;left:50%;margin-top:4px;max-width:220px;opacity:.97;overflow-wrap:break-word;padding:6px 16px;pointer-events:none;position:absolute;top:110%;transform:translateX(-50%);white-space:nowrap;word-break:break-word;z-index:100}.Chat-module_copiedTooltipLeft__j-S-5{left:0!important;transform:none!important}.Chat-module_copiedTooltipRight__R-2cE{left:auto!important;right:0!important;transform:none!important}@keyframes Chat-module_copiedTooltipFadeIn__QekO1{0%{opacity:0;transform:translateX(-50%) translateY(8px) scale(.97)}to{opacity:.97;transform:translateX(-50%) translateY(0) scale(1)}}.Chat-module_copyButton__DcxT5:focus,.Chat-module_copyButton__DcxT5:hover{border:1.5px solid #bbb;box-shadow:0 2px 8px rgba(0,132,255,.1);opacity:1}.Chat-module_copyButton__DcxT5 svg{display:block}.Chat-module_messageText__XgNyQ h1{font-size:2em}.Chat-module_messageText__XgNyQ h2{font-size:1.75em}.Chat-module_messageText__XgNyQ h3{font-size:1.5em}.Chat-module_messageText__XgNyQ h4{font-size:1.25em}.Chat-module_messageText__XgNyQ h5{font-size:1.1em}.Chat-module_messageText__XgNyQ ul{list-style:disc;margin-left:20px}.Chat-module_messageText__XgNyQ ol{list-style:decimal;margin-left:20px}.Chat-module_messageText__XgNyQ blockquote,.Chat-module_messageText__XgNyQ img,.Chat-module_messageText__XgNyQ pre,.Chat-module_messageText__XgNyQ table{border-radius:8px;margin-bottom:10px;margin-top:10px}.Chat-module_messageText__XgNyQ pre{background:#000;color:#fff}.Chat-module_messageText__XgNyQ blockquote,.Chat-module_messageText__XgNyQ pre{border:none;box-shadow:none;display:block;font-size:inherit;line-height:inherit;padding:1em}.Chat-module_messageText__XgNyQ blockquote{background:#ffffffcc;color:#000}.Chat-module_messageText__XgNyQ code{background:#cccccc55;border:none;box-shadow:none;color:inherit;display:inline-block;font-size:inherit;line-height:inherit;margin:0;padding:0}.Chat-module_messageText__XgNyQ pre code{background-color:#000000cc;border-radius:8px}.Chat-module_messageText__XgNyQ .Chat-module_chat-code-block__k8IyS{background:#181c23;border-color:#23272f;box-shadow:0 2px 8px rgba(0,0,0,.12);color:#f8fafc;font-family:Fira Mono,Menlo,Consolas,Liberation Mono,monospace;font-size:14px;line-height:1.6;overflow-x:auto}.Chat-module_messageText__XgNyQ .Chat-module_chat-code-block__k8IyS code{background:none!important;border:none!important;box-shadow:none!important;color:inherit!important;display:block;font-family:inherit!important;font-size:inherit!important;overflow-x:auto;padding:0!important;white-space:pre;word-break:break-word}.Chat-module_messageText__XgNyQ table{background:#f8fafc;border-collapse:separate;border-spacing:0;box-shadow:0 2px 8px rgba(0,0,0,.08);color:#17223b;font-size:14px;margin:16px 0;width:100%}.Chat-module_messageText__XgNyQ td,.Chat-module_messageText__XgNyQ th{background:none;border-bottom:1px solid #d1dbe8;color:#17223b;padding:10px 16px;text-align:left}.Chat-module_messageText__XgNyQ th{background:linear-gradient(90deg,#eaf3fa 80%,#d1e3f8);border-bottom:2px solid #b5c7de;color:#17223b;font-weight:700}.Chat-module_messageText__XgNyQ tr:last-child td{border-bottom:none}.Chat-module_messageText__XgNyQ tr:nth-child(2n) td{background:#eaf3fa}.Chat-module_messageText__XgNyQ tr:hover td{background:#cbe0f7;transition:background .2s}.Chat-module_messageText__XgNyQ table{border-radius:12px;overflow:hidden}.Chat-module_messageText__XgNyQ td:first-child,.Chat-module_messageText__XgNyQ th:first-child{border-top-left-radius:12px}.Chat-module_messageText__XgNyQ td:last-child,.Chat-module_messageText__XgNyQ th:last-child{border-top-right-radius:12px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ:hover{box-shadow:0 4px 16px rgba(0,0,0,.15);transform:translateY(-1px)}.Chat-module_messageButtons__WaOob{border-top:1px solid hsla(0,0%,49%,.83);display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;padding-top:12px}.Chat-module_messageButton__mRnn-{-webkit-tap-highlight-color:transparent;align-items:center;backdrop-filter:blur(10px);background:hsla(0,0%,49%,.1);border:1px solid hsla(0,0%,49%,.9);border-radius:16px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;padding:8px 14px;touch-action:manipulation;transition:all .2s ease;user-select:none}.Chat-module_messageButton__mRnn-:hover{background:rgba(0,132,255,.1);border-color:rgba(0,132,255,.3);box-shadow:0 2px 8px rgba(0,132,255,.15);transform:translateY(-1px)}.Chat-module_messageButton__mRnn-:active{transform:scale(.98);transition:transform .1s ease}.Chat-module_messageButton__mRnn- p{line-height:inherit;margin:0;padding:0}.Chat-module_messageButton__mRnn- strong{font-weight:600}.Chat-module_messageButton__mRnn- em{font-style:italic}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_rating__soc3M{align-items:center;backdrop-filter:blur(10px);background:rgba(0,0,0,.8);border-radius:12px;bottom:-8px;display:flex;gap:2px;min-width:24px;opacity:0;padding:4px 6px;position:absolute;right:8px;transform:translateY(4px);transition:all .3s cubic-bezier(.25,.46,.45,.94);z-index:1}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ:hover .Chat-module_rating__soc3M{opacity:1;transform:translateY(0)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_rating__soc3M:hover{background:rgba(0,0,0,.9);box-shadow:0 4px 12px rgba(0,0,0,.3);padding:6px 8px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_rating__soc3M span{cursor:pointer;display:inline-block;font-size:16px;transition:transform .2s ease,color .2s ease}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_rating__soc3M:hover span{transform:scale(1.1)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan{backdrop-filter:blur(20px);border-top:1px solid hsla(0,0%,49%,.1);display:flex;flex-direction:column;gap:12px;grid-area:📝;padding:20px;position:relative;width:100%;z-index:10}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan.Chat-module_dragOver__bkS-g{background:linear-gradient(0deg,rgba(0,132,255,.1) 0,rgba(0,132,255,.05));border-top:2px solid rgba(0,132,255,.3)}.Chat-module_filePreviewContainer__R70hm{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.Chat-module_filePreview__kq2aX{align-items:center;backdrop-filter:blur(10px);background:hsla(0,0%,49%,.1);border:1px solid hsla(0,0%,49%,.2);border-radius:8px;display:flex;font-size:12px;gap:8px;padding:8px 12px;transition:all .2s ease}.Chat-module_filePreview__kq2aX:hover{background:hsla(0,0%,49%,.15);border-color:hsla(0,0%,49%,.3)}.Chat-module_fileIcon__zoSKW{font-size:14px;opacity:.7}.Chat-module_fileInfo__wBLi0{display:flex;flex-direction:column;gap:2px;min-width:0}.Chat-module_fileName__bBujo{color:#000;font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.Chat-module_fileSize__ivliq{color:#6b7280;font-size:11px}.Chat-module_removeFileButton__0gakR{align-items:center;background:rgba(255,0,0,.1);border:none;border-radius:50%;color:#f44;cursor:pointer;display:flex;flex-shrink:0;height:20px;justify-content:center;transition:all .2s ease;width:20px}.Chat-module_removeFileButton__0gakR:hover{background:rgba(255,0,0,.2);transform:scale(1.1)}.Chat-module_inputContainer__bPt99{align-items:center;display:flex;gap:12px}.Chat-module_inputContainer__bPt99 textarea::placeholder{color:inherit;opacity:.7}.Chat-module_attachmentButton__qLO47{align-items:center;backdrop-filter:blur(10px);background:hsla(0,0%,49%,.05);border:1px solid hsla(0,0%,49%,.2);border-radius:50%;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;transition:all .2s ease;width:40px}.Chat-module_attachmentButton__qLO47:hover:not(:disabled){background:rgba(0,132,255,.1);border-color:rgba(0,132,255,.3);color:#0084ff;transform:scale(1.05)}.Chat-module_attachmentButton__qLO47:disabled{cursor:not-allowed;opacity:.5;transform:none}.Chat-module_voiceButton__d2zlP{align-items:center;backdrop-filter:blur(10px);background:hsla(0,0%,49%,.05);border:1px solid hsla(0,0%,49%,.2);border-radius:50%;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;transition:all .2s ease;width:40px}.Chat-module_voiceButton__d2zlP:hover{background:rgba(0,132,255,.1);border-color:rgba(0,132,255,.3);color:#0084ff;transform:scale(1.05)}.Chat-module_voiceButtonActive__Uoi3W{animation:Chat-module_voiceRecordingPulse__y2wJ5 1.5s infinite;background:rgba(255,0,0,.1)!important;border-color:rgba(255,0,0,.3)!important;color:red!important}@keyframes Chat-module_voiceRecordingPulse__y2wJ5{0%{box-shadow:0 0 0 0 rgba(255,0,0,.4)}70%{box-shadow:0 0 0 10px rgba(255,0,0,0)}to{box-shadow:0 0 0 0 rgba(255,0,0,0)}}.Chat-module_uploadProgress__jBTKe{align-items:center;background:rgba(0,132,255,.1);border:1px solid rgba(0,132,255,.2);border-radius:8px;color:#0084ff;display:flex;font-size:13px;gap:12px;padding:8px 12px}.Chat-module_uploadProgressBar__Gutnt{background:rgba(0,132,255,.2);border-radius:2px;flex:1;height:4px;overflow:hidden}.Chat-module_uploadProgressFill__EgubT{animation:Chat-module_uploadProgress__jBTKe 1.5s ease-in-out infinite;background:linear-gradient(90deg,#0084ff,rgba(0,132,255,.8));border-radius:2px;height:100%}@keyframes Chat-module_uploadProgress__jBTKe{0%{transform:translateX(-100%)}50%{transform:translateX(0)}to{transform:translateX(100%)}}.Chat-module_dragOverlay__SEGoS{align-items:center;backdrop-filter:blur(10px);background:rgba(0,132,255,.1);border:2px dashed rgba(0,132,255,.5);border-radius:12px;bottom:0;display:flex;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:20}.Chat-module_dragOverlayContent__gb9kF{align-items:center;color:#0084ff;display:flex;flex-direction:column;font-weight:600;gap:12px;text-align:center}.Chat-module_dragOverlayContent__gb9kF svg{opacity:.7}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea{-webkit-tap-highlight-color:transparent;appearance:none;-webkit-appearance:none;backdrop-filter:blur(20px);background:hsla(0,0%,49%,.05);border-radius:25px;color:#000;flex:1;font-size:15px;line-height:1.4;max-height:120px;min-width:200px;outline:none;padding:16px 20px;resize:none;touch-action:manipulation;transition:all .3s cubic-bezier(.25,.46,.45,.94)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea:focus{background:hsla(0,0%,49%,.08);border-color:#0084ff;box-shadow:0 0 0 4px rgba(0,132,255,.1),0 8px 32px rgba(0,132,255,.15);transform:translateY(-2px)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea:disabled{cursor:not-allowed;opacity:.6;transform:none}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea::placeholder{color:inherit;opacity:.7}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button{-webkit-tap-highlight-color:transparent;align-items:center;aspect-ratio:1/1;border:none;border-radius:50%!important;box-shadow:0 4px 16px rgba(0,132,255,.3);color:#fff;display:flex;height:48px;justify-content:center;margin:0!important;min-height:unset!important;min-width:unset!important;overflow:visible;padding:0!important;padding-left:unset;padding-right:unset;touch-action:manipulation;transition:all .3s cubic-bezier(.25,.46,.45,.94);user-select:none;width:48px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button img{height:100%;object-fit:contain;width:50%}.Chat-module_scrollToBottomContainer__5rXpK{align-items:flex-start;display:flex;grid-area:📝;height:100%;justify-content:center;pointer-events:none;width:100%;z-index:20}.Chat-module_scrollToBottomContainer__5rXpK .Chat-module_scrollToBottom__nzxdZ{-webkit-tap-highlight-color:transparent;align-items:center;animation:Chat-module_scrollButtonSlideIn__XnImg .3s ease-out;backdrop-filter:blur(3px);background:rgba(0,0,0,.5);border:none;border-radius:50%;box-shadow:0 4px 16px rgba(0,0,0,.3);color:#fff;cursor:pointer;display:flex;font-weight:700;height:48px;justify-content:center;outline:none;pointer-events:all;touch-action:manipulation;transform:translate(-50%,-150%);transition:all .3s cubic-bezier(.25,.46,.45,.94);user-select:none;width:48px}@keyframes Chat-module_scrollButtonSlideIn__XnImg{0%{opacity:0;transform:translate(-50%,20px) scale(.8)}to{opacity:.9;transform:translate(-50%) scale(1)}}.Chat-module_scrollToBottom__nzxdZ:hover{transform:translate(-50%,-160%) scale(1.05)}.Chat-module_scrollToBottom__nzxdZ:active{transform:translate(-50%,-160%) scale(.95);transition:transform .1s ease}.Chat-module_ratingModal__XVKYm{align-items:center;animation:Chat-module_modalFadeIn__RPc3w .3s ease-out;backdrop-filter:blur(8px);background-color:rgba(0,0,0,.6);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes Chat-module_modalFadeIn__RPc3w{0%{backdrop-filter:blur(0);opacity:0}to{backdrop-filter:blur(8px);opacity:1}}.Chat-module_ratingModalContent__CCdq7{animation:Chat-module_modalSlideIn__XXtgN .3s cubic-bezier(.25,.46,.45,.94);backdrop-filter:blur(20px);background:#fff;border:1px solid hsla(0,0%,49%,.1);border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3);color:#0f1724;font-family:Arial,Helvetica,sans-serif,OpenMojiBlack;max-width:480px;padding:32px;width:90%}@keyframes Chat-module_modalSlideIn__XXtgN{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.Chat-module_ratingModalContent__CCdq7 h3{color:#000;font-size:20px;font-weight:600;margin:0 0 24px;text-align:center}.Chat-module_stars__PCzNO{display:flex;gap:8px;justify-content:center;margin-bottom:24px}.Chat-module_stars__PCzNO span{border-radius:8px;cursor:pointer;font-size:28px;padding:4px;transition:all .2s ease}.Chat-module_stars__PCzNO span:hover{background:rgba(255,215,0,.1);transform:scale(1.2)}.Chat-module_ratingModalStar__XkbHr{cursor:pointer;font-size:24px;transition:color .2s}.Chat-module_ratingInput__z8Pv-{background:hsla(0,0%,49%,.05);border:2px solid hsla(0,0%,49%,.1);border-radius:12px;color:#0b1220;font-size:14px;line-height:1.5;margin-bottom:18px;min-height:100px;padding:16px;resize:vertical;transition:all .2s ease;width:100%}.Chat-module_ratingInput__z8Pv-:focus{background:hsla(0,0%,49%,.08);border-color:#0084ff;box-shadow:0 0 0 4px rgba(0,132,255,.1);outline:none}.Chat-module_ratingInput__z8Pv-[readonly]{background:hsla(0,0%,49%,.01);border:1px solid hsla(0,0%,49%,.5)}.Chat-module_ratingActions__nXcss{display:flex;gap:12px;justify-content:flex-end}.Chat-module_ratingActions__nXcss button{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;min-width:80px;padding:12px 24px;transition:all .2s ease}.Chat-module_ratingActions__nXcss button:first-child{background-color:hsla(0,0%,49%,.1);border:1px solid hsla(0,0%,49%,.2);color:#0b1220}.Chat-module_ratingActions__nXcss button:first-child:hover:not(:disabled){background-color:hsla(0,0%,49%,.2);color:#0b1220}.Chat-module_ratingActions__nXcss button:last-child{background:linear-gradient(135deg,#0084ff,#06c);color:#fff}.Chat-module_ratingActions__nXcss button:last-child:hover:not(:disabled){background:linear-gradient(135deg,#0071d1,#0052a3);box-shadow:0 4px 12px rgba(0,132,255,.3);transform:translateY(-1px)}.Chat-module_ratingActions__nXcss button:last-child:disabled{cursor:not-allowed;opacity:.5}.Chat-module_chatButton__d9VgA{-webkit-tap-highlight-color:transparent!important;align-items:center!important;backdrop-filter:blur(20px)!important;background:linear-gradient(135deg,#0084ff,#06c)!important;border:none!important;border-radius:20px!important;box-shadow:0 4px 16px rgba(0,132,255,.3)!important;color:#fff!important;cursor:pointer!important;display:inline-flex!important;font-size:13px!important;font-weight:600!important;gap:8px!important;justify-content:center!important;line-height:1.3!important;margin:0!important;min-height:40px!important;min-width:110px!important;overflow:hidden!important;padding:12px 16px!important;position:relative!important;touch-action:manipulation!important;transition:all .3s cubic-bezier(.25,.46,.45,.94)!important;user-select:none!important}.Chat-module_chatButton__d9VgA:before{background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.2),transparent);content:\"\";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.Chat-module_chatButton__d9VgA:hover:before{left:100%}.Chat-module_chatButton__d9VgA:hover:not(:disabled){background:linear-gradient(135deg,#09f,#07d);box-shadow:0 8px 24px rgba(0,132,255,.4);transform:translateY(-2px) scale(1.02)}.Chat-module_chatButton__d9VgA:active{box-shadow:0 4px 16px rgba(0,132,255,.3);transform:scale(.98) translateY(-1px);transition:transform .1s ease}.Chat-module_chatButton__d9VgA:focus{box-shadow:0 4px 16px rgba(0,132,255,.3),0 0 0 3px rgba(0,132,255,.3);outline:none}.Chat-module_chatButton__d9VgA svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.2));flex-shrink:0;height:16px;opacity:1;transition:all .3s cubic-bezier(.25,.46,.45,.94);width:16px}.Chat-module_chatButton__d9VgA:hover svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));transform:rotate(-90deg) scale(1.1)}.Chat-module_chatButtonText__RkGB-{font-weight:600;opacity:1;text-shadow:0 1px 2px rgba(0,0,0,.1);transition:all .2s ease;white-space:nowrap}.Chat-module_chatButton__d9VgA:hover .Chat-module_chatButtonText__RkGB-{transform:translateX(1px)}.Chat-module_useTemplateButton__xcJNR{-webkit-tap-highlight-color:transparent!important;align-items:center!important;backdrop-filter:blur(20px)!important;background:linear-gradient(135deg,#0084ff,#06c)!important;border:none!important;border-radius:20px!important;box-shadow:0 4px 16px rgba(0,132,255,.3)!important;color:#fff!important;cursor:pointer!important;display:inline-flex!important;font-size:13px!important;font-weight:600!important;gap:8px!important;justify-content:center!important;line-height:1.3!important;margin:0!important;min-height:40px!important;min-width:110px!important;overflow:hidden!important;padding:12px 16px!important;position:relative!important;touch-action:manipulation!important;transition:all .3s cubic-bezier(.25,.46,.45,.94)!important;user-select:none!important}.Chat-module_useTemplateButton__xcJNR:before{background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.2),transparent);content:\"\";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.Chat-module_useTemplateButton__xcJNR:hover:before{left:100%}.Chat-module_useTemplateButton__xcJNR:hover:not(:disabled){background:linear-gradient(135deg,#09f,#07d);box-shadow:0 8px 24px rgba(0,132,255,.4);transform:translateY(-2px) scale(1.02)}.Chat-module_useTemplateButton__xcJNR:active{box-shadow:0 4px 16px rgba(0,132,255,.3);transform:scale(.98) translateY(-1px);transition:transform .1s ease}.Chat-module_useTemplateButton__xcJNR:focus{box-shadow:0 4px 16px rgba(0,132,255,.3),0 0 0 3px rgba(0,132,255,.3);outline:none}.Chat-module_useTemplateButton__xcJNR svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.2));flex-shrink:0;height:16px;opacity:1;transition:all .3s cubic-bezier(.25,.46,.45,.94);width:16px}.Chat-module_useTemplateButton__xcJNR:hover svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));transform:scale(1.1)}.Chat-module_useTemplateButton__xcJNR:hover .Chat-module_chatButtonText__RkGB-{transform:translateX(1px)}.Chat-module_saveButtonContainer__lSNUJ{display:inline-block;position:relative}.Chat-module_saveMenu__-ph8y{background:#fff;border:1px solid #ddd;box-shadow:0 2px 8px rgba(0,0,0,.08);left:0;min-width:120px;position:absolute;top:100%;z-index:10}.Chat-module_saveMenuItem__ISApL{background:none;border:none;color:#111;cursor:pointer;display:block;padding:8px 16px;text-align:left;width:100%}.Chat-module_saveMenuItem__ISApL:hover{background-color:#f0f0f0}.Chat-module_pauseButton__eeu7K{background:linear-gradient(135deg,#ffb347,#ff8c42)!important}.Chat-module_pauseButton__eeu7K:hover:not(:disabled){background:linear-gradient(135deg,#ffc067,#ff9e5f)!important}.Chat-module_pauseButton__eeu7K.Chat-module_pausing__pTx8b{cursor:wait!important;opacity:.6!important}.Chat-module_pauseButton__eeu7K.Chat-module_paused__j-pya{background:linear-gradient(135deg,#10b981,#059669)!important}.Chat-module_pauseButton__eeu7K.Chat-module_paused__j-pya:hover:not(:disabled){background:linear-gradient(135deg,#34d399,#059669)!important;box-shadow:0 8px 24px rgba(16,185,129,.35);transform:translateY(-2px) scale(1.02)}.Chat-module_pauseButton__eeu7K svg{transition:transform .3s ease}.Chat-module_pauseButton__eeu7K.Chat-module_paused__j-pya svg{transform:scale(1.1)}.Chat-module_pauseButton__eeu7K.Chat-module_pausing__pTx8b svg{opacity:.8}.Chat-module_voiceCallIndicatorBar__N2sWN{align-items:center;backdrop-filter:blur(10px);background:linear-gradient(135deg,rgba(34,197,94,.1),rgba(16,185,129,.1));border-bottom:1px solid rgba(34,197,94,.3);display:flex;grid-area:🟦;justify-content:center;padding:12px 20px;width:100%}.Chat-module_voiceCallIndicator__tsaaG{align-items:center;backdrop-filter:blur(10px);background:linear-gradient(135deg,rgba(34,197,94,.2),rgba(16,185,129,.2));border:1px solid rgba(34,197,94,.4);border-radius:20px;box-shadow:0 2px 8px rgba(34,197,94,.2);color:#10b981;display:inline-flex;font-size:13px;font-weight:600;gap:8px;padding:8px 16px;position:relative}.Chat-module_voiceCallIndicator__tsaaG svg{animation:Chat-module_voiceCallIconPulse__zZbJn 2s ease-in-out infinite;flex-shrink:0;height:16px;width:16px}.Chat-module_voiceCallIndicator__tsaaG span{font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.1)}.Chat-module_voiceCallPulse__XcGU4{animation:Chat-module_voiceCallPulse__XcGU4 1.5s ease-in-out infinite;background:#10b981;border-radius:50%;height:8px;position:absolute;right:8px;top:50%;transform:translateY(-50%);width:8px}@keyframes Chat-module_voiceCallIconPulse__zZbJn{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}@keyframes Chat-module_voiceCallPulse__XcGU4{0%,to{opacity:1;transform:translateY(-50%) scale(1)}50%{opacity:.6;transform:translateY(-50%) scale(1.3)}}.Chat-module_chatMessage__nmLaZ .Chat-module_voiceCallIndicator__tsaaG{border-radius:16px;font-size:12px;margin-bottom:8px;padding:6px 12px}.Chat-module_chatMessage__nmLaZ .Chat-module_voiceCallIndicator__tsaaG svg{height:14px;width:14px}.Chat-module_ratingConfirmation__n16vb{word-wrap:break-word;animation:Chat-module_confirmationSlideIn__5U-wz .3s ease-out;backdrop-filter:blur(20px);background:linear-gradient(135deg,#10b981,#059669);border-radius:12px;box-shadow:0 8px 32px rgba(16,185,129,.3);color:#fff;font-weight:500;max-width:300px;padding:16px 20px;position:fixed;right:20px;top:20px;z-index:1001}@keyframes Chat-module_confirmationSlideIn__5U-wz{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@media (max-width:768px){.Chat-module_actions__gTZ5T{gap:6px;margin:12px 16px 0}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N{padding:16px 12px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ{margin-bottom:16px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{border-radius:18px;font-size:14px;max-width:85%;padding:12px 16px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm{height:36px;margin:0 10px 4px;width:36px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img{aspect-ratio:1/1;width:36px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan{gap:10px;padding:16px 12px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea{border-radius:22px;font-size:16px;padding:14px 18px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button{height:44px;width:44px}.Chat-module_scrollToBottom__nzxdZ{font-size:18px;height:44px;top:calc(100% - 160px);width:44px}.Chat-module_chatButton__d9VgA{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_chatButton__d9VgA svg{height:18px!important;width:18px!important}.Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_useTemplateButton__xcJNR{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_useTemplateButton__xcJNR svg{height:18px!important;width:18px!important}.Chat-module_useTemplateButton__xcJNR .Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_ratingModalContent__CCdq7{border-radius:16px;margin:16px;max-height:80vh;overflow-y:auto;padding:24px 20px}.Chat-module_stars__PCzNO{gap:6px;margin-bottom:20px}.Chat-module_stars__PCzNO span{font-size:32px;padding:8px}.Chat-module_ratingActions__nXcss{flex-direction:column-reverse;gap:8px}.Chat-module_ratingActions__nXcss button{border-radius:10px;font-size:16px;padding:14px;width:100%}}@media (max-width:480px){.Chat-module_actions__gTZ5T{gap:4px;margin:8px 12px 0}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N{padding:12px 8px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{border-radius:16px;font-size:14px;max-width:90%;padding:10px 14px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm{height:32px;margin:0 8px 4px;width:32px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img{aspect-ratio:1/1;width:32px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan{gap:8px;padding:12px 8px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea{border-radius:20px;font-size:16px;padding:12px 16px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button{height:40px;width:40px}.Chat-module_chatButton__d9VgA{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_chatButton__d9VgA svg{height:18px!important;width:18px!important}.Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_useTemplateButton__xcJNR{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_useTemplateButton__xcJNR svg{height:18px!important;width:18px!important}.Chat-module_useTemplateButton__xcJNR .Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_scrollToBottom__nzxdZ{font-size:16px;height:40px;top:calc(100% - 140px);width:40px}.Chat-module_ratingModal__XVKYm{align-items:flex-end;padding:0}.Chat-module_ratingModalContent__CCdq7{border-radius:20px 20px 0 0;margin:0;max-height:70vh;padding:24px 16px 20px;width:100%}}@media (prefers-reduced-motion:reduce){.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ,.Chat-module_ratingConfirmation__n16vb,.Chat-module_ratingModalContent__CCdq7,.Chat-module_ratingModal__XVKYm,.Chat-module_scrollToBottom__nzxdZ{animation:none}.Chat-module_chatButton__d9VgA,.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button,.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea,.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img,.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{transition:none}}@media (prefers-contrast:high){.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{border:2px solid}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea{border-width:3px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button{border:2px solid}}\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["Chat.module.css"],"names":[],"mappings":"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","file":"Chat.module.css","sourcesContent":["@font-face {\n    font-family: 'OpenMojiBlack';\n    src: url('https://s6.ptbk.io/fonts/OpenMoji-black-glyf.woff2') format('woff2'); /* <- TODO: [🐱‍🚀] Dynamically load from /servers.ts */\n    unicode-range: U+23, U+2A, U+2D, U+30-39, U+A9, U+AE, U+200D, U+203C, U+2049, U+20E3, U+2117, U+2120, U+2122, U+2139,\n        U+2194-2199, U+21A9, U+21AA, U+229C, U+231A, U+231B, U+2328, U+23CF, U+23E9-23F3, U+23F8-23FE, U+24C2, U+25A1,\n        U+25AA-25AE, U+25B6, U+25C0, U+25C9, U+25D0, U+25D1, U+25E7-25EA, U+25ED, U+25EE, U+25FB-25FE, U+2600-2605,\n        U+260E, U+2611, U+2614, U+2615, U+2618, U+261D, U+2620, U+2622, U+2623, U+2626, U+262A, U+262E, U+262F,\n        U+2638-263A, U+2640, U+2642, U+2648-2653, U+265F, U+2660, U+2663, U+2665, U+2666, U+2668, U+267B, U+267E, U+267F,\n        U+2691-2697, U+2699, U+269B, U+269C, U+26A0, U+26A1, U+26A7, U+26AA, U+26AB, U+26B0, U+26B1, U+26BD, U+26BE,\n        U+26C4, U+26C5, U+26C8, U+26CE, U+26CF, U+26D1, U+26D3, U+26D4, U+26E9, U+26EA, U+26F0-26F5, U+26F7-26FA, U+26FD,\n        U+2702, U+2705, U+2708-270D, U+270F, U+2712, U+2714, U+2716, U+271D, U+2721, U+2728, U+2733, U+2734, U+2744,\n        U+2747, U+274C, U+274E, U+2753-2755, U+2757, U+2763, U+2764, U+2795-2797, U+27A1, U+27B0, U+27BF, U+2934, U+2935,\n        U+2B05-2B07, U+2B0C, U+2B0D, U+2B1B, U+2B1C, U+2B1F-2B24, U+2B2E, U+2B2F, U+2B50, U+2B55, U+2B58, U+2B8F,\n        U+2BBA-2BBC, U+2BC3, U+2BC4, U+2BEA, U+2BEB, U+3030, U+303D, U+3297, U+3299, U+E000-E009, U+E010, U+E011,\n        U+E040-E06D, U+E080-E0B4, U+E0C0-E0CC, U+E0FF-E10D, U+E140-E14A, U+E150-E157, U+E181-E189, U+E1C0-E1C4,\n        U+E1C6-E1D9, U+E200-E216, U+E240-E269, U+E280-E283, U+E2C0-E2C4, U+E2C6-E2DA, U+E300-E303, U+E305-E30F,\n        U+E312-E316, U+E318-E322, U+E324-E329, U+E32B, U+E340-E348, U+E380, U+E381, U+F000, U+F77A, U+F8FF, U+FE0F,\n        U+1F004, U+1F0CF, U+1F10D-1F10F, U+1F12F, U+1F16D-1F171, U+1F17E, U+1F17F, U+1F18E, U+1F191-1F19A, U+1F1E6-1F1FF,\n        U+1F201, U+1F202, U+1F21A, U+1F22F, U+1F232-1F23A, U+1F250, U+1F251, U+1F260-1F265, U+1F300-1F321, U+1F324-1F393,\n        U+1F396, U+1F397, U+1F399-1F39B, U+1F39E-1F3F0, U+1F3F3-1F3F5, U+1F3F7-1F4FD, U+1F4FF-1F53D, U+1F549-1F54E,\n        U+1F550-1F567, U+1F56F, U+1F570, U+1F573-1F57A, U+1F587, U+1F58A-1F58D, U+1F590, U+1F595, U+1F596, U+1F5A4,\n        U+1F5A5, U+1F5A8, U+1F5B1, U+1F5B2, U+1F5BC, U+1F5C2-1F5C4, U+1F5D1-1F5D3, U+1F5DC-1F5DE, U+1F5E1, U+1F5E3,\n        U+1F5E8, U+1F5EF, U+1F5F3, U+1F5FA-1F64F, U+1F680-1F6C5, U+1F6CB-1F6D2, U+1F6D5-1F6D7, U+1F6DC-1F6E5, U+1F6E9,\n        U+1F6EB, U+1F6EC, U+1F6F0, U+1F6F3-1F6FC, U+1F7E0-1F7EB, U+1F7F0, U+1F90C-1F93A, U+1F93C-1F945, U+1F947-1F9FF,\n        U+1FA70-1FA7C, U+1FA80-1FA88, U+1FA90-1FABD, U+1FABF-1FAC5, U+1FACE-1FADB, U+1FAE0-1FAE8, U+1FAF0-1FAF8,\n        U+1FBC5-1FBC9, U+E0061-E0067, U+E0069, U+E006C-E0079, U+E007F;\n}\n\n.copiedToClipboardMessage {\n    position: fixed;\n    top: 32px;\n    left: 50%;\n    transform: translateX(-50%);\n    background: #222;\n    color: #fff;\n    padding: 10px 24px;\n    border-radius: 8px;\n    font-size: 1.1em;\n    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.18);\n    opacity: 0.97;\n    pointer-events: none;\n    z-index: 9999;\n}\n\n.Chat {\n    width: 100%;\n    height: 100%;\n    display: flex;\n    flex-direction: column;\n\n    font-family: Arial, Helvetica, sans-serif, 'OpenMojiBlack';\n    /* <- TODO: [🧠][🎱] Better, define other fonts */\n}\n\n.chatMainFlow {\n    width: 100%;\n    height: 100%;\n    max-width: 100vw;\n    display: grid;\n    grid-template:\n        '🟦' min-content\n        '💬' 1fr\n        '📝' min-content\n        / 1fr;\n}\n\n.chatMainFlow .chatBar {\n    grid-area: 🟦;\n    width: 100%;\n    padding: 16px 20px;\n    color: #0f1724;\n    background-color: #ffffff;\n    border-bottom: 1px solid rgba(15, 23, 36, 0.06);\n    text-align: center;\n    font-weight: 500;\n}\n\n.TasksInProgress {\n    grid-area: 🟦;\n    width: auto;\n    height: min-content;\n    align-self: center;\n    justify-self: self-end;\n    margin: 8px 16px;\n}\n\n.actions {\n    grid-area: 💬;\n    width: auto;\n    height: min-content;\n    z-index: 200;\n    align-self: self-start;\n    justify-self: self-end;\n    margin: 16px 20px 0;\n    display: flex;\n    align-items: center;\n    gap: 8px;\n}\n\n.actions.portal {\n    margin: 0;\n}\n\n.actions.left {\n    justify-self: self-start;\n}\n\n.actions.right {\n    justify-self: self-end;\n}\n\n/* Large tablet and small desktop screens */\n@media (max-width: 900px) {\n    .chatButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .chatButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .chatButtonText {\n        display: none !important;\n    }\n\n    .useTemplateButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .useTemplateButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .useTemplateButton .chatButtonText {\n        display: none !important;\n    }\n}\n\n/* Medium screens */\n@media (max-width: 600px) {\n    .actions {\n        margin: 14px 18px 0;\n        gap: 7px;\n    }\n}\n\n.chatMainFlow .chatChildren {\n    grid-area: 💬;\n    width: 100%;\n    height: 100%;\n    z-index: 300;\n}\n\n/* Chat messages area */\n.chatMainFlow .chatMessages {\n    grid-area: 💬;\n    width: 100%;\n    height: 100%;\n    z-index: 10;\n    padding: 24px 20px 16px;\n    overflow-y: auto;\n    overflow-x: hidden;\n    scroll-behavior: smooth;\n}\n\n/* Custom scrollbar styling */\n.chatMainFlow .chatMessages::-webkit-scrollbar {\n    width: 6px;\n}\n\n.chatMainFlow .chatMessages::-webkit-scrollbar-track {\n    background: transparent;\n}\n\n.chatMainFlow .chatMessages::-webkit-scrollbar-thumb {\n    background: rgba(125, 125, 125, 0.2);\n    border-radius: 3px;\n    transition: all 0.2s ease;\n}\n\n.chatMainFlow .chatMessages::-webkit-scrollbar-thumb:hover {\n    background: rgba(125, 125, 125, 0.3);\n}\n\n/* Individual chat message */\n.chatMainFlow .chatMessage {\n    display: flex;\n    margin-bottom: 20px;\n    align-items: flex-end;\n    flex-direction: row;\n    position: relative;\n    animation: messageSlideIn 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    max-width: 100%;\n}\n\n/* Add top margin to first message if actions are present and first message is long */\n.hasActionsAndFirstMessageIsLong {\n    margin-top: 55px;\n}\n\n@keyframes messageSlideIn {\n    from {\n        opacity: 0;\n        transform: translateY(20px) scale(0.95);\n    }\n    to {\n        opacity: 1;\n        transform: translateY(0) scale(1);\n    }\n}\n\n.isNotCompleteMessage {\n    /*/\n    outline: 1px dotted #ff0000 !important;\n    /**/\n\n    opacity: 0.7;\n    position: relative;\n}\n\n.NonCompleteMessageFiller {\n    color: transparent;\n}\n\n/* Enhanced loading states for messages */\n.isNotCompleteMessage .messageText::after {\n    content: '';\n    position: absolute;\n    bottom: 8px;\n    right: 12px;\n    width: 20px;\n    height: 4px;\n    background: linear-gradient(90deg, transparent, rgba(125, 125, 125, 0.6), transparent);\n    border-radius: 2px;\n    animation: loadingPulse 1.5s ease-in-out infinite;\n}\n\n@keyframes loadingPulse {\n    0%,\n    100% {\n        opacity: 0.3;\n        transform: scaleX(0.8);\n    }\n    50% {\n        opacity: 1;\n        transform: scaleX(1.2);\n    }\n}\n\n/* Typing indicator for AI messages */\n.typingIndicator {\n    display: flex;\n    align-items: flex-end;\n    margin-bottom: 20px;\n    animation: messageSlideIn 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n\n.typingIndicator .avatar {\n    width: 40px;\n    height: 40px;\n    margin: 0 12px 4px;\n    flex-shrink: 0;\n}\n\n.typingIndicator .avatar img {\n    width: 40px;\n    aspect-ratio: 1 / 1;\n    border-radius: 50%;\n    object-fit: cover;\n    background-color: #eef6fb;\n    border: 2px solid rgba(125, 125, 125, 0.1);\n}\n\n.typingBubble {\n    padding: 16px 20px;\n    border-radius: 20px;\n    border-bottom-left-radius: 6px;\n    border: 1px solid rgba(125, 125, 125, 0.1);\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);\n    backdrop-filter: blur(10px);\n    display: flex;\n    align-items: center;\n    gap: 4px;\n    min-height: 24px;\n}\n\n.typingDots {\n    display: flex;\n    gap: 4px;\n    align-items: center;\n}\n\n.typingDot {\n    width: 8px;\n    height: 8px;\n    border-radius: 50%;\n    background: linear-gradient(135deg, #6b7280 0%, rgba(125, 125, 125, 0.6) 100%);\n    animation: typingBounce 1.4s infinite ease-in-out;\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n}\n\n.typingDot:nth-child(1) {\n    animation-delay: -0.32s;\n}\n\n.typingDot:nth-child(2) {\n    animation-delay: -0.16s;\n}\n\n.typingDot:nth-child(3) {\n    animation-delay: 0s;\n}\n\n@keyframes typingBounce {\n    0%,\n    80%,\n    100% {\n        transform: scale(0.8) translateY(0);\n        opacity: 0.5;\n    }\n    40% {\n        transform: scale(1.2) translateY(-8px);\n        opacity: 1;\n    }\n}\n\n.chatMainFlow .chatMessage.isMe {\n    align-items: flex-end;\n    flex-direction: row-reverse;\n    justify-content: flex-start;\n}\n\n.chatMainFlow .chatMessage.isMe .messageText {\n    border-bottom-right-radius: 6px;\n}\n\n.ratingStar {\n    cursor: pointer;\n    font-size: 20px;\n    transition: color 0.2s;\n    color: var(--star-inactive-color, #ccc);\n}\n\n.ratingStar.active {\n    color: #ffd700;\n}\n\n/* Sender Avatar */\n.chatMainFlow .chatMessage .avatar {\n    width: 40px;\n    aspect-ratio: 1 / 1;\n    margin: 0 12px 4px;\n    flex-shrink: 0;\n    position: relative;\n}\n\n.chatMainFlow .chatMessage .avatar img {\n    width: 40px;\n    aspect-ratio: 1 / 1;\n    border-radius: 50%;\n    object-fit: cover;\n    background-color: var(--avatar-bg-color, #eef6fb);\n    border: 2px solid rgba(125, 125, 125, 0.1);\n    transition: transform 0.2s ease, box-shadow 0.2s ease;\n}\n\n.chatMainFlow .chatMessage .avatar img:hover {\n    transform: scale(1.05);\n    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n}\n\n/* Message text bubble */\n.chatMainFlow .chatMessage .messageText {\n    background-color: var(--message-bg-color);\n    color: var(--message-text-color);\n    position: relative;\n    padding: 14px 18px;\n    border-radius: 20px;\n    max-width: min(70%, 600px);\n    text-align: left;\n    margin-bottom: 4px;\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);\n    line-height: 1.5;\n    word-wrap: break-word;\n    transition: all 0.2s ease;\n    font-size: 15px;\n    backdrop-filter: blur(10px);\n}\n\n/* Copy button styles */\n.copyButtonContainer {\n    float: right;\n    top: 8px;\n    right: 10px;\n    z-index: 2;\n    align-items: center;\n    justify-content: flex-end;\n    pointer-events: none;\n\n    visibility: hidden;\n}\n.chatMainFlow .chatMessage .messageText:hover .copyButtonContainer,\n.copyButtonContainer:focus-within {\n    visibility: visible;\n    pointer-events: auto;\n}\n\n.copyButton {\n    background: rgba(255, 255, 255, 0.2);\n    border: 1px solid #ddd;\n    border-radius: 6px;\n    padding: 2px 5px;\n    cursor: pointer;\n    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.07);\n    transition: all 0.15s, box-shadow 0.15s, border 0.15s;\n    display: flex;\n    align-items: center;\n    opacity: 0.7;\n    position: relative;\n}\n\n.copiedTooltip {\n    position: absolute;\n    left: 50%;\n    top: 110%;\n    transform: translateX(-50%);\n    background: #222;\n    color: #fff;\n    padding: 6px 16px;\n    border-radius: 8px;\n    font-size: 0.98em;\n    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.18);\n    opacity: 0.97;\n    pointer-events: none;\n    z-index: 100;\n    white-space: nowrap;\n    margin-top: 4px;\n    animation: copiedTooltipFadeIn 0.2s;\n    max-width: 220px;\n    overflow-wrap: break-word;\n    word-break: break-word;\n}\n\n.copiedTooltipLeft {\n    left: 0 !important;\n    transform: none !important;\n}\n\n.copiedTooltipRight {\n    left: auto !important;\n    right: 0 !important;\n    transform: none !important;\n}\n\n/* Removed right-aligned override to keep tooltip position stable */\n\n@keyframes copiedTooltipFadeIn {\n    from {\n        opacity: 0;\n        transform: translateX(-50%) translateY(8px) scale(0.97);\n    }\n    to {\n        opacity: 0.97;\n        transform: translateX(-50%) translateY(0) scale(1);\n    }\n}\n\n.copyButton:hover,\n.copyButton:focus {\n    border: 1.5px solid #bbb;\n    opacity: 1;\n    box-shadow: 0 2px 8px rgba(0, 132, 255, 0.1);\n}\n\n.copyButton svg {\n    display: block;\n}\n\n.messageText h1 {\n    font-size: 2em;\n}\n\n.messageText h2 {\n    font-size: 1.75em;\n}\n\n.messageText h3 {\n    font-size: 1.5em;\n}\n\n.messageText h4 {\n    font-size: 1.25em;\n}\n\n.messageText h5 {\n    font-size: 1.1em;\n}\n\n.messageText ul {\n    list-style: disc;\n    margin-left: 20px;\n}\n\n.messageText ol {\n    list-style: decimal;\n    margin-left: 20px;\n}\n\n.messageText img,\n.messageText pre,\n.messageText blockquote,\n.messageText table {\n    margin-top: 10px;\n    margin-bottom: 10px;\n    border-radius: 8px;\n}\n\n.messageText pre {\n    display: block;\n    border: none;\n    box-shadow: none;\n    background: #000000ff;\n    font-size: inherit;\n    line-height: inherit;\n    color: #fff;\n    padding: 1em;\n}\n\n.messageText blockquote {\n    display: block;\n    border: none;\n    box-shadow: none;\n    background: #ffffffcc;\n    font-size: inherit;\n    line-height: inherit;\n    color: #000;\n    padding: 1em;\n}\n\n.messageText code {\n    display: inline-block;\n    margin: 0;\n    padding: 0;\n    border: none;\n    box-shadow: none;\n    background: #cccccc55;\n    font-size: inherit;\n    line-height: inherit;\n    color: inherit;\n}\n\n.messageText pre code {\n    background-color: #000000cc;\n    border-radius: 8px;\n}\n\n.messageText .chat-code-block {\n    background: #181c23;\n    color: #f8fafc;\n    font-size: 14px;\n    line-height: 1.6;\n    overflow-x: auto;\n    border-color: #23272f;\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);\n    font-family: 'Fira Mono', 'Menlo', 'Consolas', 'Liberation Mono', monospace;\n}\n.messageText .chat-code-block code {\n    background: none !important;\n    color: inherit !important;\n    font-family: inherit !important;\n    font-size: inherit !important;\n    padding: 0 !important;\n    border: none !important;\n    box-shadow: none !important;\n    white-space: pre;\n    word-break: break-word;\n    overflow-x: auto;\n    display: block;\n}\n.messageText table {\n    width: 100%;\n    border-collapse: separate;\n    border-spacing: 0;\n    margin: 16px 0;\n    background: #f8fafc; /* Stronger light background for contrast */\n    border-radius: 12px;\n    overflow: hidden;\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);\n    font-size: 14px;\n    color: #17223b; /* Dark text for contrast */\n}\n.messageText th,\n.messageText td {\n    padding: 10px 16px;\n    border-bottom: 1px solid #d1dbe8;\n    text-align: left;\n    color: #17223b; /* Ensure strong text color for all cells */\n    background: none;\n}\n.messageText th {\n    background: linear-gradient(90deg, #eaf3fa 80%, #d1e3f8 100%);\n    font-weight: 700;\n    color: #17223b; /* Strong header text */\n    border-bottom: 2px solid #b5c7de;\n}\n.messageText tr:last-child td {\n    border-bottom: none;\n}\n.messageText tr:nth-child(even) td {\n    background: #eaf3fa;\n}\n.messageText tr:hover td {\n    background: #cbe0f7;\n    transition: background 0.2s;\n}\n.messageText table {\n    border-radius: 12px;\n    overflow: hidden;\n}\n.messageText th:first-child,\n.messageText td:first-child {\n    border-top-left-radius: 12px;\n}\n.messageText th:last-child,\n.messageText td:last-child {\n    border-top-right-radius: 12px;\n}\n\n.chatMainFlow .chatMessage .messageText:hover {\n    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);\n    transform: translateY(-1px);\n}\n\n/* Message buttons container */\n.messageButtons {\n    display: flex;\n    flex-wrap: wrap;\n    gap: 8px;\n    margin-top: 12px;\n    padding-top: 12px;\n    border-top: 1px solid rgba(125 125 125 / 0.83);\n}\n\n/* Individual message button */\n.messageButton {\n    display: inline-flex;\n    align-items: center;\n    padding: 8px 14px;\n    background: rgba(125, 125, 125, 0.1);\n    border: 1px solid rgba(125, 125, 125, 0.9);\n    border-radius: 16px;\n    font-size: 13px;\n    font-weight: 500;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    backdrop-filter: blur(10px);\n    -webkit-tap-highlight-color: transparent;\n    touch-action: manipulation;\n    user-select: none;\n}\n\n.messageButton:hover {\n    background: rgba(0, 132, 255, 0.1);\n    border-color: rgba(0, 132, 255, 0.3);\n    transform: translateY(-1px);\n    box-shadow: 0 2px 8px rgba(0, 132, 255, 0.15);\n}\n\n.messageButton:active {\n    transform: scale(0.98);\n    transition: transform 0.1s ease;\n}\n\n/* Remove default markdown styles from button content */\n.messageButton p {\n    margin: 0;\n    padding: 0;\n    line-height: inherit;\n}\n\n.messageButton strong {\n    font-weight: 600;\n}\n\n.messageButton em {\n    font-style: italic;\n}\n\n/* Rating system */\n.chatMainFlow .chatMessage .rating {\n    position: absolute;\n    bottom: -8px;\n    right: 8px;\n    display: flex;\n    gap: 2px;\n    align-items: center;\n    min-width: 24px;\n    z-index: 1;\n    background: rgba(0, 0, 0, 0.8);\n    border-radius: 12px;\n    padding: 4px 6px;\n    backdrop-filter: blur(10px);\n    opacity: 0;\n    transform: translateY(4px);\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n\n.chatMainFlow .chatMessage:hover .rating {\n    opacity: 1;\n    transform: translateY(0);\n}\n\n.chatMainFlow .chatMessage .rating:hover {\n    background: rgba(0, 0, 0, 0.9);\n    padding: 6px 8px;\n    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);\n}\n\n.chatMainFlow .chatMessage .rating span {\n    transition: transform 0.2s ease, color 0.2s ease;\n    display: inline-block;\n    cursor: pointer;\n    font-size: 16px;\n}\n\n.chatMainFlow .chatMessage .rating:hover span {\n    transform: scale(1.1);\n}\n\n/* Chat input area */\n.chatMainFlow .chatInput {\n    z-index: 10;\n    grid-area: 📝;\n    width: 100%;\n    padding: 20px;\n    backdrop-filter: blur(20px);\n    border-top: 1px solid rgba(125, 125, 125, 0.1);\n    display: flex;\n    flex-direction: column;\n    gap: 12px;\n    position: relative;\n}\n\n/* File upload drag-and-drop styles */\n.chatMainFlow .chatInput.dragOver {\n    background: linear-gradient(to top, rgba(0, 132, 255, 0.1) 0%, rgba(0, 132, 255, 0.05) 100%);\n    border-top: 2px solid rgba(0, 132, 255, 0.3);\n}\n\n/* File preview container */\n.filePreviewContainer {\n    display: flex;\n    flex-wrap: wrap;\n    gap: 8px;\n    margin-bottom: 8px;\n}\n\n/* Individual file preview */\n.filePreview {\n    display: flex;\n    align-items: center;\n    gap: 8px;\n    padding: 8px 12px;\n    background: rgba(125, 125, 125, 0.1);\n    border: 1px solid rgba(125, 125, 125, 0.2);\n    border-radius: 8px;\n    font-size: 12px;\n    backdrop-filter: blur(10px);\n    transition: all 0.2s ease;\n}\n\n.filePreview:hover {\n    background: rgba(125, 125, 125, 0.15);\n    border-color: rgba(125, 125, 125, 0.3);\n}\n\n.fileIcon {\n    font-size: 14px;\n    opacity: 0.7;\n}\n\n.fileInfo {\n    display: flex;\n    flex-direction: column;\n    gap: 2px;\n    min-width: 0;\n}\n\n.fileName {\n    font-weight: 500;\n    color: black;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    max-width: 150px;\n}\n\n.fileSize {\n    color: #6b7280;\n    font-size: 11px;\n}\n\n.removeFileButton {\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    width: 20px;\n    height: 20px;\n    border: none;\n    background: rgba(255, 0, 0, 0.1);\n    color: #ff4444;\n    border-radius: 50%;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    flex-shrink: 0;\n}\n\n.removeFileButton:hover {\n    background: rgba(255, 0, 0, 0.2);\n    transform: scale(1.1);\n}\n\n/* Input container for textarea and buttons */\n.inputContainer {\n    display: flex;\n    align-items: center;\n    gap: 12px;\n}\n\n.inputContainer textarea::placeholder {\n    color: inherit;\n    opacity: 0.7;\n}\n\n/* Attachment button */\n.attachmentButton {\n    width: 40px;\n    height: 40px;\n    border: 1px solid rgba(125, 125, 125, 0.2);\n    background: rgba(125, 125, 125, 0.05);\n    color: #6b7280;\n    border-radius: 50%;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    backdrop-filter: blur(10px);\n    flex-shrink: 0;\n}\n\n.attachmentButton:hover:not(:disabled) {\n    background: rgba(0, 132, 255, 0.1);\n    border-color: rgba(0, 132, 255, 0.3);\n    color: #0084ff;\n    transform: scale(1.05);\n}\n\n.attachmentButton:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n    transform: none;\n}\n\n/* Voice Button */\n.voiceButton {\n    width: 40px;\n    height: 40px;\n    border: 1px solid rgba(125, 125, 125, 0.2);\n    background: rgba(125, 125, 125, 0.05);\n    color: #6b7280;\n    border-radius: 50%;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    backdrop-filter: blur(10px);\n    flex-shrink: 0;\n}\n\n.voiceButton:hover {\n    background: rgba(0, 132, 255, 0.1);\n    border-color: rgba(0, 132, 255, 0.3);\n    color: #0084ff;\n    transform: scale(1.05);\n}\n\n.voiceButtonActive {\n    background: rgba(255, 0, 0, 0.1) !important;\n    border-color: rgba(255, 0, 0, 0.3) !important;\n    color: #ff0000 !important;\n    animation: voiceRecordingPulse 1.5s infinite;\n}\n\n@keyframes voiceRecordingPulse {\n    0% {\n        box-shadow: 0 0 0 0 rgba(255, 0, 0, 0.4);\n    }\n    70% {\n        box-shadow: 0 0 0 10px rgba(255, 0, 0, 0);\n    }\n    100% {\n        box-shadow: 0 0 0 0 rgba(255, 0, 0, 0);\n    }\n}\n\n/* Upload progress indicator */\n.uploadProgress {\n    display: flex;\n    align-items: center;\n    gap: 12px;\n    padding: 8px 12px;\n    background: rgba(0, 132, 255, 0.1);\n    border: 1px solid rgba(0, 132, 255, 0.2);\n    border-radius: 8px;\n    font-size: 13px;\n    color: #0084ff;\n}\n\n.uploadProgressBar {\n    flex: 1;\n    height: 4px;\n    background: rgba(0, 132, 255, 0.2);\n    border-radius: 2px;\n    overflow: hidden;\n}\n\n.uploadProgressFill {\n    height: 100%;\n    background: linear-gradient(90deg, #0084ff, rgba(0, 132, 255, 0.8));\n    border-radius: 2px;\n    animation: uploadProgress 1.5s ease-in-out infinite;\n}\n\n@keyframes uploadProgress {\n    0% {\n        transform: translateX(-100%);\n    }\n    50% {\n        transform: translateX(0%);\n    }\n    100% {\n        transform: translateX(100%);\n    }\n}\n\n/* Drag overlay */\n.dragOverlay {\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    background: rgba(0, 132, 255, 0.1);\n    border: 2px dashed rgba(0, 132, 255, 0.5);\n    border-radius: 12px;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    backdrop-filter: blur(10px);\n    z-index: 20;\n    pointer-events: none;\n}\n\n.dragOverlayContent {\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n    gap: 12px;\n    color: #0084ff;\n    font-weight: 600;\n    text-align: center;\n}\n\n.dragOverlayContent svg {\n    opacity: 0.7;\n}\n\n/* Chat input field */\n.chatMainFlow .chatInput textarea {\n    flex: 1;\n    padding: 16px 20px;\n\n    outline: none;\n    border-radius: 25px;\n    background: rgba(125, 125, 125, 0.05);\n    backdrop-filter: blur(20px);\n    color: black;\n    min-width: 200px;\n    max-height: 120px;\n    font-size: 15px;\n    line-height: 1.4;\n    resize: none;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    appearance: none;\n    -webkit-appearance: none;\n    -webkit-tap-highlight-color: transparent;\n    touch-action: manipulation;\n}\n\n.chatMainFlow .chatInput textarea:focus {\n    border-color: #0084ff;\n    background: rgba(125, 125, 125, 0.08);\n    box-shadow: 0 0 0 4px rgba(0, 132, 255, 0.1), 0 8px 32px rgba(0, 132, 255, 0.15);\n    transform: translateY(-2px);\n}\n\n.chatMainFlow .chatInput textarea:disabled {\n    opacity: 0.6;\n    cursor: not-allowed;\n    transform: none;\n}\n\n.chatMainFlow .chatInput textarea::placeholder {\n    color: inherit;\n    opacity: 0.7;\n}\n\n/* Chat send button */\n.chatMainFlow .chatInput button {\n    width: 48px;\n    height: 48px;\n    margin: 0 !important;\n    padding: 0 !important;\n\n    border: none;\n    /* background: linear-gradient(135deg, #0084ff 0%, #0066cc 100%); */\n    /* <- Note: Background is set in the inline style */\n    color: #ffffff;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    border-radius: 50% !important;\n    aspect-ratio: 1 / 1;\n    min-width: unset !important;\n    min-height: unset !important;\n    padding-left: unset;\n    padding-right: unset;\n\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3);\n    -webkit-tap-highlight-color: transparent;\n    touch-action: manipulation;\n    user-select: none;\n    overflow: visible;\n}\n\n.chatMainFlow .chatInput button img {\n    width: 50%;\n    height: 100%;\n    object-fit: contain;\n}\n\n/* Scroll to bottom button */\n\n.scrollToBottomContainer {\n    /*/\n    outline: 1px dotted red;\n    /**/\n\n    z-index: 20;\n    grid-area: 📝;\n    width: 100%;\n    height: 100%;\n    display: flex;\n    justify-content: center;\n    align-items: flex-start;\n\n    pointer-events: none;\n}\n\n.scrollToBottomContainer .scrollToBottom {\n    pointer-events: all;\n\n    transform: translate(-50%, -150%);\n    width: 48px;\n    height: 48px;\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    border: none;\n    outline: none;\n    background: rgba(0 0 0 / 0.5);\n    backdrop-filter: blur(3px);\n    border-radius: 50%;\n    font-weight: bold;\n    color: white;\n    cursor: pointer;\n    -webkit-tap-highlight-color: transparent;\n    touch-action: manipulation;\n    user-select: none;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);\n    animation: scrollButtonSlideIn 0.3s ease-out;\n}\n\n@keyframes scrollButtonSlideIn {\n    from {\n        opacity: 0;\n        transform: translate(-50%, 20px) scale(0.8);\n    }\n    to {\n        opacity: 0.9;\n        transform: translate(-50%, 0) scale(1);\n    }\n}\n\n.scrollToBottom:hover {\n    transform: translate(-50%, -160%) scale(1.05);\n}\n\n.scrollToBottom:active {\n    transform: translate(-50%, -160%) scale(0.95);\n    transition: transform 0.1s ease;\n}\n\n/* Rating modal */\n.ratingModal {\n    position: fixed;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n\n    background-color: rgba(0, 0, 0, 0.6);\n    backdrop-filter: blur(8px);\n\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    z-index: 1000;\n    animation: modalFadeIn 0.3s ease-out;\n}\n\n@keyframes modalFadeIn {\n    from {\n        opacity: 0;\n        backdrop-filter: blur(0px);\n    }\n    to {\n        opacity: 1;\n        backdrop-filter: blur(8px);\n    }\n}\n\n.ratingModalContent {\n    background: #ffffff;\n    color: #0f1724;\n    padding: 32px;\n    border-radius: 16px;\n    width: 90%;\n    max-width: 480px;\n    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);\n    border: 1px solid rgba(125, 125, 125, 0.1);\n    backdrop-filter: blur(20px);\n    animation: modalSlideIn 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n\n    font-family: Arial, Helvetica, sans-serif, 'OpenMojiBlack';\n    /* <- TODO: [🧠][🎱] Better, define other fonts */\n}\n\n@keyframes modalSlideIn {\n    from {\n        opacity: 0;\n        transform: translateY(20px) scale(0.95);\n    }\n    to {\n        opacity: 1;\n        transform: translateY(0) scale(1);\n    }\n}\n\n.ratingModalContent h3 {\n    margin: 0 0 24px 0;\n    text-align: center;\n    color: black;\n    font-size: 20px;\n    font-weight: 600;\n}\n\n.stars {\n    display: flex;\n    justify-content: center;\n    gap: 8px;\n    margin-bottom: 24px;\n}\n\n.stars span {\n    font-size: 28px;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    padding: 4px;\n    border-radius: 8px;\n}\n\n.stars span:hover {\n    transform: scale(1.2);\n    background: rgba(255, 215, 0, 0.1);\n}\n\n.ratingModalStar {\n    cursor: pointer;\n    font-size: 24px;\n    transition: color 0.2s;\n}\n\n.ratingInput {\n    width: 100%;\n    min-height: 100px;\n    padding: 16px;\n    border: 2px solid rgba(125, 125, 125, 0.1);\n    border-radius: 12px;\n    margin-bottom: 18px;\n    resize: vertical;\n    background: rgba(125, 125, 125, 0.05);\n    color: #0b1220;\n    font-size: 14px;\n    line-height: 1.5;\n    transition: all 0.2s ease;\n}\n\n.ratingInput:focus {\n    border-color: #0084ff;\n    background: rgba(125, 125, 125, 0.08);\n    box-shadow: 0 0 0 4px rgba(0, 132, 255, 0.1);\n    outline: none;\n}\n\n.ratingInput[readonly] {\n    border: 1px solid rgba(125, 125, 125, 0.5);\n    background: rgba(125, 125, 125, 0.01);\n}\n\n.ratingActions {\n    display: flex;\n    justify-content: flex-end;\n    gap: 12px;\n}\n\n.ratingActions button {\n    padding: 12px 24px;\n    border: none;\n    border-radius: 8px;\n    cursor: pointer;\n    font-size: 14px;\n    font-weight: 500;\n    transition: all 0.2s ease;\n    min-width: 80px;\n}\n\n.ratingActions button:first-child {\n    background-color: rgba(125, 125, 125, 0.1);\n    color: #0b1220;\n    border: 1px solid rgba(125, 125, 125, 0.2);\n}\n\n.ratingActions button:first-child:hover:not(:disabled) {\n    background-color: rgba(125, 125, 125, 0.2);\n    color: #0b1220;\n}\n\n.ratingActions button:last-child {\n    background: linear-gradient(135deg, #0084ff 0%, #0066cc 100%);\n    color: #ffffff;\n}\n\n.ratingActions button:last-child:hover:not(:disabled) {\n    background: linear-gradient(135deg, #0071d1 0%, #0052a3 100%);\n    transform: translateY(-1px);\n    box-shadow: 0 4px 12px rgba(0, 132, 255, 0.3);\n}\n\n.ratingActions button:last-child:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n}\n\n/* New chat button styling - Matches the sleek chat message design */\n.chatButton {\n    display: inline-flex !important;\n    align-items: center !important;\n    justify-content: center !important;\n    gap: 8px !important;\n    padding: 12px 16px !important;\n    margin: 0 !important;\n    background: linear-gradient(135deg, #0084ff 0%, #0066cc 100%) !important;\n    color: #ffffff !important;\n    border: none !important;\n    border-radius: 20px !important;\n    font-size: 13px !important;\n    font-weight: 600 !important;\n    line-height: 1.3 !important;\n    cursor: pointer !important;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3) !important;\n    backdrop-filter: blur(20px) !important;\n    -webkit-tap-highlight-color: transparent !important;\n    touch-action: manipulation !important;\n    user-select: none !important;\n    min-height: 40px !important;\n    min-width: 110px !important;\n    position: relative !important;\n    overflow: hidden !important;\n}\n\n.chatButton::before {\n    content: '';\n    position: absolute;\n    top: 0;\n    left: -100%;\n    width: 100%;\n    height: 100%;\n    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);\n    transition: left 0.5s ease;\n}\n\n.chatButton:hover::before {\n    left: 100%;\n}\n\n.chatButton:hover:not(:disabled) {\n    background: linear-gradient(135deg, #0099ff 0%, #0077dd 100%);\n    transform: translateY(-2px) scale(1.02);\n    box-shadow: 0 8px 24px rgba(0, 132, 255, 0.4);\n}\n\n.chatButton:active {\n    transform: scale(0.98) translateY(-1px);\n    transition: transform 0.1s ease;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3);\n}\n\n.chatButton:focus {\n    outline: none;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3), 0 0 0 3px rgba(0, 132, 255, 0.3);\n}\n\n.chatButton svg {\n    width: 16px;\n    height: 16px;\n    flex-shrink: 0;\n    opacity: 1;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.2));\n}\n\n.chatButton:hover svg {\n    transform: rotate(-90deg) scale(1.1);\n    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));\n}\n\n.chatButtonText {\n    white-space: nowrap;\n    font-weight: 600;\n    transition: all 0.2s ease;\n    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);\n    opacity: 1;\n}\n\n.chatButton:hover .chatButtonText {\n    transform: translateX(1px);\n}\n\n/* Use template button styling - matches the chatButton and saveButton */\n.useTemplateButton {\n    display: inline-flex !important;\n    align-items: center !important;\n    justify-content: center !important;\n    gap: 8px !important;\n    padding: 12px 16px !important;\n    margin: 0 !important;\n    background: linear-gradient(135deg, #0084ff 0%, #0066cc 100%) !important;\n    color: #ffffff !important;\n    border: none !important;\n    border-radius: 20px !important;\n    font-size: 13px !important;\n    font-weight: 600 !important;\n    line-height: 1.3 !important;\n    cursor: pointer !important;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3) !important;\n    backdrop-filter: blur(20px) !important;\n    -webkit-tap-highlight-color: transparent !important;\n    touch-action: manipulation !important;\n    user-select: none !important;\n    min-height: 40px !important;\n    min-width: 110px !important;\n    position: relative !important;\n    overflow: hidden !important;\n}\n\n.useTemplateButton::before {\n    content: '';\n    position: absolute;\n    top: 0;\n    left: -100%;\n    width: 100%;\n    height: 100%;\n    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);\n    transition: left 0.5s ease;\n}\n\n.useTemplateButton:hover::before {\n    left: 100%;\n}\n\n.useTemplateButton:hover:not(:disabled) {\n    background: linear-gradient(135deg, #0099ff 0%, #0077dd 100%);\n    transform: translateY(-2px) scale(1.02);\n    box-shadow: 0 8px 24px rgba(0, 132, 255, 0.4);\n}\n\n.useTemplateButton:active {\n    transform: scale(0.98) translateY(-1px);\n    transition: transform 0.1s ease;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3);\n}\n\n.useTemplateButton:focus {\n    outline: none;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3), 0 0 0 3px rgba(0, 132, 255, 0.3);\n}\n\n.useTemplateButton svg {\n    width: 16px;\n    height: 16px;\n    flex-shrink: 0;\n    opacity: 1;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.2));\n}\n\n.useTemplateButton:hover svg {\n    transform: scale(1.1);\n    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));\n}\n\n.useTemplateButton:hover .chatButtonText {\n    transform: translateX(1px);\n}\n\n.saveButtonContainer {\n    display: inline-block;\n    position: relative;\n}\n\n.saveMenu {\n    position: absolute;\n    top: 100%;\n    left: 0;\n    background: #fff;\n    border: 1px solid #ddd;\n    z-index: 10;\n    min-width: 120px;\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);\n}\n\n.saveMenuItem {\n    display: block;\n    width: 100%;\n    padding: 8px 16px;\n    border: none;\n    background: none;\n    text-align: left;\n    cursor: pointer;\n    color: #111;\n}\n\n.saveMenuItem:hover {\n    background-color: #f0f0f0;\n}\n\n/* Pause/Resume button variant (reuses .chatButton base styles for DRY) */\n.pauseButton {\n    background: linear-gradient(135deg, #ffb347 0%, #ff8c42 100%) !important; /* Warm orange for \"active/running\" */\n}\n\n.pauseButton:hover:not(:disabled) {\n    background: linear-gradient(135deg, #ffc067 0%, #ff9e5f 100%) !important;\n}\n\n.pauseButton.pausing {\n    opacity: 0.6 !important;\n    cursor: wait !important;\n}\n\n.pauseButton.paused {\n    background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important; /* Green when paused (ready to resume) */\n}\n\n.pauseButton.paused:hover:not(:disabled) {\n    background: linear-gradient(135deg, #34d399 0%, #059669 100%) !important;\n    transform: translateY(-2px) scale(1.02);\n    box-shadow: 0 8px 24px rgba(16, 185, 129, 0.35);\n}\n\n.pauseButton svg {\n    transition: transform 0.3s ease;\n}\n\n.pauseButton.paused svg {\n    transform: scale(1.1);\n}\n\n.pauseButton.pausing svg {\n    opacity: 0.8;\n}\n\n/* Voice call indicator bar */\n.voiceCallIndicatorBar {\n    grid-area: 🟦;\n    width: 100%;\n    padding: 12px 20px;\n    background: linear-gradient(135deg, rgba(34, 197, 94, 0.1) 0%, rgba(16, 185, 129, 0.1) 100%);\n    border-bottom: 1px solid rgba(34, 197, 94, 0.3);\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    backdrop-filter: blur(10px);\n}\n\n/* Voice call indicator */\n.voiceCallIndicator {\n    display: inline-flex;\n    align-items: center;\n    gap: 8px;\n    padding: 8px 16px;\n    background: linear-gradient(135deg, rgba(34, 197, 94, 0.2) 0%, rgba(16, 185, 129, 0.2) 100%);\n    border: 1px solid rgba(34, 197, 94, 0.4);\n    border-radius: 20px;\n    color: #10b981;\n    font-size: 13px;\n    font-weight: 600;\n    backdrop-filter: blur(10px);\n    box-shadow: 0 2px 8px rgba(34, 197, 94, 0.2);\n    position: relative;\n}\n\n.voiceCallIndicator svg {\n    width: 16px;\n    height: 16px;\n    flex-shrink: 0;\n    animation: voiceCallIconPulse 2s ease-in-out infinite;\n}\n\n.voiceCallIndicator span {\n    font-weight: 600;\n    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);\n}\n\n/* Voice call pulse animation */\n.voiceCallPulse {\n    position: absolute;\n    right: 8px;\n    top: 50%;\n    transform: translateY(-50%);\n    width: 8px;\n    height: 8px;\n    background: #10b981;\n    border-radius: 50%;\n    animation: voiceCallPulse 1.5s ease-in-out infinite;\n}\n\n@keyframes voiceCallIconPulse {\n    0%,\n    100% {\n        transform: scale(1);\n        opacity: 1;\n    }\n    50% {\n        transform: scale(1.1);\n        opacity: 0.8;\n    }\n}\n\n@keyframes voiceCallPulse {\n    0%,\n    100% {\n        transform: translateY(-50%) scale(1);\n        opacity: 1;\n    }\n    50% {\n        transform: translateY(-50%) scale(1.3);\n        opacity: 0.6;\n    }\n}\n\n/* Voice call indicator in messages */\n.chatMessage .voiceCallIndicator {\n    margin-bottom: 8px;\n    padding: 6px 12px;\n    font-size: 12px;\n    border-radius: 16px;\n}\n\n.chatMessage .voiceCallIndicator svg {\n    width: 14px;\n    height: 14px;\n}\n\n/* Rating confirmation */\n.ratingConfirmation {\n    position: fixed;\n    top: 20px;\n    right: 20px;\n    background: linear-gradient(135deg, #10b981 0%, #059669 100%);\n    color: white;\n    padding: 16px 20px;\n    border-radius: 12px;\n    box-shadow: 0 8px 32px rgba(16, 185, 129, 0.3);\n    z-index: 1001;\n    animation: confirmationSlideIn 0.3s ease-out;\n    max-width: 300px;\n    word-wrap: break-word;\n    font-weight: 500;\n    backdrop-filter: blur(20px);\n}\n\n@keyframes confirmationSlideIn {\n    from {\n        transform: translateX(100%);\n        opacity: 0;\n    }\n    to {\n        transform: translateX(0);\n        opacity: 1;\n    }\n}\n\n/* Mobile responsiveness */\n@media (max-width: 768px) {\n    .actions {\n        margin: 12px 16px 0;\n        gap: 6px;\n    }\n\n    .chatMainFlow .chatMessages {\n        padding: 16px 12px;\n    }\n\n    .chatMainFlow .chatMessage {\n        margin-bottom: 16px;\n    }\n\n    .chatMainFlow .chatMessage .messageText {\n        max-width: 85%;\n        padding: 12px 16px;\n        font-size: 14px;\n        border-radius: 18px;\n    }\n\n    .chatMainFlow .chatMessage .avatar {\n        width: 36px;\n        height: 36px;\n        margin: 0 10px 4px;\n    }\n\n    .chatMainFlow .chatMessage .avatar img {\n        width: 36px;\n        aspect-ratio: 1 / 1;\n    }\n\n    .chatMainFlow .chatInput {\n        padding: 16px 12px;\n        gap: 10px;\n    }\n\n    .chatMainFlow .chatInput textarea {\n        font-size: 16px;\n        padding: 14px 18px;\n        border-radius: 22px;\n    }\n\n    .chatMainFlow .chatInput button {\n        width: 44px;\n        height: 44px;\n    }\n\n    .scrollToBottom {\n        width: 44px;\n        height: 44px;\n        font-size: 18px;\n        top: calc(100% - 160px);\n    }\n\n    .chatButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .chatButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .chatButtonText {\n        display: none !important;\n    }\n\n    .useTemplateButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .useTemplateButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .useTemplateButton .chatButtonText {\n        display: none !important;\n    }\n\n    .ratingModalContent {\n        margin: 16px;\n        padding: 24px 20px;\n        border-radius: 16px;\n        max-height: 80vh;\n        overflow-y: auto;\n    }\n\n    .stars {\n        gap: 6px;\n        margin-bottom: 20px;\n    }\n\n    .stars span {\n        font-size: 32px;\n        padding: 8px;\n    }\n\n    .ratingActions {\n        flex-direction: column-reverse;\n        gap: 8px;\n    }\n\n    .ratingActions button {\n        width: 100%;\n        padding: 14px;\n        font-size: 16px;\n        border-radius: 10px;\n    }\n}\n\n@media (max-width: 480px) {\n    .actions {\n        margin: 8px 12px 0;\n        gap: 4px;\n    }\n\n    .chatMainFlow .chatMessages {\n        padding: 12px 8px;\n    }\n\n    .chatMainFlow .chatMessage .messageText {\n        max-width: 90%;\n        padding: 10px 14px;\n        font-size: 14px;\n        border-radius: 16px;\n    }\n\n    .chatMainFlow .chatMessage .avatar {\n        width: 32px;\n        height: 32px;\n        margin: 0 8px 4px;\n    }\n\n    .chatMainFlow .chatMessage .avatar img {\n        width: 32px;\n        aspect-ratio: 1 / 1;\n    }\n\n    .chatMainFlow .chatInput {\n        padding: 12px 8px;\n        gap: 8px;\n    }\n\n    .chatMainFlow .chatInput textarea {\n        padding: 12px 16px;\n        border-radius: 20px;\n        font-size: 16px;\n    }\n\n    .chatMainFlow .chatInput button {\n        width: 40px;\n        height: 40px;\n    }\n\n    .chatButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .chatButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .chatButtonText {\n        display: none !important;\n    }\n\n    .useTemplateButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .useTemplateButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .useTemplateButton .chatButtonText {\n        display: none !important;\n    }\n\n    .scrollToBottom {\n        width: 40px;\n        height: 40px;\n        font-size: 16px;\n        top: calc(100% - 140px);\n    }\n\n    .ratingModal {\n        padding: 0;\n        align-items: flex-end;\n    }\n\n    .ratingModalContent {\n        margin: 0;\n        width: 100%;\n        border-radius: 20px 20px 0 0;\n        max-height: 70vh;\n        padding: 24px 16px 20px;\n    }\n}\n\n/* Reduced motion support */\n@media (prefers-reduced-motion: reduce) {\n    .chatMainFlow .chatMessage,\n    .scrollToBottom,\n    .ratingModal,\n    .ratingModalContent,\n    .ratingConfirmation {\n        animation: none;\n    }\n\n    .chatMainFlow .chatMessage .messageText,\n    .chatMainFlow .chatInput textarea,\n    .chatMainFlow .chatInput button,\n    .chatMainFlow .chatMessage .avatar img,\n    .chatButton {\n        transition: none;\n    }\n}\n\n/* High contrast mode support */\n@media (prefers-contrast: high) {\n    .chatMainFlow .chatMessage .messageText {\n        border: 2px solid currentColor;\n    }\n\n    .chatMainFlow .chatInput textarea {\n        border-width: 3px;\n    }\n\n    .chatMainFlow .chatInput button {\n        border: 2px solid currentColor;\n    }\n}\n\n/**\n * TODO: [🌉] DRY Markdown primitives styling\n */\n"]} */";
|
|
8663
9143
|
var chatStyles = {"copiedToClipboardMessage":"Chat-module_copiedToClipboardMessage__apCPY","Chat":"Chat-module_Chat__j2eE5","chatMainFlow":"Chat-module_chatMainFlow__--8FE","chatBar":"Chat-module_chatBar__fLECN","TasksInProgress":"Chat-module_TasksInProgress__fQfei","actions":"Chat-module_actions__gTZ5T","portal":"Chat-module_portal__uTOT8","left":"Chat-module_left__7l5Mn","right":"Chat-module_right__ABZrW","chatButton":"Chat-module_chatButton__d9VgA","chatButtonText":"Chat-module_chatButtonText__RkGB-","useTemplateButton":"Chat-module_useTemplateButton__xcJNR","chatChildren":"Chat-module_chatChildren__flOPK","chatMessages":"Chat-module_chatMessages__J2u2N","chatMessage":"Chat-module_chatMessage__nmLaZ","messageSlideIn":"Chat-module_messageSlideIn__soTy2","hasActionsAndFirstMessageIsLong":"Chat-module_hasActionsAndFirstMessageIsLong__5jgoZ","isNotCompleteMessage":"Chat-module_isNotCompleteMessage__Hj2K7","NonCompleteMessageFiller":"Chat-module_NonCompleteMessageFiller__G5-Ve","messageText":"Chat-module_messageText__XgNyQ","loadingPulse":"Chat-module_loadingPulse__VomRm","typingIndicator":"Chat-module_typingIndicator__S-CT-","avatar":"Chat-module_avatar__gL6bm","typingBubble":"Chat-module_typingBubble__0Lb7B","typingDots":"Chat-module_typingDots__srOBB","typingDot":"Chat-module_typingDot__dnhKT","typingBounce":"Chat-module_typingBounce__1yp2v","isMe":"Chat-module_isMe__nBtaV","ratingStar":"Chat-module_ratingStar__rRfqC","active":"Chat-module_active__lbYL-","copyButtonContainer":"Chat-module_copyButtonContainer__Rij0U","copyButton":"Chat-module_copyButton__DcxT5","copiedTooltip":"Chat-module_copiedTooltip__LH81j","copiedTooltipFadeIn":"Chat-module_copiedTooltipFadeIn__QekO1","copiedTooltipLeft":"Chat-module_copiedTooltipLeft__j-S-5","copiedTooltipRight":"Chat-module_copiedTooltipRight__R-2cE","chat-code-block":"Chat-module_chat-code-block__k8IyS","messageButtons":"Chat-module_messageButtons__WaOob","messageButton":"Chat-module_messageButton__mRnn-","rating":"Chat-module_rating__soc3M","chatInput":"Chat-module_chatInput__1Ecan","dragOver":"Chat-module_dragOver__bkS-g","filePreviewContainer":"Chat-module_filePreviewContainer__R70hm","filePreview":"Chat-module_filePreview__kq2aX","fileIcon":"Chat-module_fileIcon__zoSKW","fileInfo":"Chat-module_fileInfo__wBLi0","fileName":"Chat-module_fileName__bBujo","fileSize":"Chat-module_fileSize__ivliq","removeFileButton":"Chat-module_removeFileButton__0gakR","inputContainer":"Chat-module_inputContainer__bPt99","attachmentButton":"Chat-module_attachmentButton__qLO47","voiceButton":"Chat-module_voiceButton__d2zlP","voiceButtonActive":"Chat-module_voiceButtonActive__Uoi3W","voiceRecordingPulse":"Chat-module_voiceRecordingPulse__y2wJ5","uploadProgress":"Chat-module_uploadProgress__jBTKe","uploadProgressBar":"Chat-module_uploadProgressBar__Gutnt","uploadProgressFill":"Chat-module_uploadProgressFill__EgubT","dragOverlay":"Chat-module_dragOverlay__SEGoS","dragOverlayContent":"Chat-module_dragOverlayContent__gb9kF","scrollToBottomContainer":"Chat-module_scrollToBottomContainer__5rXpK","scrollToBottom":"Chat-module_scrollToBottom__nzxdZ","scrollButtonSlideIn":"Chat-module_scrollButtonSlideIn__XnImg","ratingModal":"Chat-module_ratingModal__XVKYm","modalFadeIn":"Chat-module_modalFadeIn__RPc3w","ratingModalContent":"Chat-module_ratingModalContent__CCdq7","modalSlideIn":"Chat-module_modalSlideIn__XXtgN","stars":"Chat-module_stars__PCzNO","ratingModalStar":"Chat-module_ratingModalStar__XkbHr","ratingInput":"Chat-module_ratingInput__z8Pv-","ratingActions":"Chat-module_ratingActions__nXcss","saveButtonContainer":"Chat-module_saveButtonContainer__lSNUJ","saveMenu":"Chat-module_saveMenu__-ph8y","saveMenuItem":"Chat-module_saveMenuItem__ISApL","pauseButton":"Chat-module_pauseButton__eeu7K","pausing":"Chat-module_pausing__pTx8b","paused":"Chat-module_paused__j-pya","voiceCallIndicatorBar":"Chat-module_voiceCallIndicatorBar__N2sWN","voiceCallIndicator":"Chat-module_voiceCallIndicator__tsaaG","voiceCallIconPulse":"Chat-module_voiceCallIconPulse__zZbJn","voiceCallPulse":"Chat-module_voiceCallPulse__XcGU4","ratingConfirmation":"Chat-module_ratingConfirmation__n16vb","confirmationSlideIn":"Chat-module_confirmationSlideIn__5U-wz"};
|
|
8664
9144
|
styleInject(css_248z$2);
|
|
8665
9145
|
|
|
@@ -8800,7 +9280,7 @@ const ChatMessageItem = memo(({ message, participant, participants, isLastMessag
|
|
|
8800
9280
|
// Note: Do not hide tooltip on mouse leave, it will be hidden by clicking outside
|
|
8801
9281
|
};
|
|
8802
9282
|
const isMe = participant === null || participant === void 0 ? void 0 : participant.isMe;
|
|
8803
|
-
const color = Color.
|
|
9283
|
+
const color = Color.fromSafe((participant && participant.color) || (isMe ? USER_CHAT_COLOR : PROMPTBOOK_CHAT_COLOR));
|
|
8804
9284
|
const colorOfText = color.then(textColor);
|
|
8805
9285
|
const { contentWithoutButtons, buttons } = parseMessageButtons(message.content);
|
|
8806
9286
|
const shouldShowButtons = isLastMessage && buttons.length > 0 && onMessage;
|
|
@@ -8956,8 +9436,8 @@ function Chat(props) {
|
|
|
8956
9436
|
// isExperimental = false,
|
|
8957
9437
|
// TODO: [😅]> isSaveButtonEnabled = false,
|
|
8958
9438
|
// exportHeaderMarkdown,
|
|
8959
|
-
participants = [], extraActions, actionsContainer, saveFormats, isSaveButtonEnabled = true, isCopyButtonEnabled = true, } = props;
|
|
8960
|
-
const
|
|
9439
|
+
participants = [], extraActions, actionsContainer, saveFormats, isSaveButtonEnabled = true, isCopyButtonEnabled = true, buttonColor: buttonColorRaw, onUseTemplate, } = props;
|
|
9440
|
+
const buttonColor = useMemo(() => Color.from(buttonColorRaw || '#0066cc'), [buttonColorRaw]);
|
|
8961
9441
|
// Use the auto-scroll hook
|
|
8962
9442
|
const { isAutoScrolling, chatMessagesRef, handleScroll, handleMessagesChange, scrollToBottom, isMobile: isMobileFromHook, } = useChatAutoScroll();
|
|
8963
9443
|
const textareaRef = useRef(null);
|
|
@@ -9081,7 +9561,7 @@ function Chat(props) {
|
|
|
9081
9561
|
const fileContents = uploadedFiles.map((f) => f.content).join(' ');
|
|
9082
9562
|
messageContent = messageContent ? `${messageContent} ${fileContents}` : fileContents;
|
|
9083
9563
|
}
|
|
9084
|
-
if (spaceTrim(messageContent) === '') {
|
|
9564
|
+
if (spaceTrim$2(messageContent) === '') {
|
|
9085
9565
|
throw new Error(`You need to write some text or upload a file`);
|
|
9086
9566
|
}
|
|
9087
9567
|
await onMessage(messageContent);
|
|
@@ -9298,10 +9778,19 @@ function Chat(props) {
|
|
|
9298
9778
|
return;
|
|
9299
9779
|
}
|
|
9300
9780
|
onChange(((_a = textareaRef.current) === null || _a === void 0 ? void 0 : _a.value) || '');
|
|
9301
|
-
} }), onFileUpload && (jsxs(Fragment, { children: [jsx("input", { ref: fileInputRef, type: "file", multiple: true, style: { display: 'none' }, onChange: handleFileInputChange }), jsx("button", { type: "button",
|
|
9781
|
+
} }), onFileUpload && (jsxs(Fragment, { children: [jsx("input", { ref: fileInputRef, type: "file", multiple: true, style: { display: 'none' }, onChange: handleFileInputChange }), jsx("button", { type: "button", style: {
|
|
9782
|
+
backgroundColor: buttonColor.toHex(),
|
|
9783
|
+
color: buttonColor.then(textColor).toHex(),
|
|
9784
|
+
}, className: chatStyles.attachmentButton, onClick: () => { var _a; return (_a = fileInputRef.current) === null || _a === void 0 ? void 0 : _a.click(); }, disabled: isUploading, title: "Attach file", children: jsx(AttachmentIcon, { size: 20 }) })] })), onVoiceInput && (jsx("button", { "data-button-type": "voice", style: {
|
|
9785
|
+
backgroundColor: buttonColor.toHex(),
|
|
9786
|
+
color: buttonColor.then(textColor).toHex(),
|
|
9787
|
+
}, className: classNames(chatStyles.voiceButton, isVoiceCalling && chatStyles.voiceButtonActive), onClick: (event) => {
|
|
9302
9788
|
event.preventDefault();
|
|
9303
9789
|
onVoiceInput();
|
|
9304
|
-
}, title: isVoiceCalling ? 'Stop voice call' : 'Start voice call', children: jsx(MicIcon, { size: 25 }) })), jsx("button", { "data-button-type": "call-to-action",
|
|
9790
|
+
}, title: isVoiceCalling ? 'Stop voice call' : 'Start voice call', children: jsx(MicIcon, { size: 25 }) })), jsx("button", { "data-button-type": "call-to-action", style: {
|
|
9791
|
+
backgroundColor: buttonColor.toHex(),
|
|
9792
|
+
color: buttonColor.then(textColor).toHex(),
|
|
9793
|
+
}, ref: buttonSendRef, onClick: (event) => {
|
|
9305
9794
|
if (!onMessage) {
|
|
9306
9795
|
return;
|
|
9307
9796
|
}
|
|
@@ -9437,7 +9926,7 @@ ChatPersistence.STORAGE_PREFIX = 'promptbook_chat_';
|
|
|
9437
9926
|
* @public exported from `@promptbook/components`
|
|
9438
9927
|
*/
|
|
9439
9928
|
function LlmChat(props) {
|
|
9440
|
-
const { llmTools, persistenceKey, onChange, onReset, initialMessages, sendMessage, userParticipantName = 'USER', llmParticipantName = 'ASSISTANT', ...restProps } = props;
|
|
9929
|
+
const { llmTools, persistenceKey, onChange, onReset, initialMessages, sendMessage, userParticipantName = 'USER', llmParticipantName = 'ASSISTANT', autoExecuteMessage, buttonColor, ...restProps } = props;
|
|
9441
9930
|
// Internal state management
|
|
9442
9931
|
// DRY: Single factory for seeding initial messages (used on mount and after reset)
|
|
9443
9932
|
const buildInitialMessages = useCallback(() => (initialMessages ? [...initialMessages] : []), [initialMessages]);
|
|
@@ -9771,7 +10260,15 @@ function LlmChat(props) {
|
|
|
9771
10260
|
sendMessage._attach(handleMessage);
|
|
9772
10261
|
}
|
|
9773
10262
|
}, [sendMessage, handleMessage]);
|
|
9774
|
-
|
|
10263
|
+
// Handle autoExecuteMessage
|
|
10264
|
+
const hasAutoExecutedRef = useRef(false);
|
|
10265
|
+
useEffect(() => {
|
|
10266
|
+
if (autoExecuteMessage && !hasAutoExecutedRef.current) {
|
|
10267
|
+
hasAutoExecutedRef.current = true;
|
|
10268
|
+
handleMessage(autoExecuteMessage);
|
|
10269
|
+
}
|
|
10270
|
+
}, [autoExecuteMessage, handleMessage]);
|
|
10271
|
+
return (jsx(Fragment, { children: jsx(Chat, { ...restProps, messages, onReset, tasksProgress, participants, buttonColor, onMessage: handleMessage, onReset: handleReset, onVoiceInput: llmTools.callVoiceChatModel ? handleVoiceInput : undefined, isVoiceCalling: isVoiceCalling }) }));
|
|
9775
10272
|
}
|
|
9776
10273
|
|
|
9777
10274
|
/**
|
|
@@ -9788,34 +10285,35 @@ function LlmChat(props) {
|
|
|
9788
10285
|
*/
|
|
9789
10286
|
function AgentChat(props) {
|
|
9790
10287
|
const { agent, title, persistenceKey, onChange, sendMessage, ...restProps } = props;
|
|
9791
|
-
|
|
9792
|
-
|
|
9793
|
-
|
|
9794
|
-
|
|
9795
|
-
|
|
9796
|
-
|
|
10288
|
+
const brandColor = Color.fromSafe(agent.meta.color || PROMPTBOOK_COLOR).then(saturate(-0.5));
|
|
10289
|
+
return (jsx(Fragment, { children: jsx(LlmChat, { title: title || `Chat with ${agent.meta.fullname || agent.agentName || 'Agent'}`, persistenceKey: persistenceKey || `agent-chat-${agent.agentName}`, userParticipantName: "USER", llmParticipantName: "AGENT" // <- TODO: [🧠] Maybe dynamic agent id
|
|
10290
|
+
, initialMessages: [
|
|
10291
|
+
{
|
|
10292
|
+
from: 'AGENT',
|
|
10293
|
+
content: agent.initialMessage ||
|
|
10294
|
+
spaceTrim$2(`
|
|
9797
10295
|
|
|
9798
10296
|
Hello! I am ${agent.meta.fullname || agent.agentName || 'an AI Agent'}.
|
|
9799
10297
|
|
|
9800
10298
|
[Hello](?message=Hello, can you tell me about yourself?)
|
|
9801
10299
|
`),
|
|
9802
|
-
|
|
9803
|
-
|
|
9804
|
-
|
|
9805
|
-
|
|
9806
|
-
|
|
9807
|
-
|
|
9808
|
-
|
|
9809
|
-
|
|
9810
|
-
|
|
9811
|
-
|
|
9812
|
-
|
|
9813
|
-
|
|
9814
|
-
|
|
9815
|
-
|
|
9816
|
-
|
|
9817
|
-
|
|
9818
|
-
|
|
10300
|
+
},
|
|
10301
|
+
], participants: [
|
|
10302
|
+
{
|
|
10303
|
+
name: 'AGENT',
|
|
10304
|
+
fullname: agent.meta.fullname || agent.agentName || 'Agent',
|
|
10305
|
+
avatarSrc: agent.meta.image,
|
|
10306
|
+
color: brandColor,
|
|
10307
|
+
isMe: false,
|
|
10308
|
+
agentSource: asUpdatableSubject(agent.agentSource).getValue() /* <- TODO: [🐱🚀] asValue */,
|
|
10309
|
+
},
|
|
10310
|
+
{
|
|
10311
|
+
name: 'USER',
|
|
10312
|
+
fullname: 'User',
|
|
10313
|
+
color: '#115EB6',
|
|
10314
|
+
isMe: true,
|
|
10315
|
+
},
|
|
10316
|
+
], buttonColor: brandColor, llmTools: agent, onChange, sendMessage, ...restProps }) }));
|
|
9819
10317
|
}
|
|
9820
10318
|
|
|
9821
10319
|
/**
|
|
@@ -10261,7 +10759,7 @@ function book(strings, ...values) {
|
|
|
10261
10759
|
const bookString = prompt(strings, ...values);
|
|
10262
10760
|
if (!isValidPipelineString(bookString)) {
|
|
10263
10761
|
// TODO: Make the CustomError for this
|
|
10264
|
-
throw new Error(spaceTrim(`
|
|
10762
|
+
throw new Error(spaceTrim$2(`
|
|
10265
10763
|
The string is not a valid pipeline string
|
|
10266
10764
|
|
|
10267
10765
|
book\`
|
|
@@ -10271,7 +10769,7 @@ function book(strings, ...values) {
|
|
|
10271
10769
|
}
|
|
10272
10770
|
if (!isValidBook(bookString)) {
|
|
10273
10771
|
// TODO: Make the CustomError for this
|
|
10274
|
-
throw new Error(spaceTrim(`
|
|
10772
|
+
throw new Error(spaceTrim$2(`
|
|
10275
10773
|
The string is not a valid book
|
|
10276
10774
|
|
|
10277
10775
|
book\`
|
|
@@ -10334,14 +10832,14 @@ class MultipleLlmExecutionTools {
|
|
|
10334
10832
|
if (description === undefined) {
|
|
10335
10833
|
return headLine;
|
|
10336
10834
|
}
|
|
10337
|
-
return spaceTrim((block) => `
|
|
10835
|
+
return spaceTrim$2((block) => `
|
|
10338
10836
|
${headLine}
|
|
10339
10837
|
|
|
10340
10838
|
${ /* <- Note: Indenting the description: */block(description)}
|
|
10341
10839
|
`);
|
|
10342
10840
|
})
|
|
10343
10841
|
.join('\n\n');
|
|
10344
|
-
return spaceTrim((block) => `
|
|
10842
|
+
return spaceTrim$2((block) => `
|
|
10345
10843
|
Multiple LLM Providers:
|
|
10346
10844
|
|
|
10347
10845
|
${block(innerModelsTitlesAndDescriptions)}
|
|
@@ -10432,7 +10930,7 @@ class MultipleLlmExecutionTools {
|
|
|
10432
10930
|
// 1) OpenAI throw PipelineExecutionError: Parameter `{knowledge}` is not defined
|
|
10433
10931
|
// 2) AnthropicClaude throw PipelineExecutionError: Parameter `{knowledge}` is not defined
|
|
10434
10932
|
// 3) ...
|
|
10435
|
-
spaceTrim((block) => `
|
|
10933
|
+
spaceTrim$2((block) => `
|
|
10436
10934
|
All execution tools of ${this.title} failed:
|
|
10437
10935
|
|
|
10438
10936
|
${block(errors
|
|
@@ -10445,7 +10943,7 @@ class MultipleLlmExecutionTools {
|
|
|
10445
10943
|
throw new PipelineExecutionError(`You have not provided any \`LlmExecutionTools\` into ${this.title}`);
|
|
10446
10944
|
}
|
|
10447
10945
|
else {
|
|
10448
|
-
throw new PipelineExecutionError(spaceTrim((block) => `
|
|
10946
|
+
throw new PipelineExecutionError(spaceTrim$2((block) => `
|
|
10449
10947
|
You have not provided any \`LlmExecutionTools\` that support model variant "${prompt.modelRequirements.modelVariant}" into ${this.title}
|
|
10450
10948
|
|
|
10451
10949
|
Available \`LlmExecutionTools\`:
|
|
@@ -10478,7 +10976,7 @@ class MultipleLlmExecutionTools {
|
|
|
10478
10976
|
*/
|
|
10479
10977
|
function joinLlmExecutionTools(title, ...llmExecutionTools) {
|
|
10480
10978
|
if (llmExecutionTools.length === 0) {
|
|
10481
|
-
const warningMessage = spaceTrim(`
|
|
10979
|
+
const warningMessage = spaceTrim$2(`
|
|
10482
10980
|
You have not provided any \`LlmExecutionTools\`
|
|
10483
10981
|
This means that you won't be able to execute any prompts that require large language models like GPT-4 or Anthropic's Claude.
|
|
10484
10982
|
|
|
@@ -10657,7 +11155,7 @@ function pipelineJsonToString(pipelineJson) {
|
|
|
10657
11155
|
pipelineString += '\n\n';
|
|
10658
11156
|
pipelineString += '```' + contentLanguage;
|
|
10659
11157
|
pipelineString += '\n';
|
|
10660
|
-
pipelineString += spaceTrim(content);
|
|
11158
|
+
pipelineString += spaceTrim$2(content);
|
|
10661
11159
|
// <- TODO: [main] !!3 Escape
|
|
10662
11160
|
// <- TODO: [🧠] Some clear strategy how to spaceTrim the blocks
|
|
10663
11161
|
pipelineString += '\n';
|
|
@@ -11718,14 +12216,14 @@ function $registeredScrapersMessage(availableScrapers) {
|
|
|
11718
12216
|
return { ...metadata, isMetadataAviailable, isInstalled, isAvailableInTools };
|
|
11719
12217
|
});
|
|
11720
12218
|
if (metadata.length === 0) {
|
|
11721
|
-
return spaceTrim(`
|
|
12219
|
+
return spaceTrim$2(`
|
|
11722
12220
|
**No scrapers are available**
|
|
11723
12221
|
|
|
11724
12222
|
This is a unexpected behavior, you are probably using some broken version of Promptbook
|
|
11725
12223
|
At least there should be available the metadata of the scrapers
|
|
11726
12224
|
`);
|
|
11727
12225
|
}
|
|
11728
|
-
return spaceTrim((block) => `
|
|
12226
|
+
return spaceTrim$2((block) => `
|
|
11729
12227
|
Available scrapers are:
|
|
11730
12228
|
${block(metadata
|
|
11731
12229
|
.map(({ packageName, className, isMetadataAviailable, isInstalled, mimeTypes, isAvailableInBrowser, isAvailableInTools, }, i) => {
|
|
@@ -11871,7 +12369,7 @@ const promptbookFetch = async (urlOrRequest, init) => {
|
|
|
11871
12369
|
else if (urlOrRequest instanceof Request) {
|
|
11872
12370
|
url = urlOrRequest.url;
|
|
11873
12371
|
}
|
|
11874
|
-
throw new PromptbookFetchError(spaceTrim((block) => `
|
|
12372
|
+
throw new PromptbookFetchError(spaceTrim$2((block) => `
|
|
11875
12373
|
Can not fetch "${url}"
|
|
11876
12374
|
|
|
11877
12375
|
Fetch error:
|
|
@@ -12032,7 +12530,7 @@ async function makeKnowledgeSourceHandler(knowledgeSource, tools, options) {
|
|
|
12032
12530
|
const fileExtension = getFileExtension(filename);
|
|
12033
12531
|
const mimeType = extensionToMimeType(fileExtension || '');
|
|
12034
12532
|
if (!(await isFileExisting(filename, tools.fs))) {
|
|
12035
|
-
throw new NotFoundError(spaceTrim((block) => `
|
|
12533
|
+
throw new NotFoundError(spaceTrim$2((block) => `
|
|
12036
12534
|
Can not make source handler for file which does not exist:
|
|
12037
12535
|
|
|
12038
12536
|
File:
|
|
@@ -12125,7 +12623,7 @@ async function prepareKnowledgePieces(knowledgeSources, tools, options) {
|
|
|
12125
12623
|
// <- TODO: [🪓] Here should be no need for spreading new array, just `partialPieces = partialPiecesUnchecked`
|
|
12126
12624
|
break;
|
|
12127
12625
|
}
|
|
12128
|
-
console.warn(spaceTrim((block) => `
|
|
12626
|
+
console.warn(spaceTrim$2((block) => `
|
|
12129
12627
|
Cannot scrape knowledge from source despite the scraper \`${scraper.metadata.className}\` supports the mime type "${sourceHandler.mimeType}".
|
|
12130
12628
|
|
|
12131
12629
|
The source:
|
|
@@ -12141,7 +12639,7 @@ async function prepareKnowledgePieces(knowledgeSources, tools, options) {
|
|
|
12141
12639
|
// <- TODO: [🏮] Some standard way how to transform errors into warnings and how to handle non-critical fails during the tasks
|
|
12142
12640
|
}
|
|
12143
12641
|
if (partialPieces === null) {
|
|
12144
|
-
throw new KnowledgeScrapeError(spaceTrim((block) => `
|
|
12642
|
+
throw new KnowledgeScrapeError(spaceTrim$2((block) => `
|
|
12145
12643
|
Cannot scrape knowledge
|
|
12146
12644
|
|
|
12147
12645
|
The source:
|
|
@@ -12578,7 +13076,7 @@ const CsvFormatParser = {
|
|
|
12578
13076
|
const { value, outputParameterName, settings, mapCallback, onProgress } = options;
|
|
12579
13077
|
const csv = csvParse(value, settings);
|
|
12580
13078
|
if (csv.errors.length !== 0) {
|
|
12581
|
-
throw new CsvFormatError(spaceTrim((block) => `
|
|
13079
|
+
throw new CsvFormatError(spaceTrim$2((block) => `
|
|
12582
13080
|
CSV parsing error
|
|
12583
13081
|
|
|
12584
13082
|
Error(s) from CSV parsing:
|
|
@@ -12623,7 +13121,7 @@ const CsvFormatParser = {
|
|
|
12623
13121
|
const { value, settings, mapCallback, onProgress } = options;
|
|
12624
13122
|
const csv = csvParse(value, settings);
|
|
12625
13123
|
if (csv.errors.length !== 0) {
|
|
12626
|
-
throw new CsvFormatError(spaceTrim((block) => `
|
|
13124
|
+
throw new CsvFormatError(spaceTrim$2((block) => `
|
|
12627
13125
|
CSV parsing error
|
|
12628
13126
|
|
|
12629
13127
|
Error(s) from CSV parsing:
|
|
@@ -12809,7 +13307,7 @@ function mapAvailableToExpectedParameters(options) {
|
|
|
12809
13307
|
}
|
|
12810
13308
|
// Phase 2️⃣: Non-matching mapping
|
|
12811
13309
|
if (expectedParameterNames.size !== availableParametersNames.size) {
|
|
12812
|
-
throw new PipelineExecutionError(spaceTrim((block) => `
|
|
13310
|
+
throw new PipelineExecutionError(spaceTrim$2((block) => `
|
|
12813
13311
|
Can not map available parameters to expected parameters
|
|
12814
13312
|
|
|
12815
13313
|
Mapped parameters:
|
|
@@ -13381,7 +13879,7 @@ async function executeFormatSubvalues(options) {
|
|
|
13381
13879
|
return /* not await */ executeAttempts({ ...options, logLlmCall });
|
|
13382
13880
|
}
|
|
13383
13881
|
if (jokerParameterNames.length !== 0) {
|
|
13384
|
-
throw new UnexpectedError(spaceTrim((block) => `
|
|
13882
|
+
throw new UnexpectedError(spaceTrim$2((block) => `
|
|
13385
13883
|
JOKER parameters are not supported together with FOREACH command
|
|
13386
13884
|
|
|
13387
13885
|
[🧞♀️] This should be prevented in \`validatePipeline\`
|
|
@@ -13394,7 +13892,7 @@ async function executeFormatSubvalues(options) {
|
|
|
13394
13892
|
if (formatDefinition === undefined) {
|
|
13395
13893
|
throw new UnexpectedError(
|
|
13396
13894
|
// <- TODO: [🧠][🧐] Should be formats fixed per promptbook version or behave as plugins (=> change UnexpectedError)
|
|
13397
|
-
spaceTrim((block) => `
|
|
13895
|
+
spaceTrim$2((block) => `
|
|
13398
13896
|
Unsupported format "${task.foreach.formatName}"
|
|
13399
13897
|
|
|
13400
13898
|
Available formats:
|
|
@@ -13411,7 +13909,7 @@ async function executeFormatSubvalues(options) {
|
|
|
13411
13909
|
if (subvalueParser === undefined) {
|
|
13412
13910
|
throw new UnexpectedError(
|
|
13413
13911
|
// <- TODO: [🧠][🧐] Should be formats fixed per promptbook version or behave as plugins (=> change UnexpectedError)
|
|
13414
|
-
spaceTrim((block) => `
|
|
13912
|
+
spaceTrim$2((block) => `
|
|
13415
13913
|
Unsupported subformat name "${task.foreach.subformatName}" for format "${task.foreach.formatName}"
|
|
13416
13914
|
|
|
13417
13915
|
Available subformat names for format "${formatDefinition.formatName}":
|
|
@@ -13451,7 +13949,7 @@ async function executeFormatSubvalues(options) {
|
|
|
13451
13949
|
if (!(error instanceof PipelineExecutionError)) {
|
|
13452
13950
|
throw error;
|
|
13453
13951
|
}
|
|
13454
|
-
const highLevelError = new PipelineExecutionError(spaceTrim((block) => `
|
|
13952
|
+
const highLevelError = new PipelineExecutionError(spaceTrim$2((block) => `
|
|
13455
13953
|
${error.message}
|
|
13456
13954
|
|
|
13457
13955
|
This is error in FOREACH command when mapping ${formatDefinition.formatName} ${subvalueParser.subvalueName} data (${index + 1}/${length})
|
|
@@ -13475,7 +13973,7 @@ async function executeFormatSubvalues(options) {
|
|
|
13475
13973
|
...options,
|
|
13476
13974
|
priority: priority + index,
|
|
13477
13975
|
parameters: allSubparameters,
|
|
13478
|
-
pipelineIdentification: spaceTrim((block) => `
|
|
13976
|
+
pipelineIdentification: spaceTrim$2((block) => `
|
|
13479
13977
|
${block(pipelineIdentification)}
|
|
13480
13978
|
Subparameter index: ${index}
|
|
13481
13979
|
`),
|
|
@@ -13484,7 +13982,7 @@ async function executeFormatSubvalues(options) {
|
|
|
13484
13982
|
}
|
|
13485
13983
|
catch (error) {
|
|
13486
13984
|
if (length > BIG_DATASET_TRESHOLD) {
|
|
13487
|
-
console.error(spaceTrim((block) => `
|
|
13985
|
+
console.error(spaceTrim$2((block) => `
|
|
13488
13986
|
${error.message}
|
|
13489
13987
|
|
|
13490
13988
|
This is error in FOREACH command when processing ${formatDefinition.formatName} ${subvalueParser.subvalueName} data (${index + 1}/${length})
|
|
@@ -15842,7 +16340,7 @@ class OpenAiCompatibleExecutionTools {
|
|
|
15842
16340
|
// Note: Match exact or prefix for model families
|
|
15843
16341
|
const model = this.HARDCODED_MODELS.find(({ modelName }) => modelName === defaultModelName || modelName.startsWith(defaultModelName));
|
|
15844
16342
|
if (model === undefined) {
|
|
15845
|
-
throw new PipelineExecutionError(spaceTrim((block) => `
|
|
16343
|
+
throw new PipelineExecutionError(spaceTrim$2((block) => `
|
|
15846
16344
|
Cannot find model in ${this.title} models with name "${defaultModelName}" which should be used as default.
|
|
15847
16345
|
|
|
15848
16346
|
Available models:
|
|
@@ -16097,18 +16595,26 @@ class OpenAiAssistantExecutionTools extends OpenAiExecutionTools {
|
|
|
16097
16595
|
modelName: 'assistant',
|
|
16098
16596
|
// <- [🧠] What is the best value here
|
|
16099
16597
|
});
|
|
16598
|
+
// Build thread messages: include previous thread messages + current user message
|
|
16599
|
+
const threadMessages = [];
|
|
16600
|
+
// TODO: [🈹] Maybe this should not be here but in other place, look at commit 39d705e75e5bcf7a818c3af36bc13e1c8475c30c
|
|
16601
|
+
// Add previous messages from thread (if any)
|
|
16602
|
+
if ('thread' in prompt &&
|
|
16603
|
+
Array.isArray(prompt.thread)) {
|
|
16604
|
+
const previousMessages = prompt.thread.map((msg) => ({
|
|
16605
|
+
role: (msg.role === 'assistant' ? 'assistant' : 'user'),
|
|
16606
|
+
content: msg.content,
|
|
16607
|
+
}));
|
|
16608
|
+
threadMessages.push(...previousMessages);
|
|
16609
|
+
}
|
|
16610
|
+
// Always add the current user message
|
|
16611
|
+
threadMessages.push({ role: 'user', content: rawPromptContent });
|
|
16100
16612
|
const rawRequest = {
|
|
16101
16613
|
// TODO: [👨👨👧👧] ...modelSettings,
|
|
16102
16614
|
// TODO: [👨👨👧👧][🧠] What about system message for assistants, does it make sense - combination of OpenAI assistants with Promptbook Personas
|
|
16103
16615
|
assistant_id: this.assistantId,
|
|
16104
16616
|
thread: {
|
|
16105
|
-
messages:
|
|
16106
|
-
Array.isArray(prompt.thread)
|
|
16107
|
-
? prompt.thread.map((msg) => ({
|
|
16108
|
-
role: msg.role === 'assistant' ? 'assistant' : 'user',
|
|
16109
|
-
content: msg.content,
|
|
16110
|
-
}))
|
|
16111
|
-
: [{ role: 'user', content: rawPromptContent }],
|
|
16617
|
+
messages: threadMessages,
|
|
16112
16618
|
},
|
|
16113
16619
|
// <- TODO: Add user identification here> user: this.options.user,
|
|
16114
16620
|
};
|
|
@@ -16128,7 +16634,7 @@ class OpenAiAssistantExecutionTools extends OpenAiExecutionTools {
|
|
|
16128
16634
|
console.info('textDelta', textDelta.value);
|
|
16129
16635
|
}
|
|
16130
16636
|
const chunk = {
|
|
16131
|
-
content:
|
|
16637
|
+
content: snapshot.value,
|
|
16132
16638
|
modelName: 'assistant',
|
|
16133
16639
|
timing: {
|
|
16134
16640
|
start,
|
|
@@ -16802,7 +17308,7 @@ class Agent extends AgentLlmExecutionTools {
|
|
|
16802
17308
|
}
|
|
16803
17309
|
// TODO: !!! Extract learning to separate method
|
|
16804
17310
|
// Learning: Append the conversation sample to the agent source
|
|
16805
|
-
const learningExample = spaceTrim((block) => `
|
|
17311
|
+
const learningExample = spaceTrim$2((block) => `
|
|
16806
17312
|
|
|
16807
17313
|
---
|
|
16808
17314
|
|
|
@@ -16815,7 +17321,7 @@ class Agent extends AgentLlmExecutionTools {
|
|
|
16815
17321
|
`);
|
|
16816
17322
|
// Append to the current source
|
|
16817
17323
|
const currentSource = this.agentSource.value;
|
|
16818
|
-
const newSource = padBook(validateBook(spaceTrim(currentSource) + '\n\n' + learningExample));
|
|
17324
|
+
const newSource = padBook(validateBook(spaceTrim$2(currentSource) + '\n\n' + learningExample));
|
|
16819
17325
|
// Update the source (which will trigger the subscription and update the underlying tools)
|
|
16820
17326
|
this.agentSource.next(newSource);
|
|
16821
17327
|
return result;
|
|
@@ -17025,18 +17531,18 @@ class RemoteAgent extends Agent {
|
|
|
17025
17531
|
* TODO: !!! Agent on remote server
|
|
17026
17532
|
*/
|
|
17027
17533
|
|
|
17028
|
-
var css_248z = ".PromptbookAgent-module_promptbookAgent__ImvJD{bottom:20px;font-family:sans-serif;position:fixed;right:20px;z-index:10000}.PromptbookAgent-module_promptbookAgentButton__YhQfE{align-items:center;background-color:#007bff;border-radius:30px;box-shadow:0 4px 12px rgba(0,0,0,.15);color:#fff;cursor:pointer;display:flex;padding:10px 20px;position:relative;transition:transform .2s,box-shadow .2s}.PromptbookAgent-module_promptbookAgentButton__YhQfE:hover{box-shadow:0 6px 16px rgba(0,0,0,.2);transform:translateY(-2px)}.PromptbookAgent-module_promptbookAgentAvatar__WhrxA{background-color:#eee;border-radius:50%;height:32px;margin-right:10px;overflow:hidden;transform:translate(-10px) scale(1.3);width:32px}.PromptbookAgent-module_promptbookAgentAvatar__WhrxA img{height:100%;object-fit:cover;width:100%}.PromptbookAgent-module_promptbookAgentLabel__vPwVo{font-weight:700}.PromptbookAgent-module_promptbookAgentStatus__kZ-6L{border:2px solid #fff;border-radius:50%;bottom:12px;height:12px;left:40px;position:absolute;width:12px;z-index:10}.PromptbookAgent-module_promptbookAgentStatusConnected__M8yU5{background-color:#57b660}.PromptbookAgent-module_promptbookAgentStatusPending__czc3Y{background-color:#9e9e9e}.PromptbookAgent-module_promptbookAgentStatusError__Dvytw{background-color:#f44336}.PromptbookAgent-module_promptbookAgent__ImvJD.PromptbookAgent-module_open__TWzmA .PromptbookAgent-module_promptbookAgentButton__YhQfE{display:none}.PromptbookAgent-module_promptbookAgentWindow__mohTT{animation:PromptbookAgent-module_promptbook-agent-slide-up__PA--W .3s ease-out;background-color:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.2);display:flex;flex-direction:column;height:600px;max-height:80vh;overflow:hidden;width:380px}@keyframes PromptbookAgent-module_promptbook-agent-slide-up__PA--W{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.PromptbookAgent-module_promptbookAgentHeader__C7Ui3{align-items:center;background-color:#007bff;color:#fff;display:flex;justify-content:space-between;padding:15px}.PromptbookAgent-module_promptbookAgentHeader__C7Ui3 button{align-items:center!important;background:transparent!important;border:none!important;border-radius:50%!important;box-shadow:none!important;color:inherit!important;cursor:pointer;display:flex!important;height:32px!important;justify-content:center!important;margin:0 2px!important;min-width:32px!important;opacity:.8;padding:5px!important;transition:opacity .2s}.PromptbookAgent-module_promptbookAgentHeader__C7Ui3 button:hover{background-color:hsla(0,0%,100%,.2)!important;opacity:1}.PromptbookAgent-module_promptbookAgentHeader__C7Ui3 button span{display:none!important}.PromptbookAgent-module_promptbookAgentHeader__C7Ui3 button svg{height:20px;width:20px}.PromptbookAgent-module_promptbookAgentTitle__pU86r{font-size:1.1em;font-weight:700}.PromptbookAgent-module_promptbookAgentClose__RB4MO{font-size:1.2em}.PromptbookAgent-module_promptbookAgentContent__-82xH{display:flex;flex:1;flex-direction:column;overflow-y:auto;position:relative}.PromptbookAgent-module_promptbookAgentError__ejwA9,.PromptbookAgent-module_promptbookAgentLoading__hcXD5{align-items:center;color:#666;display:flex;flex:1;justify-content:center;padding:20px;text-align:center}.PromptbookAgent-module_promptbookAgentError__ejwA9{color:#d32f2f}@media (max-width:480px){.PromptbookAgent-module_promptbookAgent__ImvJD.PromptbookAgent-module_open__TWzmA{bottom:0;left:0;right:0}.PromptbookAgent-module_promptbookAgentWindow__mohTT{border-radius:0;height:100vh;max-height:100vh;width:100%}}\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlByb21wdGJvb2tBZ2VudC5tb2R1bGUuY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLCtDQUVJLFdBQVksQ0FHWixzQkFBdUIsQ0FKdkIsY0FBZSxDQUVmLFVBQVcsQ0FDWCxhQUVKLENBRUEscURBRUksa0JBQW1CLENBQ25CLHdCQUF5QixDQUV6QixrQkFBbUIsQ0FHbkIscUNBQTBDLENBSjFDLFVBQVksQ0FHWixjQUFlLENBTmYsWUFBYSxDQUtiLGlCQUFrQixDQUlsQixpQkFBa0IsQ0FEbEIsdUNBRUosQ0FFQSwyREFFSSxvQ0FBeUMsQ0FEekMsMEJBRUosQ0FFQSxxREFNSSxxQkFBc0IsQ0FIdEIsaUJBQWtCLENBRGxCLFdBQVksQ0FHWixpQkFBa0IsQ0FEbEIsZUFBZ0IsQ0FJaEIscUNBQXlDLENBUHpDLFVBUUosQ0FFQSx5REFFSSxXQUFZLENBQ1osZ0JBQWlCLENBRmpCLFVBR0osQ0FFQSxvREFDSSxlQUNKLENBRUEscURBS0kscUJBQXVCLENBRHZCLGlCQUFrQixDQUdsQixXQUFZLENBSlosV0FBWSxDQUdaLFNBQVUsQ0FMVixpQkFBa0IsQ0FDbEIsVUFBVyxDQU1YLFVBQ0osQ0FFQSw4REFDSSx3QkFDSixDQUVBLDREQUNJLHdCQUNKLENBRUEsMERBQ0ksd0JBQ0osQ0FRQSx1SUFDSSxZQUNKLENBRUEscURBVUksOEVBQWtELENBTmxELHFCQUF1QixDQUN2QixrQkFBbUIsQ0FDbkIsb0NBQXlDLENBQ3pDLFlBQWEsQ0FDYixxQkFBc0IsQ0FOdEIsWUFBYSxDQUNiLGVBQWdCLENBTWhCLGVBQWdCLENBUmhCLFdBVUosQ0FFQSxtRUFDSSxHQUNJLFNBQVUsQ0FDViwwQkFDSixDQUNBLEdBQ0ksU0FBVSxDQUNWLHVCQUNKLENBQ0osQ0FFQSxxREFNSSxrQkFBbUIsQ0FMbkIsd0JBQXlCLENBQ3pCLFVBQVksQ0FFWixZQUFhLENBQ2IsNkJBQThCLENBRjlCLFlBSUosQ0FNQSw0REFXSSw0QkFBOEIsQ0FWOUIsZ0NBQWtDLENBQ2xDLHFCQUF1QixDQWF2QiwyQkFBNkIsQ0FaN0IseUJBQTJCLENBQzNCLHVCQUF5QixDQUN6QixjQUFlLENBS2Ysc0JBQXdCLENBSXhCLHFCQUF1QixDQUZ2QixnQ0FBa0MsQ0FIbEMsc0JBQXdCLENBSXhCLHdCQUEwQixDQVAxQixVQUFZLENBRVoscUJBQXVCLENBRHZCLHNCQVNKLENBRUEsa0VBRUksNkNBQXFELENBRHJELFNBRUosQ0FHQSxpRUFDSSxzQkFDSixDQUdBLGdFQUVJLFdBQVksQ0FEWixVQUVKLENBRUEsb0RBRUksZUFBZ0IsQ0FEaEIsZUFFSixDQUVBLG9EQUVJLGVBQ0osQ0FFQSxzREFJSSxZQUFhLENBSGIsTUFBTyxDQUlQLHFCQUFzQixDQUh0QixlQUFnQixDQUNoQixpQkFHSixDQUVBLDBHQUtJLGtCQUFtQixDQUduQixVQUFXLENBTFgsWUFBYSxDQURiLE1BQU8sQ0FFUCxzQkFBdUIsQ0FFdkIsWUFBYSxDQUNiLGlCQUVKLENBRUEsb0RBQ0ksYUFDSixDQUVBLHlCQUNJLGtGQUNJLFFBQVMsQ0FFVCxNQUFPLENBRFAsT0FFSixDQUVBLHFEQUlJLGVBQWdCLENBRmhCLFlBQWEsQ0FDYixnQkFBaUIsQ0FGakIsVUFJSixDQUNKIiwiZmlsZSI6IlByb21wdGJvb2tBZ2VudC5tb2R1bGUuY3NzIiwic291cmNlc0NvbnRlbnQiOlsiLnByb21wdGJvb2tBZ2VudCB7XG4gICAgcG9zaXRpb246IGZpeGVkO1xuICAgIGJvdHRvbTogMjBweDtcbiAgICByaWdodDogMjBweDtcbiAgICB6LWluZGV4OiAxMDAwMDtcbiAgICBmb250LWZhbWlseTogc2Fucy1zZXJpZjtcbn1cblxuLnByb21wdGJvb2tBZ2VudEJ1dHRvbiB7XG4gICAgZGlzcGxheTogZmxleDtcbiAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgIGJhY2tncm91bmQtY29sb3I6ICMwMDdiZmY7XG4gICAgY29sb3I6IHdoaXRlO1xuICAgIGJvcmRlci1yYWRpdXM6IDMwcHg7XG4gICAgcGFkZGluZzogMTBweCAyMHB4O1xuICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICBib3gtc2hhZG93OiAwIDRweCAxMnB4IHJnYmEoMCwgMCwgMCwgMC4xNSk7XG4gICAgdHJhbnNpdGlvbjogdHJhbnNmb3JtIDAuMnMsIGJveC1zaGFkb3cgMC4ycztcbiAgICBwb3NpdGlvbjogcmVsYXRpdmU7XG59XG5cbi5wcm9tcHRib29rQWdlbnRCdXR0b246aG92ZXIge1xuICAgIHRyYW5zZm9ybTogdHJhbnNsYXRlWSgtMnB4KTtcbiAgICBib3gtc2hhZG93OiAwIDZweCAxNnB4IHJnYmEoMCwgMCwgMCwgMC4yKTtcbn1cblxuLnByb21wdGJvb2tBZ2VudEF2YXRhciB7XG4gICAgd2lkdGg6IDMycHg7XG4gICAgaGVpZ2h0OiAzMnB4O1xuICAgIGJvcmRlci1yYWRpdXM6IDUwJTtcbiAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgIG1hcmdpbi1yaWdodDogMTBweDtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAjZWVlO1xuXG4gICAgdHJhbnNmb3JtOiB0cmFuc2xhdGUoLTEwcHgsIDApIHNjYWxlKDEuMyk7XG59XG5cbi5wcm9tcHRib29rQWdlbnRBdmF0YXIgaW1nIHtcbiAgICB3aWR0aDogMTAwJTtcbiAgICBoZWlnaHQ6IDEwMCU7XG4gICAgb2JqZWN0LWZpdDogY292ZXI7XG59XG5cbi5wcm9tcHRib29rQWdlbnRMYWJlbCB7XG4gICAgZm9udC13ZWlnaHQ6IGJvbGQ7XG59XG5cbi5wcm9tcHRib29rQWdlbnRTdGF0dXMge1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICB3aWR0aDogMTJweDtcbiAgICBoZWlnaHQ6IDEycHg7XG4gICAgYm9yZGVyLXJhZGl1czogNTAlO1xuICAgIGJvcmRlcjogMnB4IHNvbGlkIHdoaXRlO1xuICAgIGxlZnQ6IDQwcHg7XG4gICAgYm90dG9tOiAxMnB4O1xuICAgIHotaW5kZXg6IDEwO1xufVxuXG4ucHJvbXB0Ym9va0FnZW50U3RhdHVzQ29ubmVjdGVkIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAjNTdiNjYwO1xufVxuXG4ucHJvbXB0Ym9va0FnZW50U3RhdHVzUGVuZGluZyB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogIzllOWU5ZTtcbn1cblxuLnByb21wdGJvb2tBZ2VudFN0YXR1c0Vycm9yIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAjZjQ0MzM2O1xufVxuXG4vKiBTdGF0ZSBjbGFzc2VzIChlbXB0eSB0byBhbGxvdyBtb2R1bGUgbWFwcGluZykgKi9cbi5vcGVuIHtcbn1cbi5jbG9zZWQge1xufVxuXG4ucHJvbXB0Ym9va0FnZW50Lm9wZW4gLnByb21wdGJvb2tBZ2VudEJ1dHRvbiB7XG4gICAgZGlzcGxheTogbm9uZTtcbn1cblxuLnByb21wdGJvb2tBZ2VudFdpbmRvdyB7XG4gICAgd2lkdGg6IDM4MHB4O1xuICAgIGhlaWdodDogNjAwcHg7XG4gICAgbWF4LWhlaWdodDogODB2aDtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiB3aGl0ZTtcbiAgICBib3JkZXItcmFkaXVzOiAxMnB4O1xuICAgIGJveC1zaGFkb3c6IDAgOHB4IDMycHggcmdiYSgwLCAwLCAwLCAwLjIpO1xuICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgIGFuaW1hdGlvbjogcHJvbXB0Ym9vay1hZ2VudC1zbGlkZS11cCAwLjNzIGVhc2Utb3V0O1xufVxuXG5Aa2V5ZnJhbWVzIHByb21wdGJvb2stYWdlbnQtc2xpZGUtdXAge1xuICAgIGZyb20ge1xuICAgICAgICBvcGFjaXR5OiAwO1xuICAgICAgICB0cmFuc2Zvcm06IHRyYW5zbGF0ZVkoMjBweCk7XG4gICAgfVxuICAgIHRvIHtcbiAgICAgICAgb3BhY2l0eTogMTtcbiAgICAgICAgdHJhbnNmb3JtOiB0cmFuc2xhdGVZKDApO1xuICAgIH1cbn1cblxuLnByb21wdGJvb2tBZ2VudEhlYWRlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogIzAwN2JmZjtcbiAgICBjb2xvcjogd2hpdGU7XG4gICAgcGFkZGluZzogMTVweDtcbiAgICBkaXNwbGF5OiBmbGV4O1xuICAgIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgICBhbGlnbi1pdGVtczogY2VudGVyO1xufVxuXG4vKiBcbiAgIE92ZXJyaWRlIGNoYXQgYWN0aW9uIGJ1dHRvbnMgdG8gbG9vayBsaWtlIHRoZSBjbG9zZSBidXR0b24gXG4gICB3aGVuIHJlbmRlcmVkIGluc2lkZSB0aGUgaGVhZGVyIHZpYSBwb3J0YWxcbiovXG4ucHJvbXB0Ym9va0FnZW50SGVhZGVyIGJ1dHRvbiB7XG4gICAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQgIWltcG9ydGFudDtcbiAgICBib3JkZXI6IG5vbmUgIWltcG9ydGFudDtcbiAgICBib3gtc2hhZG93OiBub25lICFpbXBvcnRhbnQ7XG4gICAgY29sb3I6IGluaGVyaXQgIWltcG9ydGFudDtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgb3BhY2l0eTogMC44O1xuICAgIHRyYW5zaXRpb246IG9wYWNpdHkgMC4ycztcbiAgICBwYWRkaW5nOiA1cHggIWltcG9ydGFudDtcbiAgICBtYXJnaW46IDAgMnB4ICFpbXBvcnRhbnQ7XG4gICAgZGlzcGxheTogZmxleCAhaW1wb3J0YW50O1xuICAgIGFsaWduLWl0ZW1zOiBjZW50ZXIgIWltcG9ydGFudDtcbiAgICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlciAhaW1wb3J0YW50O1xuICAgIG1pbi13aWR0aDogMzJweCAhaW1wb3J0YW50O1xuICAgIGhlaWdodDogMzJweCAhaW1wb3J0YW50O1xuICAgIGJvcmRlci1yYWRpdXM6IDUwJSAhaW1wb3J0YW50O1xufVxuXG4ucHJvbXB0Ym9va0FnZW50SGVhZGVyIGJ1dHRvbjpob3ZlciB7XG4gICAgb3BhY2l0eTogMTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiByZ2JhKDI1NSwgMjU1LCAyNTUsIDAuMikgIWltcG9ydGFudDtcbn1cblxuLyogSGlkZSB0ZXh0IGxhYmVscyBpbnNpZGUgYnV0dG9ucyBpbiBoZWFkZXIgKE5ldyBDaGF0LCBTYXZlKSAqL1xuLnByb21wdGJvb2tBZ2VudEhlYWRlciBidXR0b24gc3BhbiB7XG4gICAgZGlzcGxheTogbm9uZSAhaW1wb3J0YW50O1xufVxuXG4vKiBFbnN1cmUgU1ZHIGljb25zIGFyZSB2aXNpYmxlIGFuZCBzaXplZCBjb3JyZWN0bHkgKi9cbi5wcm9tcHRib29rQWdlbnRIZWFkZXIgYnV0dG9uIHN2ZyB7XG4gICAgd2lkdGg6IDIwcHg7XG4gICAgaGVpZ2h0OiAyMHB4O1xufVxuXG4ucHJvbXB0Ym9va0FnZW50VGl0bGUge1xuICAgIGZvbnQtd2VpZ2h0OiBib2xkO1xuICAgIGZvbnQtc2l6ZTogMS4xZW07XG59XG5cbi5wcm9tcHRib29rQWdlbnRDbG9zZSB7XG4gICAgLyogVXNlIHNhbWUgc3R5bGVzIGFzIGFib3ZlIG92ZXJyaWRlLCBidXQga2VlcCBzcGVjaWZpYyBpZiBuZWVkZWQgKi9cbiAgICBmb250LXNpemU6IDEuMmVtO1xufVxuXG4ucHJvbXB0Ym9va0FnZW50Q29udGVudCB7XG4gICAgZmxleDogMTtcbiAgICBvdmVyZmxvdy15OiBhdXRvO1xuICAgIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgICBkaXNwbGF5OiBmbGV4O1xuICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG59XG5cbi5wcm9tcHRib29rQWdlbnRMb2FkaW5nLFxuLnByb21wdGJvb2tBZ2VudEVycm9yIHtcbiAgICBmbGV4OiAxO1xuICAgIGRpc3BsYXk6IGZsZXg7XG4gICAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICBwYWRkaW5nOiAyMHB4O1xuICAgIHRleHQtYWxpZ246IGNlbnRlcjtcbiAgICBjb2xvcjogIzY2Njtcbn1cblxuLnByb21wdGJvb2tBZ2VudEVycm9yIHtcbiAgICBjb2xvcjogI2QzMmYyZjtcbn1cblxuQG1lZGlhIChtYXgtd2lkdGg6IDQ4MHB4KSB7XG4gICAgLnByb21wdGJvb2tBZ2VudC5vcGVuIHtcbiAgICAgICAgYm90dG9tOiAwO1xuICAgICAgICByaWdodDogMDtcbiAgICAgICAgbGVmdDogMDtcbiAgICB9XG5cbiAgICAucHJvbXB0Ym9va0FnZW50V2luZG93IHtcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIGhlaWdodDogMTAwdmg7XG4gICAgICAgIG1heC1oZWlnaHQ6IDEwMHZoO1xuICAgICAgICBib3JkZXItcmFkaXVzOiAwO1xuICAgIH1cbn1cbiJdfQ== */";
|
|
17029
|
-
var styles = {"
|
|
17534
|
+
var css_248z = ".PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegration__KTAQl{bottom:20px;font-family:sans-serif;position:fixed;right:20px;z-index:10000}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationButton__beMWa{align-items:center;background-color:#007bff;border-radius:30px;box-shadow:0 4px 12px rgba(0,0,0,.15);color:#fff;cursor:pointer;display:flex;padding:10px 20px;position:relative;transition:transform .2s,box-shadow .2s}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationButton__beMWa:hover{box-shadow:0 6px 16px rgba(0,0,0,.2);transform:translateY(-2px)}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationAvatar__OrK-R{background-color:#eee;border-radius:50%;height:32px;margin-right:10px;overflow:hidden;transform:translate(-10px) scale(1.3);width:32px}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationAvatar__OrK-R img{height:100%;object-fit:cover;width:100%}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationLabel__gvgCn{font-weight:700}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationStatus__QBwnt{border:2px solid #fff;border-radius:50%;bottom:12px;height:12px;left:40px;position:absolute;width:12px;z-index:10}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationStatusConnected__w15ZJ{background-color:#57b660}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationStatusPending__vtVxc{background-color:#9e9e9e}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationStatusError__nu02u{background-color:#f44336}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegration__KTAQl.PromptbookAgentSeamlessIntegration-module_open__rt5ey .PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationButton__beMWa{display:none}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationWindow__6sxeZ{animation:PromptbookAgentSeamlessIntegration-module_promptbook-agent-slide-up__0dGVe .3s ease-out;background-color:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.2);display:flex;flex-direction:column;height:600px;max-height:80vh;overflow:hidden;width:380px}@keyframes PromptbookAgentSeamlessIntegration-module_promptbook-agent-slide-up__0dGVe{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationHeader__9ae8B{align-items:center;background-color:#007bff;color:#fff;display:flex;justify-content:space-between;padding:15px}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationHeader__9ae8B button{align-items:center!important;background:transparent!important;border:none!important;border-radius:50%!important;box-shadow:none!important;color:inherit!important;cursor:pointer;display:flex!important;height:32px!important;justify-content:center!important;margin:0 2px!important;min-width:32px!important;opacity:.8;padding:5px!important;transition:opacity .2s}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationHeader__9ae8B button:hover{background-color:hsla(0,0%,100%,.2)!important;opacity:1}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationHeader__9ae8B button span{display:none!important}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationHeader__9ae8B button svg{height:20px;width:20px}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationTitle__D6p2j{font-size:1.1em;font-weight:700}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationClose__Ot41T{font-size:1.2em}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationContent__xqAns{display:flex;flex:1;flex-direction:column;overflow-y:auto;position:relative}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationError__RaBDa,.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationLoading__OAqgE{align-items:center;color:#666;display:flex;flex:1;justify-content:center;padding:20px;text-align:center}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationError__RaBDa{color:#d32f2f}@media (max-width:480px){.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegration__KTAQl.PromptbookAgentSeamlessIntegration-module_open__rt5ey{bottom:0;left:0;right:0}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationWindow__6sxeZ{border-radius:0;height:100vh;max-height:100vh;width:100%}}\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["PromptbookAgentSeamlessIntegration.module.css"],"names":[],"mappings":"AAAA,qFAEI,WAAY,CAGZ,sBAAuB,CAJvB,cAAe,CAEf,UAAW,CACX,aAEJ,CAEA,2FAEI,kBAAmB,CACnB,wBAAyB,CAEzB,kBAAmB,CAGnB,qCAA0C,CAJ1C,UAAY,CAGZ,cAAe,CANf,YAAa,CAKb,iBAAkB,CAIlB,iBAAkB,CADlB,uCAEJ,CAEA,iGAEI,oCAAyC,CADzC,0BAEJ,CAEA,2FAMI,qBAAsB,CAHtB,iBAAkB,CADlB,WAAY,CAGZ,iBAAkB,CADlB,eAAgB,CAIhB,qCAAyC,CAPzC,UAQJ,CAEA,+FAEI,WAAY,CACZ,gBAAiB,CAFjB,UAGJ,CAEA,0FACI,eACJ,CAEA,2FAKI,qBAAuB,CADvB,iBAAkB,CAGlB,WAAY,CAJZ,WAAY,CAGZ,SAAU,CALV,iBAAkB,CAClB,UAAW,CAMX,UACJ,CAEA,oGACI,wBACJ,CAEA,kGACI,wBACJ,CAEA,gGACI,wBACJ,CAQA,sOACI,YACJ,CAEA,2FAUI,iGAAkD,CANlD,qBAAuB,CACvB,kBAAmB,CACnB,oCAAyC,CACzC,YAAa,CACb,qBAAsB,CANtB,YAAa,CACb,eAAgB,CAMhB,eAAgB,CARhB,WAUJ,CAEA,sFACI,GACI,SAAU,CACV,0BACJ,CACA,GACI,SAAU,CACV,uBACJ,CACJ,CAEA,2FAMI,kBAAmB,CALnB,wBAAyB,CACzB,UAAY,CAEZ,YAAa,CACb,6BAA8B,CAF9B,YAIJ,CAMA,kGAWI,4BAA8B,CAV9B,gCAAkC,CAClC,qBAAuB,CAavB,2BAA6B,CAZ7B,yBAA2B,CAC3B,uBAAyB,CACzB,cAAe,CAKf,sBAAwB,CAIxB,qBAAuB,CAFvB,gCAAkC,CAHlC,sBAAwB,CAIxB,wBAA0B,CAP1B,UAAY,CAEZ,qBAAuB,CADvB,sBASJ,CAEA,wGAEI,6CAAqD,CADrD,SAEJ,CAGA,uGACI,sBACJ,CAGA,sGAEI,WAAY,CADZ,UAEJ,CAEA,0FAEI,eAAgB,CADhB,eAEJ,CAEA,0FAEI,eACJ,CAEA,4FAII,YAAa,CAHb,MAAO,CAIP,qBAAsB,CAHtB,eAAgB,CAChB,iBAGJ,CAEA,sLAKI,kBAAmB,CAGnB,UAAW,CALX,YAAa,CADb,MAAO,CAEP,sBAAuB,CAEvB,YAAa,CACb,iBAEJ,CAEA,0FACI,aACJ,CAEA,yBACI,2IACI,QAAS,CAET,MAAO,CADP,OAEJ,CAEA,2FAII,eAAgB,CAFhB,YAAa,CACb,gBAAiB,CAFjB,UAIJ,CACJ","file":"PromptbookAgentSeamlessIntegration.module.css","sourcesContent":[".PromptbookAgentSeamlessIntegration {\n    position: fixed;\n    bottom: 20px;\n    right: 20px;\n    z-index: 10000;\n    font-family: sans-serif;\n}\n\n.PromptbookAgentSeamlessIntegrationButton {\n    display: flex;\n    align-items: center;\n    background-color: #007bff;\n    color: white;\n    border-radius: 30px;\n    padding: 10px 20px;\n    cursor: pointer;\n    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n    transition: transform 0.2s, box-shadow 0.2s;\n    position: relative;\n}\n\n.PromptbookAgentSeamlessIntegrationButton:hover {\n    transform: translateY(-2px);\n    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);\n}\n\n.PromptbookAgentSeamlessIntegrationAvatar {\n    width: 32px;\n    height: 32px;\n    border-radius: 50%;\n    overflow: hidden;\n    margin-right: 10px;\n    background-color: #eee;\n\n    transform: translate(-10px, 0) scale(1.3);\n}\n\n.PromptbookAgentSeamlessIntegrationAvatar img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n}\n\n.PromptbookAgentSeamlessIntegrationLabel {\n    font-weight: bold;\n}\n\n.PromptbookAgentSeamlessIntegrationStatus {\n    position: absolute;\n    width: 12px;\n    height: 12px;\n    border-radius: 50%;\n    border: 2px solid white;\n    left: 40px;\n    bottom: 12px;\n    z-index: 10;\n}\n\n.PromptbookAgentSeamlessIntegrationStatusConnected {\n    background-color: #57b660;\n}\n\n.PromptbookAgentSeamlessIntegrationStatusPending {\n    background-color: #9e9e9e;\n}\n\n.PromptbookAgentSeamlessIntegrationStatusError {\n    background-color: #f44336;\n}\n\n/* State classes (empty to allow module mapping) */\n.open {\n}\n.closed {\n}\n\n.PromptbookAgentSeamlessIntegration.open .PromptbookAgentSeamlessIntegrationButton {\n    display: none;\n}\n\n.PromptbookAgentSeamlessIntegrationWindow {\n    width: 380px;\n    height: 600px;\n    max-height: 80vh;\n    background-color: white;\n    border-radius: 12px;\n    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);\n    display: flex;\n    flex-direction: column;\n    overflow: hidden;\n    animation: promptbook-agent-slide-up 0.3s ease-out;\n}\n\n@keyframes promptbook-agent-slide-up {\n    from {\n        opacity: 0;\n        transform: translateY(20px);\n    }\n    to {\n        opacity: 1;\n        transform: translateY(0);\n    }\n}\n\n.PromptbookAgentSeamlessIntegrationHeader {\n    background-color: #007bff;\n    color: white;\n    padding: 15px;\n    display: flex;\n    justify-content: space-between;\n    align-items: center;\n}\n\n/* \n   Override chat action buttons to look like the close button \n   when rendered inside the header via portal\n*/\n.PromptbookAgentSeamlessIntegrationHeader button {\n    background: transparent !important;\n    border: none !important;\n    box-shadow: none !important;\n    color: inherit !important;\n    cursor: pointer;\n    opacity: 0.8;\n    transition: opacity 0.2s;\n    padding: 5px !important;\n    margin: 0 2px !important;\n    display: flex !important;\n    align-items: center !important;\n    justify-content: center !important;\n    min-width: 32px !important;\n    height: 32px !important;\n    border-radius: 50% !important;\n}\n\n.PromptbookAgentSeamlessIntegrationHeader button:hover {\n    opacity: 1;\n    background-color: rgba(255, 255, 255, 0.2) !important;\n}\n\n/* Hide text labels inside buttons in header (New Chat, Save) */\n.PromptbookAgentSeamlessIntegrationHeader button span {\n    display: none !important;\n}\n\n/* Ensure SVG icons are visible and sized correctly */\n.PromptbookAgentSeamlessIntegrationHeader button svg {\n    width: 20px;\n    height: 20px;\n}\n\n.PromptbookAgentSeamlessIntegrationTitle {\n    font-weight: bold;\n    font-size: 1.1em;\n}\n\n.PromptbookAgentSeamlessIntegrationClose {\n    /* Use same styles as above override, but keep specific if needed */\n    font-size: 1.2em;\n}\n\n.PromptbookAgentSeamlessIntegrationContent {\n    flex: 1;\n    overflow-y: auto;\n    position: relative;\n    display: flex;\n    flex-direction: column;\n}\n\n.PromptbookAgentSeamlessIntegrationLoading,\n.PromptbookAgentSeamlessIntegrationError {\n    flex: 1;\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    padding: 20px;\n    text-align: center;\n    color: #666;\n}\n\n.PromptbookAgentSeamlessIntegrationError {\n    color: #d32f2f;\n}\n\n@media (max-width: 480px) {\n    .PromptbookAgentSeamlessIntegration.open {\n        bottom: 0;\n        right: 0;\n        left: 0;\n    }\n\n    .PromptbookAgentSeamlessIntegrationWindow {\n        width: 100%;\n        height: 100vh;\n        max-height: 100vh;\n        border-radius: 0;\n    }\n}\n"]} */";
|
|
17535
|
+
var styles = {"PromptbookAgentSeamlessIntegration":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegration__KTAQl","PromptbookAgentSeamlessIntegrationButton":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationButton__beMWa","PromptbookAgentSeamlessIntegrationAvatar":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationAvatar__OrK-R","PromptbookAgentSeamlessIntegrationLabel":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationLabel__gvgCn","PromptbookAgentSeamlessIntegrationStatus":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationStatus__QBwnt","PromptbookAgentSeamlessIntegrationStatusConnected":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationStatusConnected__w15ZJ","PromptbookAgentSeamlessIntegrationStatusPending":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationStatusPending__vtVxc","PromptbookAgentSeamlessIntegrationStatusError":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationStatusError__nu02u","open":"PromptbookAgentSeamlessIntegration-module_open__rt5ey","closed":"PromptbookAgentSeamlessIntegration-module_closed__VPHQ-","PromptbookAgentSeamlessIntegrationWindow":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationWindow__6sxeZ","promptbook-agent-slide-up":"PromptbookAgentSeamlessIntegration-module_promptbook-agent-slide-up__0dGVe","PromptbookAgentSeamlessIntegrationHeader":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationHeader__9ae8B","PromptbookAgentSeamlessIntegrationTitle":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationTitle__D6p2j","PromptbookAgentSeamlessIntegrationClose":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationClose__Ot41T","PromptbookAgentSeamlessIntegrationContent":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationContent__xqAns","PromptbookAgentSeamlessIntegrationLoading":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationLoading__OAqgE","PromptbookAgentSeamlessIntegrationError":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationError__RaBDa"};
|
|
17030
17536
|
styleInject(css_248z);
|
|
17031
17537
|
|
|
17032
17538
|
/**
|
|
17033
17539
|
* Renders a floating agent button that opens a chat window with the remote agent.
|
|
17034
17540
|
*
|
|
17035
|
-
* @
|
|
17541
|
+
* @private component of PromptbookAgentIntegration
|
|
17036
17542
|
*/
|
|
17037
|
-
function
|
|
17543
|
+
function PromptbookAgentSeamlessIntegration(props) {
|
|
17038
17544
|
var _a, _b;
|
|
17039
|
-
const { agentUrl, meta, onOpenChange } = props;
|
|
17545
|
+
const { agentUrl, meta, onOpenChange, className, style } = props;
|
|
17040
17546
|
const [isOpen, setIsOpen] = useState(false);
|
|
17041
17547
|
const [headerElement, setHeaderElement] = useState(null);
|
|
17042
17548
|
useEffect(() => {
|
|
@@ -17094,11 +17600,36 @@ function PromptbookAgent(props) {
|
|
|
17094
17600
|
else if (error) {
|
|
17095
17601
|
connectionStatus = 'error';
|
|
17096
17602
|
}
|
|
17097
|
-
return (jsxs("div", { className: `${styles.
|
|
17098
|
-
? styles.
|
|
17603
|
+
return (jsxs("div", { className: classNames(`${styles.PromptbookAgentSeamlessIntegration} ${isOpen ? styles.open : styles.closed}`, className), style: style, children: [jsxs("div", { className: styles.PromptbookAgentSeamlessIntegrationButton, onClick: () => setIsOpen(!isOpen), style: { backgroundColor: color }, children: [jsx("div", { className: styles.PromptbookAgentSeamlessIntegrationAvatar, children: jsx("img", { src: image, alt: "Agent" }) }), jsx("div", { className: `${styles.PromptbookAgentSeamlessIntegrationStatus} ${connectionStatus === 'connected'
|
|
17604
|
+
? styles.PromptbookAgentSeamlessIntegrationStatusConnected
|
|
17099
17605
|
: connectionStatus === 'error'
|
|
17100
|
-
? styles.
|
|
17101
|
-
: styles.
|
|
17606
|
+
? styles.PromptbookAgentSeamlessIntegrationStatusError
|
|
17607
|
+
: styles.PromptbookAgentSeamlessIntegrationStatusPending}` }), jsx("div", { className: styles.PromptbookAgentSeamlessIntegrationLabel, children: "CHAT" })] }), isOpen && (jsxs("div", { className: styles.PromptbookAgentSeamlessIntegrationWindow, children: [jsx("div", { className: styles.PromptbookAgentSeamlessIntegrationHeader, style: { backgroundColor: color }, ref: setHeaderElement, children: jsx("div", { className: styles.PromptbookAgentSeamlessIntegrationTitle, children: (agent === null || agent === void 0 ? void 0 : agent.meta.fullname) || (meta === null || meta === void 0 ? void 0 : meta.fullname) || (agent === null || agent === void 0 ? void 0 : agent.agentName) || 'Chat with Agent' }) }), jsx("div", { className: styles.PromptbookAgentSeamlessIntegrationContent, children: agent ? (jsx(AgentChat, { agent: agent, actionsContainer: headerElement, extraActions: jsx("button", { className: styles.PromptbookAgentSeamlessIntegrationClose, onClick: () => setIsOpen(false), title: "Close", children: jsx(CloseIcon, {}) }) })) : error ? (jsxs("div", { className: styles.PromptbookAgentSeamlessIntegrationError, children: ["Failed to connect to agent: ", error.message] })) : (jsx("div", { className: styles.PromptbookAgentSeamlessIntegrationLoading, children: "Connecting to agent..." })) })] }))] }));
|
|
17608
|
+
}
|
|
17609
|
+
|
|
17610
|
+
/**
|
|
17611
|
+
* Renders a floating agent button that opens a chat window with the remote agent.
|
|
17612
|
+
*
|
|
17613
|
+
* @public exported from `@promptbook/components`
|
|
17614
|
+
*/
|
|
17615
|
+
function PromptbookAgentIntegration(props) {
|
|
17616
|
+
const { agentUrl, formfactor = 'seamless', meta, onOpenChange, className, style } = props;
|
|
17617
|
+
if (just(false)) ;
|
|
17618
|
+
else if (formfactor === 'seamless') {
|
|
17619
|
+
return jsx(PromptbookAgentSeamlessIntegration, { agentUrl, meta, onOpenChange, className, style });
|
|
17620
|
+
}
|
|
17621
|
+
else if (formfactor === 'book') {
|
|
17622
|
+
return jsx("iframe", { src: agentUrl + '/book?headless', className: className, style: style });
|
|
17623
|
+
}
|
|
17624
|
+
else if (formfactor === 'chat') {
|
|
17625
|
+
return jsx("iframe", { src: agentUrl + '/chat?headless', className: className, style: style });
|
|
17626
|
+
}
|
|
17627
|
+
else if (formfactor === 'profile') {
|
|
17628
|
+
return jsx("iframe", { src: agentUrl + '?headless', className: className, style: style });
|
|
17629
|
+
}
|
|
17630
|
+
else {
|
|
17631
|
+
throw new Error(`PromptbookAgentIntegration: Unsupported formfactor "${formfactor}"`);
|
|
17632
|
+
}
|
|
17102
17633
|
}
|
|
17103
17634
|
|
|
17104
17635
|
/**
|
|
@@ -17375,5 +17906,5 @@ function injectCssModuleIntoShadowRoot(options) {
|
|
|
17375
17906
|
}
|
|
17376
17907
|
}
|
|
17377
17908
|
|
|
17378
|
-
export { AboutPromptbookInformation, AgentChat, ArrowIcon, AttachmentIcon, AvatarChip, AvatarChipFromSource, AvatarProfile, AvatarProfileFromSource, BLOCKY_FLOW, BOOK_LANGUAGE_VERSION, BookEditor, BrandedQrCode, CHAT_SAVE_FORMATS, Chat, DEFAULT_BOOK_EDITOR_HEIGHT, FAST_FLOW, GenericQrCode, LlmChat, MOCKED_CHAT_DELAY_CONFIGS, MarkdownContent, MicIcon, MockedChat, NORMAL_FLOW, PROMPTBOOK_ENGINE_VERSION, PauseIcon, PlayIcon,
|
|
17909
|
+
export { AboutPromptbookInformation, AgentChat, ArrowIcon, AttachmentIcon, AvatarChip, AvatarChipFromSource, AvatarProfile, AvatarProfileFromSource, BLOCKY_FLOW, BOOK_LANGUAGE_VERSION, BookEditor, BrandedQrCode, CHAT_SAVE_FORMATS, Chat, DEFAULT_BOOK_EDITOR_HEIGHT, FAST_FLOW, GenericQrCode, LlmChat, MOCKED_CHAT_DELAY_CONFIGS, MarkdownContent, MicIcon, MockedChat, NORMAL_FLOW, PROMPTBOOK_ENGINE_VERSION, PauseIcon, PlayIcon, PromptbookAgentIntegration, PromptbookQrCode, RANDOM_FLOW, ResetIcon, SLOW_FLOW, SaveIcon, SendIcon, TemplateIcon, getChatSaveFormatDefinitions, htmlSaveFormatDefinition, injectCssModuleIntoShadowRoot, jsonSaveFormatDefinition, mdSaveFormatDefinition, parseMessageButtons, pdfSaveFormatDefinition, reactSaveFormatDefinition, txtSaveFormatDefinition, useChatAutoScroll, useSendMessageToLlmChat };
|
|
17379
17910
|
//# sourceMappingURL=index.es.js.map
|