genassist-chat-react 1.0.21 → 1.0.22
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/AttachmentPreview.js +7 -2
- package/dist/components/ChatMessage.js +4 -15
- package/dist/components/GenAgentChat.js +84 -34
- package/dist/components/InteractiveContent.js +18 -1
- package/dist/components/common/UploadFilePreview.d.ts +8 -0
- package/dist/components/common/UploadFilePreview.js +54 -0
- package/dist/hooks/useChat.d.ts +2 -1
- package/dist/hooks/useChat.js +38 -30
- package/dist/services/chatService.d.ts +4 -5
- package/dist/services/chatService.js +49 -5
- package/dist/types/index.d.ts +24 -0
- package/dist/types/index.js +1 -1
- package/dist/utils/interactiveContent.d.ts +1 -1
- package/dist/utils/interactiveContent.js +15 -2
- package/package.json +1 -1
|
@@ -11,6 +11,7 @@ var __assign = (this && this.__assign) || function () {
|
|
|
11
11
|
};
|
|
12
12
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
13
13
|
import React from 'react';
|
|
14
|
+
import { getFileIcon } from './FileTypeIcon';
|
|
14
15
|
import { X } from 'lucide-react';
|
|
15
16
|
// Utility function to parse markdown bold syntax (**text**) and convert to React elements
|
|
16
17
|
export var parseBoldText = function (input) {
|
|
@@ -41,6 +42,14 @@ export var InteractiveContent = function (_a) {
|
|
|
41
42
|
return null;
|
|
42
43
|
return (_jsx("div", { style: { display: 'flex', flexDirection: 'column', gap: 12 }, children: blocks.map(function (block, index) {
|
|
43
44
|
switch (block.kind) {
|
|
45
|
+
case 'file':
|
|
46
|
+
var fileData = block.data;
|
|
47
|
+
if (fileData && fileData.type && fileData.type.startsWith('image')) {
|
|
48
|
+
return _jsx(ImageBlock, { imageData: fileData }, index);
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
return _jsx(FileBlock, { fileData: fileData }, index);
|
|
52
|
+
}
|
|
44
53
|
case 'text':
|
|
45
54
|
return _jsx(TextBlock, { text: block.text }, index);
|
|
46
55
|
case 'options':
|
|
@@ -185,4 +194,12 @@ var ScheduleBlock = function (_a) {
|
|
|
185
194
|
boxShadow: '0 1px 4px rgba(0,0,0,0.12)',
|
|
186
195
|
}, children: "Confirm" }) }))] }));
|
|
187
196
|
};
|
|
188
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"InteractiveContent.js","sourceRoot":"","sources":["../../src/components/InteractiveContent.tsx"],"names":[],"mappings":"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","sourcesContent":["import React from 'react';\nimport { X } from 'lucide-react';\nimport { ChatContentBlock, DynamicChatItem, ScheduleItem } from '../types';\n\n// Utility function to parse markdown bold syntax (**text**) and convert to React elements\nexport const parseBoldText = (input: string): React.ReactNode[] => {\n  const parts: React.ReactNode[] = [];\n  const boldRegex = /\\*\\*(.*?)\\*\\*/g;\n  let lastIndex = 0;\n  let match;\n  let key = 0;\n\n  while ((match = boldRegex.exec(input)) !== null) {\n    // Add text before the match\n    if (match.index > lastIndex) {\n      parts.push(input.slice(lastIndex, match.index));\n    }\n    \n    // Add bold text\n    parts.push(\n      <strong key={key++} style={{ fontWeight: 700 }}>\n        {match[1]}\n      </strong>\n    );\n    \n    lastIndex = match.index + match[0].length;\n  }\n\n  // Add remaining text after the last match\n  if (lastIndex < input.length) {\n    parts.push(input.slice(lastIndex));\n  }\n\n  // If no matches found, return the original text\n  return parts.length > 0 ? parts : [input];\n};\n\ninterface InteractiveContentProps {\n  blocks: ChatContentBlock[];\n  primaryColor: string;\n  textColor: string;\n  isActionable: boolean;\n  onQuickAction?: (text: string) => void;\n  onScheduleConfirm?: (schedule: ScheduleItem) => void;\n}\n\nexport const InteractiveContent: React.FC<InteractiveContentProps> = ({\n  blocks,\n  primaryColor,\n  textColor,\n  isActionable,\n  onQuickAction,\n  onScheduleConfirm,\n}) => {\n  if (!blocks.length) return null;\n\n  return (\n    <div style={{ display: 'flex', flexDirection: 'column', gap: 12 }}>\n      {blocks.map((block, index) => {\n        switch (block.kind) {\n          case 'text':\n            return <TextBlock key={index} text={block.text} />;\n          case 'options':\n            return (\n              <QuickOptions\n                key={index}\n                options={block.options}\n                primaryColor={primaryColor}\n                isActionable={isActionable}\n                onQuickAction={onQuickAction}\n              />\n            );\n          case 'items':\n            return (\n              <DynamicItemsList\n                key={index}\n                items={block.items}\n                primaryColor={primaryColor}\n                textColor={textColor}\n                isActionable={isActionable}\n                onSelect={onQuickAction}\n              />\n            );\n          case 'schedule':\n            return (\n              <ScheduleBlock\n                key={index}\n                schedule={block.schedule}\n                primaryColor={primaryColor}\n                textColor={textColor}\n                isActionable={isActionable}\n                onQuickAction={onQuickAction}\n                onConfirm={onScheduleConfirm}\n              />\n            );\n          default:\n            return null;\n        }\n      })}\n    </div>\n  );\n};\n\nconst TextBlock: React.FC<{ text: string }> = ({ text }) => {\n  return (\n    <div style={{ whiteSpace: 'pre-wrap', lineHeight: 1.5 }}>\n      {parseBoldText(text)}\n    </div>\n  );\n};\n\ninterface QuickOptionsProps {\n  options: string[];\n  primaryColor: string;\n  isActionable: boolean;\n  onQuickAction?: (text: string) => void;\n}\n\nconst QuickOptions: React.FC<QuickOptionsProps> = ({\n  options,\n  primaryColor,\n  isActionable,\n  onQuickAction,\n}) => {\n  const [visibleOptions, setVisibleOptions] = React.useState(options);\n\n  React.useEffect(() => {\n    setVisibleOptions(options);\n  }, [options]);\n\n  if (!visibleOptions.length) return null;\n\n  return (\n    <div\n      style={{\n        display: 'flex',\n        gap: 8,\n        flexWrap: 'wrap',\n      }}\n    >\n      {visibleOptions.map((option, idx) => (\n        <button\n          key={`${option}-${idx}`}\n          type=\"button\"\n          disabled={!isActionable}\n          onClick={() => {\n            if (!isActionable) return;\n            setVisibleOptions([]);\n            onQuickAction?.(option);\n          }}\n          style={{\n            borderRadius: 99,\n            border: 'none',\n            backgroundColor: primaryColor,\n            padding: '12px 12px',\n            cursor: isActionable ? 'pointer' : 'not-allowed',\n            fontWeight: 500,\n            fontSize: 14,\n            color: '#ffffff',\n            whiteSpace: 'nowrap',\n            transition: 'transform 0.12s ease, opacity 0.12s ease',\n            opacity: isActionable ? 1 : 0.6,\n            boxShadow: '0 2px 6px rgba(0,0,0,0.12)',\n          }}\n        >\n          {option}\n        </button>\n      ))}\n    </div>\n  );\n};\n\ninterface DynamicItemsListProps {\n  items: DynamicChatItem[];\n  primaryColor: string;\n  textColor: string;\n  isActionable: boolean;\n  onSelect?: (text: string) => void;\n}\n\nconst DynamicItemsList: React.FC<DynamicItemsListProps> = ({\n  items,\n  primaryColor,\n  textColor,\n  isActionable,\n  onSelect,\n}) => {\n  return (\n    <div style={{ display: 'flex', flexDirection: 'column', gap: 10 }}>\n      {items.map((item) => (\n        <DynamicItemCard\n          key={item.id}\n          item={item}\n          primaryColor={primaryColor}\n          textColor={textColor}\n          isActionable={isActionable}\n          onSelect={() => isActionable && onSelect?.(item.name)}\n        />\n      ))}\n    </div>\n  );\n};\n\ninterface DynamicItemCardProps {\n  item: DynamicChatItem;\n  primaryColor: string;\n  textColor: string;\n  isActionable: boolean;\n  onSelect?: () => void;\n  onSlotSelect?: (slot: string) => void;\n  onRemove?: () => void;\n}\n\nconst DynamicItemCard: React.FC<DynamicItemCardProps> = ({\n  item,\n  primaryColor,\n  textColor,\n  isActionable,\n  onSelect,\n  onSlotSelect,\n  onRemove,\n}) => {\n  const [expanded, setExpanded] = React.useState(false);\n  const hasSlots = Array.isArray(item.slots) && item.slots.length > 0;\n\n  const handleCardClick = () => {\n    setExpanded((prev) => !prev);\n    onSelect?.();\n  };\n\n  return (\n    <div\n      onClick={handleCardClick}\n      style={{\n        display: 'flex',\n        gap: 12,\n        padding: 12,\n        borderRadius: 12,\n        border: '1px solid #e5e7eb',\n        backgroundColor: '#f8fafc',\n        cursor: isActionable ? 'pointer' : 'default',\n        boxShadow: '0 1px 2px rgba(0,0,0,0.05)',\n      }}\n    >\n      {item.image && (\n        <img\n          src={item.image}\n          alt={item.name}\n          style={{ width: 64, height: 64, borderRadius: 8, objectFit: 'cover' }}\n        />\n      )}\n      <div style={{ flex: 1, minWidth: 0, display: 'flex', flexDirection: 'column', gap: 4 }}>\n        <div style={{ display: 'flex', alignItems: 'flex-start', gap: 8 }}>\n          <div style={{ fontWeight: 700, color: textColor, fontSize: 15, flex: 1 }}>\n            {item.name}\n          </div>\n          {onRemove && (\n            <button\n              type=\"button\"\n              onClick={(e) => {\n                e.stopPropagation();\n                onRemove();\n              }}\n              style={{\n                background: '#f1f5f9',\n                borderRadius: 9999,\n                border: '1px solid #e2e8f0',\n                width: 28,\n                height: 28,\n                display: 'flex',\n                alignItems: 'center',\n                justifyContent: 'center',\n                cursor: 'pointer',\n              }}\n            >\n              <X size={16} />\n            </button>\n          )}\n        </div>\n        {item.category && (\n          <div style={{ color: '#6b7280', fontSize: 13, fontWeight: 500 }}>\n            {item.category}\n          </div>\n        )}\n        {item.description && (\n          <div\n            style={{\n              color: '#374151',\n              fontSize: 13,\n              lineHeight: 1.5,\n              display: '-webkit-box',\n              WebkitLineClamp: expanded ? 'unset' : 3,\n              WebkitBoxOrient: 'vertical',\n              overflow: expanded ? 'visible' : 'hidden',\n            }}\n          >\n            {item.description}\n          </div>\n        )}\n        {hasSlots && (\n          <div style={{ display: 'flex', gap: 8, flexWrap: 'wrap', marginTop: 4 }}>\n            {item.slots!.map((slot) => {\n              const isSelected = item.selectedSlot === slot;\n              return (\n                <button\n                  key={slot}\n                  type=\"button\"\n                  disabled={!isActionable}\n                  onClick={(e) => {\n                    e.stopPropagation();\n                    if (!isActionable) return;\n                    onSlotSelect?.(slot);\n                  }}\n                  style={{\n                    borderRadius: 9999,\n                    border: `1px solid ${isSelected ? primaryColor : '#e5e7eb'}`,\n                    backgroundColor: isSelected ? primaryColor : '#ffffff',\n                    color: isSelected ? '#ffffff' : '#111827',\n                    padding: '6px 12px',\n                    cursor: isActionable ? 'pointer' : 'not-allowed',\n                    fontSize: 13,\n                    fontWeight: 600,\n                  }}\n                >\n                  {slot}\n                </button>\n              );\n            })}\n          </div>\n        )}\n      </div>\n    </div>\n  );\n};\n\ninterface ScheduleBlockProps {\n  schedule: ScheduleItem;\n  primaryColor: string;\n  textColor: string;\n  isActionable: boolean;\n  onQuickAction?: (text: string) => void;\n  onConfirm?: (schedule: ScheduleItem) => void;\n}\n\nconst ScheduleBlock: React.FC<ScheduleBlockProps> = ({\n  schedule,\n  primaryColor,\n  textColor,\n  isActionable,\n  onQuickAction,\n  onConfirm,\n}) => {\n  const [currentSchedule, setCurrentSchedule] = React.useState<ScheduleItem>(schedule);\n\n  React.useEffect(() => {\n    setCurrentSchedule(schedule);\n  }, [schedule]);\n\n  const updateRestaurant = (id: string, updater: (item: DynamicChatItem) => DynamicChatItem) => {\n    setCurrentSchedule((prev) => ({\n      ...prev,\n      restaurants: prev.restaurants.map((restaurant) =>\n        restaurant.id === id ? updater(restaurant) : restaurant\n      ),\n    }));\n  };\n\n  const removeRestaurant = (id: string) => {\n    setCurrentSchedule((prev) => ({\n      ...prev,\n      restaurants: prev.restaurants.filter((restaurant) => restaurant.id !== id),\n    }));\n  };\n\n  return (\n    <div style={{ display: 'flex', flexDirection: 'column', gap: 10 }}>\n      <div\n        style={{\n          padding: 12,\n          borderRadius: 12,\n          backgroundColor: '#f8fafc',\n          border: '1px solid #e5e7eb',\n          fontWeight: 700,\n          color: textColor,\n        }}\n      >\n        {currentSchedule.title || 'Schedule'}\n      </div>\n\n      <div style={{ display: 'flex', flexDirection: 'column', gap: 10 }}>\n        {currentSchedule.restaurants.map((restaurant) => (\n          <DynamicItemCard\n            key={restaurant.id}\n            item={restaurant}\n            primaryColor={primaryColor}\n            textColor={textColor}\n            isActionable={isActionable}\n            onSelect={() => isActionable && onQuickAction?.(restaurant.name)}\n            onSlotSelect={(slot) =>\n              updateRestaurant(restaurant.id, (item) => ({ ...item, selectedSlot: slot }))\n            }\n            onRemove={isActionable ? () => removeRestaurant(restaurant.id) : undefined}\n          />\n        ))}\n      </div>\n\n      {isActionable && currentSchedule.restaurants.length > 0 && (\n        <div style={{ display: 'flex', justifyContent: 'flex-start' }}>\n          <button\n            type=\"button\"\n            onClick={() => onConfirm?.(currentSchedule)}\n            style={{\n              backgroundColor: primaryColor,\n              color: '#ffffff',\n              border: 'none',\n              borderRadius: 10,\n              padding: '10px 16px',\n              fontWeight: 700,\n              cursor: 'pointer',\n              boxShadow: '0 1px 4px rgba(0,0,0,0.12)',\n            }}\n          >\n            Confirm\n          </button>\n        </div>\n      )}\n    </div>\n  );\n};\n"]}
|
|
197
|
+
var ImageBlock = function (_a) {
|
|
198
|
+
var imageData = _a.imageData;
|
|
199
|
+
return (_jsx("div", { style: { display: 'flex', alignItems: 'center', gap: 8, cursor: 'pointer' }, onClick: function () { return window.open(imageData.url, '_blank'); }, children: _jsx("img", { src: imageData.url, alt: "Image", style: { width: 80, height: 64, borderRadius: 8, objectFit: 'cover' } }) }));
|
|
200
|
+
};
|
|
201
|
+
var FileBlock = function (_a) {
|
|
202
|
+
var fileData = _a.fileData;
|
|
203
|
+
return (_jsxs("div", { style: { display: 'flex', alignItems: 'center', gap: 8, cursor: 'pointer' }, onClick: function () { return window.open(fileData.url, '_blank'); }, children: [getFileIcon(fileData.type), _jsx("span", { className: "text-xs text-muted-foreground", children: fileData.name })] }));
|
|
204
|
+
};
|
|
205
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"InteractiveContent.js","sourceRoot":"","sources":["../../src/components/InteractiveContent.tsx"],"names":[],"mappings":"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","sourcesContent":["import React from 'react';\nimport { ChatContentBlock, DynamicChatItem, FileItem, ScheduleItem } from '../types';\nimport { getFileIcon } from './FileTypeIcon';\nimport { X } from 'lucide-react';\n\n// Utility function to parse markdown bold syntax (**text**) and convert to React elements\nexport const parseBoldText = (input: string): React.ReactNode[] => {\n  const parts: React.ReactNode[] = [];\n  const boldRegex = /\\*\\*(.*?)\\*\\*/g;\n  let lastIndex = 0;\n  let match;\n  let key = 0;\n\n  while ((match = boldRegex.exec(input)) !== null) {\n    // Add text before the match\n    if (match.index > lastIndex) {\n      parts.push(input.slice(lastIndex, match.index));\n    }\n    \n    // Add bold text\n    parts.push(\n      <strong key={key++} style={{ fontWeight: 700 }}>\n        {match[1]}\n      </strong>\n    );\n    \n    lastIndex = match.index + match[0].length;\n  }\n\n  // Add remaining text after the last match\n  if (lastIndex < input.length) {\n    parts.push(input.slice(lastIndex));\n  }\n\n  // If no matches found, return the original text\n  return parts.length > 0 ? parts : [input];\n};\n\ninterface InteractiveContentProps {\n  blocks: ChatContentBlock[];\n  primaryColor: string;\n  textColor: string;\n  isActionable: boolean;\n  onQuickAction?: (text: string) => void;\n  onScheduleConfirm?: (schedule: ScheduleItem) => void;\n}\n\nexport const InteractiveContent: React.FC<InteractiveContentProps> = ({\n  blocks,\n  primaryColor,\n  textColor,\n  isActionable,\n  onQuickAction,\n  onScheduleConfirm,\n}) => {\n  if (!blocks.length) return null;\n\n  return (\n    <div style={{ display: 'flex', flexDirection: 'column', gap: 12 }}>\n      {blocks.map((block, index) => {\n        \n        switch (block.kind) {\n          case 'file':\n            const fileData = block.data;\n            if (fileData && fileData.type && fileData.type.startsWith('image')) {\n              return <ImageBlock key={index} imageData={fileData} />;\n            } else {\n              return <FileBlock key={index} fileData={fileData} />;\n            }\n          case 'text':\n            return <TextBlock key={index} text={block.text} />;\n          case 'options':\n            return (\n              <QuickOptions\n                key={index}\n                options={block.options}\n                primaryColor={primaryColor}\n                isActionable={isActionable}\n                onQuickAction={onQuickAction}\n              />\n            );\n          case 'items':\n            return (\n              <DynamicItemsList\n                key={index}\n                items={block.items}\n                primaryColor={primaryColor}\n                textColor={textColor}\n                isActionable={isActionable}\n                onSelect={onQuickAction}\n              />\n            );\n          case 'schedule':\n            return (\n              <ScheduleBlock\n                key={index}\n                schedule={block.schedule}\n                primaryColor={primaryColor}\n                textColor={textColor}\n                isActionable={isActionable}\n                onQuickAction={onQuickAction}\n                onConfirm={onScheduleConfirm}\n              />\n            );\n          default:\n            return null;\n        }\n      })}\n    </div>\n  );\n};\n\nconst TextBlock: React.FC<{ text: string }> = ({ text }) => {\n  return (\n    <div style={{ whiteSpace: 'pre-wrap', lineHeight: 1.5 }}>\n      {parseBoldText(text)}\n    </div>\n  );\n};\n\ninterface QuickOptionsProps {\n  options: string[];\n  primaryColor: string;\n  isActionable: boolean;\n  onQuickAction?: (text: string) => void;\n}\n\nconst QuickOptions: React.FC<QuickOptionsProps> = ({\n  options,\n  primaryColor,\n  isActionable,\n  onQuickAction,\n}) => {\n  const [visibleOptions, setVisibleOptions] = React.useState(options);\n\n  React.useEffect(() => {\n    setVisibleOptions(options);\n  }, [options]);\n\n  if (!visibleOptions.length) return null;\n\n  return (\n    <div\n      style={{\n        display: 'flex',\n        gap: 8,\n        flexWrap: 'wrap',\n      }}\n    >\n      {visibleOptions.map((option, idx) => (\n        <button\n          key={`${option}-${idx}`}\n          type=\"button\"\n          disabled={!isActionable}\n          onClick={() => {\n            if (!isActionable) return;\n            setVisibleOptions([]);\n            onQuickAction?.(option);\n          }}\n          style={{\n            borderRadius: 99,\n            border: 'none',\n            backgroundColor: primaryColor,\n            padding: '12px 12px',\n            cursor: isActionable ? 'pointer' : 'not-allowed',\n            fontWeight: 500,\n            fontSize: 14,\n            color: '#ffffff',\n            whiteSpace: 'nowrap',\n            transition: 'transform 0.12s ease, opacity 0.12s ease',\n            opacity: isActionable ? 1 : 0.6,\n            boxShadow: '0 2px 6px rgba(0,0,0,0.12)',\n          }}\n        >\n          {option}\n        </button>\n      ))}\n    </div>\n  );\n};\n\ninterface DynamicItemsListProps {\n  items: DynamicChatItem[];\n  primaryColor: string;\n  textColor: string;\n  isActionable: boolean;\n  onSelect?: (text: string) => void;\n}\n\nconst DynamicItemsList: React.FC<DynamicItemsListProps> = ({\n  items,\n  primaryColor,\n  textColor,\n  isActionable,\n  onSelect,\n}) => {\n  return (\n    <div style={{ display: 'flex', flexDirection: 'column', gap: 10 }}>\n      {items.map((item) => (\n        <DynamicItemCard\n          key={item.id}\n          item={item}\n          primaryColor={primaryColor}\n          textColor={textColor}\n          isActionable={isActionable}\n          onSelect={() => isActionable && onSelect?.(item.name)}\n        />\n      ))}\n    </div>\n  );\n};\n\ninterface DynamicItemCardProps {\n  item: DynamicChatItem;\n  primaryColor: string;\n  textColor: string;\n  isActionable: boolean;\n  onSelect?: () => void;\n  onSlotSelect?: (slot: string) => void;\n  onRemove?: () => void;\n}\n\nconst DynamicItemCard: React.FC<DynamicItemCardProps> = ({\n  item,\n  primaryColor,\n  textColor,\n  isActionable,\n  onSelect,\n  onSlotSelect,\n  onRemove,\n}) => {\n  const [expanded, setExpanded] = React.useState(false);\n  const hasSlots = Array.isArray(item.slots) && item.slots.length > 0;\n\n  const handleCardClick = () => {\n    setExpanded((prev) => !prev);\n    onSelect?.();\n  };\n\n  return (\n    <div\n      onClick={handleCardClick}\n      style={{\n        display: 'flex',\n        gap: 12,\n        padding: 12,\n        borderRadius: 12,\n        border: '1px solid #e5e7eb',\n        backgroundColor: '#f8fafc',\n        cursor: isActionable ? 'pointer' : 'default',\n        boxShadow: '0 1px 2px rgba(0,0,0,0.05)',\n      }}\n    >\n      {item.image && (\n        <img\n          src={item.image}\n          alt={item.name}\n          style={{ width: 64, height: 64, borderRadius: 8, objectFit: 'cover' }}\n        />\n      )}\n      <div style={{ flex: 1, minWidth: 0, display: 'flex', flexDirection: 'column', gap: 4 }}>\n        <div style={{ display: 'flex', alignItems: 'flex-start', gap: 8 }}>\n          <div style={{ fontWeight: 700, color: textColor, fontSize: 15, flex: 1 }}>\n            {item.name}\n          </div>\n          {onRemove && (\n            <button\n              type=\"button\"\n              onClick={(e) => {\n                e.stopPropagation();\n                onRemove();\n              }}\n              style={{\n                background: '#f1f5f9',\n                borderRadius: 9999,\n                border: '1px solid #e2e8f0',\n                width: 28,\n                height: 28,\n                display: 'flex',\n                alignItems: 'center',\n                justifyContent: 'center',\n                cursor: 'pointer',\n              }}\n            >\n              <X size={16} />\n            </button>\n          )}\n        </div>\n        {item.category && (\n          <div style={{ color: '#6b7280', fontSize: 13, fontWeight: 500 }}>\n            {item.category}\n          </div>\n        )}\n        {item.description && (\n          <div\n            style={{\n              color: '#374151',\n              fontSize: 13,\n              lineHeight: 1.5,\n              display: '-webkit-box',\n              WebkitLineClamp: expanded ? 'unset' : 3,\n              WebkitBoxOrient: 'vertical',\n              overflow: expanded ? 'visible' : 'hidden',\n            }}\n          >\n            {item.description}\n          </div>\n        )}\n        {hasSlots && (\n          <div style={{ display: 'flex', gap: 8, flexWrap: 'wrap', marginTop: 4 }}>\n            {item.slots!.map((slot) => {\n              const isSelected = item.selectedSlot === slot;\n              return (\n                <button\n                  key={slot}\n                  type=\"button\"\n                  disabled={!isActionable}\n                  onClick={(e) => {\n                    e.stopPropagation();\n                    if (!isActionable) return;\n                    onSlotSelect?.(slot);\n                  }}\n                  style={{\n                    borderRadius: 9999,\n                    border: `1px solid ${isSelected ? primaryColor : '#e5e7eb'}`,\n                    backgroundColor: isSelected ? primaryColor : '#ffffff',\n                    color: isSelected ? '#ffffff' : '#111827',\n                    padding: '6px 12px',\n                    cursor: isActionable ? 'pointer' : 'not-allowed',\n                    fontSize: 13,\n                    fontWeight: 600,\n                  }}\n                >\n                  {slot}\n                </button>\n              );\n            })}\n          </div>\n        )}\n      </div>\n    </div>\n  );\n};\n\ninterface ScheduleBlockProps {\n  schedule: ScheduleItem;\n  primaryColor: string;\n  textColor: string;\n  isActionable: boolean;\n  onQuickAction?: (text: string) => void;\n  onConfirm?: (schedule: ScheduleItem) => void;\n}\n\nconst ScheduleBlock: React.FC<ScheduleBlockProps> = ({\n  schedule,\n  primaryColor,\n  textColor,\n  isActionable,\n  onQuickAction,\n  onConfirm,\n}) => {\n  const [currentSchedule, setCurrentSchedule] = React.useState<ScheduleItem>(schedule);\n\n  React.useEffect(() => {\n    setCurrentSchedule(schedule);\n  }, [schedule]);\n\n  const updateRestaurant = (id: string, updater: (item: DynamicChatItem) => DynamicChatItem) => {\n    setCurrentSchedule((prev) => ({\n      ...prev,\n      restaurants: prev.restaurants.map((restaurant) =>\n        restaurant.id === id ? updater(restaurant) : restaurant\n      ),\n    }));\n  };\n\n  const removeRestaurant = (id: string) => {\n    setCurrentSchedule((prev) => ({\n      ...prev,\n      restaurants: prev.restaurants.filter((restaurant) => restaurant.id !== id),\n    }));\n  };\n\n  return (\n    <div style={{ display: 'flex', flexDirection: 'column', gap: 10 }}>\n      <div\n        style={{\n          padding: 12,\n          borderRadius: 12,\n          backgroundColor: '#f8fafc',\n          border: '1px solid #e5e7eb',\n          fontWeight: 700,\n          color: textColor,\n        }}\n      >\n        {currentSchedule.title || 'Schedule'}\n      </div>\n\n      <div style={{ display: 'flex', flexDirection: 'column', gap: 10 }}>\n        {currentSchedule.restaurants.map((restaurant) => (\n          <DynamicItemCard\n            key={restaurant.id}\n            item={restaurant}\n            primaryColor={primaryColor}\n            textColor={textColor}\n            isActionable={isActionable}\n            onSelect={() => isActionable && onQuickAction?.(restaurant.name)}\n            onSlotSelect={(slot) =>\n              updateRestaurant(restaurant.id, (item) => ({ ...item, selectedSlot: slot }))\n            }\n            onRemove={isActionable ? () => removeRestaurant(restaurant.id) : undefined}\n          />\n        ))}\n      </div>\n\n      {isActionable && currentSchedule.restaurants.length > 0 && (\n        <div style={{ display: 'flex', justifyContent: 'flex-start' }}>\n          <button\n            type=\"button\"\n            onClick={() => onConfirm?.(currentSchedule)}\n            style={{\n              backgroundColor: primaryColor,\n              color: '#ffffff',\n              border: 'none',\n              borderRadius: 10,\n              padding: '10px 16px',\n              fontWeight: 700,\n              cursor: 'pointer',\n              boxShadow: '0 1px 4px rgba(0,0,0,0.12)',\n            }}\n          >\n            Confirm\n          </button>\n        </div>\n      )}\n    </div>\n  );\n};\n\nconst ImageBlock: React.FC<{ imageData: FileItem }> = ({ imageData }) => {\n  return (\n    <div style={{ display: 'flex', alignItems: 'center', gap: 8, cursor: 'pointer' }} onClick={() => window.open(imageData.url, '_blank')}>\n      <img src={imageData.url} alt=\"Image\" style={{ width: 80, height: 64, borderRadius: 8, objectFit: 'cover' }} />\n    </div>\n  );\n};\n\nconst FileBlock: React.FC<{ fileData: FileItem }> = ({ fileData }) => {\n  return (\n    <div style={{ display: 'flex', alignItems: 'center', gap: 8, cursor: 'pointer' }} onClick={() => window.open(fileData.url, '_blank')}>\n      {getFileIcon(fileData.type)}\n      <span className=\"text-xs text-muted-foreground\">{fileData.name}</span>\n    </div>\n  );\n};"]}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { getFileIcon } from '../FileTypeIcon';
|
|
3
|
+
export var UploadFilePreview = function (_a) {
|
|
4
|
+
var file = _a.file, index = _a.index;
|
|
5
|
+
var fileType = file === null || file === void 0 ? void 0 : file.type;
|
|
6
|
+
// const baseUrl = process.env.REACT_APP_BASE_URL;
|
|
7
|
+
var containerStyle = {
|
|
8
|
+
cursor: 'pointer',
|
|
9
|
+
};
|
|
10
|
+
var contentStyle = {
|
|
11
|
+
display: 'flex',
|
|
12
|
+
alignItems: 'center',
|
|
13
|
+
padding: '8px',
|
|
14
|
+
backgroundColor: '#f0f0f0',
|
|
15
|
+
borderRadius: '8px',
|
|
16
|
+
position: 'relative',
|
|
17
|
+
maxWidth: '250px',
|
|
18
|
+
};
|
|
19
|
+
var imageStyle = {
|
|
20
|
+
width: '40px',
|
|
21
|
+
height: '40px',
|
|
22
|
+
borderRadius: '4px',
|
|
23
|
+
objectFit: 'cover',
|
|
24
|
+
marginRight: '10px',
|
|
25
|
+
};
|
|
26
|
+
var fileNameStyle = {
|
|
27
|
+
width: '90%',
|
|
28
|
+
maxWidth: '150px',
|
|
29
|
+
fontWeight: 'bold',
|
|
30
|
+
fontSize: '14px',
|
|
31
|
+
overflow: 'hidden',
|
|
32
|
+
textOverflow: 'ellipsis',
|
|
33
|
+
whiteSpace: 'nowrap',
|
|
34
|
+
};
|
|
35
|
+
var fileSizeStyle = {
|
|
36
|
+
fontSize: '12px',
|
|
37
|
+
color: '#666',
|
|
38
|
+
};
|
|
39
|
+
var fileIconStyle = {
|
|
40
|
+
width: 40,
|
|
41
|
+
height: 40,
|
|
42
|
+
display: 'flex',
|
|
43
|
+
alignItems: 'center',
|
|
44
|
+
justifyContent: 'center',
|
|
45
|
+
};
|
|
46
|
+
var openFile = function () {
|
|
47
|
+
window.open(file === null || file === void 0 ? void 0 : file.url, '_blank');
|
|
48
|
+
};
|
|
49
|
+
var renderContent = function () {
|
|
50
|
+
return (_jsxs("div", { style: contentStyle, children: [(fileType === null || fileType === void 0 ? void 0 : fileType.startsWith('image/')) ? (_jsx("img", { src: file === null || file === void 0 ? void 0 : file.url, alt: file === null || file === void 0 ? void 0 : file.name, style: imageStyle })) : (_jsx("div", { style: fileIconStyle, children: getFileIcon(fileType || '') })), _jsxs("div", { style: { display: 'flex', flexDirection: 'column' }, children: [_jsx("div", { style: fileNameStyle, title: file === null || file === void 0 ? void 0 : file.name, children: file === null || file === void 0 ? void 0 : file.name }), _jsxs("div", { style: fileSizeStyle, children: [(fileType === null || fileType === void 0 ? void 0 : fileType.includes('/')) ? fileType === null || fileType === void 0 ? void 0 : fileType.split('/')[1].toUpperCase() : fileType, (file === null || file === void 0 ? void 0 : file.size) ? " \u00B7 ".concat(((file === null || file === void 0 ? void 0 : file.size) / 1024).toFixed(1), " KB") : ''] })] })] }, index || Math.random()));
|
|
51
|
+
};
|
|
52
|
+
return (_jsx("div", { style: containerStyle, onClick: openFile, children: renderContent() }));
|
|
53
|
+
};
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVXBsb2FkRmlsZVByZXZpZXcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy9jb21tb24vVXBsb2FkRmlsZVByZXZpZXcudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFFQSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFROUMsTUFBTSxDQUFDLElBQU0saUJBQWlCLEdBQXFDLFVBQUMsRUFBZTtRQUFiLElBQUksVUFBQSxFQUFFLEtBQUssV0FBQTtJQUMvRSxJQUFNLFFBQVEsR0FBRyxJQUFJLGFBQUosSUFBSSx1QkFBSixJQUFJLENBQUUsSUFBSSxDQUFDO0lBQzVCLGtEQUFrRDtJQUdsRCxJQUFNLGNBQWMsR0FBd0I7UUFDMUMsTUFBTSxFQUFFLFNBQVM7S0FDbEIsQ0FBQztJQUVGLElBQU0sWUFBWSxHQUF3QjtRQUN4QyxPQUFPLEVBQUUsTUFBTTtRQUNmLFVBQVUsRUFBRSxRQUFRO1FBQ3BCLE9BQU8sRUFBRSxLQUFLO1FBQ2QsZUFBZSxFQUFFLFNBQVM7UUFDMUIsWUFBWSxFQUFFLEtBQUs7UUFDbkIsUUFBUSxFQUFFLFVBQVU7UUFDcEIsUUFBUSxFQUFFLE9BQU87S0FDbEIsQ0FBQztJQUVGLElBQU0sVUFBVSxHQUF3QjtRQUN0QyxLQUFLLEVBQUUsTUFBTTtRQUNiLE1BQU0sRUFBRSxNQUFNO1FBQ2QsWUFBWSxFQUFFLEtBQUs7UUFDbkIsU0FBUyxFQUFFLE9BQU87UUFDbEIsV0FBVyxFQUFFLE1BQU07S0FDcEIsQ0FBQztJQUVGLElBQU0sYUFBYSxHQUF3QjtRQUN6QyxLQUFLLEVBQUUsS0FBSztRQUNaLFFBQVEsRUFBRSxPQUFPO1FBQ2pCLFVBQVUsRUFBRSxNQUFNO1FBQ2xCLFFBQVEsRUFBRSxNQUFNO1FBQ2hCLFFBQVEsRUFBRSxRQUFRO1FBQ2xCLFlBQVksRUFBRSxVQUFVO1FBQ3hCLFVBQVUsRUFBRSxRQUFRO0tBQ3JCLENBQUM7SUFFRixJQUFNLGFBQWEsR0FBd0I7UUFDekMsUUFBUSxFQUFFLE1BQU07UUFDaEIsS0FBSyxFQUFFLE1BQU07S0FDZCxDQUFDO0lBRUYsSUFBTSxhQUFhLEdBQXdCO1FBQ3pDLEtBQUssRUFBRSxFQUFFO1FBQ1QsTUFBTSxFQUFFLEVBQUU7UUFDVixPQUFPLEVBQUUsTUFBTTtRQUNmLFVBQVUsRUFBRSxRQUFRO1FBQ3BCLGNBQWMsRUFBRSxRQUFRO0tBQ3pCLENBQUM7SUFFRixJQUFNLFFBQVEsR0FBRztRQUNmLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxhQUFKLElBQUksdUJBQUosSUFBSSxDQUFFLEdBQUcsRUFBRSxRQUFRLENBQUMsQ0FBQztJQUNuQyxDQUFDLENBQUM7SUFFRixJQUFNLGFBQWEsR0FBRztRQUNwQixPQUFPLENBQ1AsZUFFSSxLQUFLLEVBQUUsWUFBWSxhQUVsQixDQUFBLFFBQVEsYUFBUixRQUFRLHVCQUFSLFFBQVEsQ0FBRSxVQUFVLENBQUMsUUFBUSxDQUFDLEVBQUMsQ0FBQyxDQUFDLENBQ2xDLGNBQ0ksR0FBRyxFQUFFLElBQUksYUFBSixJQUFJLHVCQUFKLElBQUksQ0FBRSxHQUFHLEVBQ2QsR0FBRyxFQUFFLElBQUksYUFBSixJQUFJLHVCQUFKLElBQUksQ0FBRSxJQUFJLEVBQ2YsS0FBSyxFQUFFLFVBQVUsR0FDbkIsQ0FDRCxDQUFDLENBQUMsQ0FBQyxDQUNGLGNBQUssS0FBSyxFQUFFLGFBQWEsWUFDcEIsV0FBVyxDQUFDLFFBQVEsSUFBSSxFQUFFLENBQUMsR0FDMUIsQ0FDUCxFQUNELGVBQUssS0FBSyxFQUFFLEVBQUUsT0FBTyxFQUFFLE1BQU0sRUFBRSxhQUFhLEVBQUUsUUFBUSxFQUFFLGFBQ3hELGNBQUssS0FBSyxFQUFFLGFBQWEsRUFBRSxLQUFLLEVBQUUsSUFBSSxhQUFKLElBQUksdUJBQUosSUFBSSxDQUFFLElBQUksWUFBRyxJQUFJLGFBQUosSUFBSSx1QkFBSixJQUFJLENBQUUsSUFBSSxHQUFPLEVBQ2hFLGVBQUssS0FBSyxFQUFFLGFBQWEsYUFDcEIsQ0FBQSxRQUFRLGFBQVIsUUFBUSx1QkFBUixRQUFRLENBQUUsUUFBUSxDQUFDLEdBQUcsQ0FBQyxFQUFDLENBQUMsQ0FBQyxRQUFRLGFBQVIsUUFBUSx1QkFBUixRQUFRLENBQUUsS0FBSyxDQUFDLEdBQUcsRUFBRSxDQUFDLEVBQUUsV0FBVyxFQUFFLENBQUMsQ0FBQyxDQUFDLFFBQVEsRUFDMUUsQ0FBQSxJQUFJLGFBQUosSUFBSSx1QkFBSixJQUFJLENBQUUsSUFBSSxFQUFDLENBQUMsQ0FBQyxrQkFBTSxDQUFDLENBQUEsSUFBSSxhQUFKLElBQUksdUJBQUosSUFBSSxDQUFFLElBQUksSUFBRyxJQUFJLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLFFBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUMxRCxJQUNBLEtBcEJELEtBQUssSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFLENBcUJ6QixDQUNMLENBQUM7SUFDSixDQUFDLENBQUM7SUFFRixPQUFPLENBQ0wsY0FBSyxLQUFLLEVBQUUsY0FBYyxFQUFFLE9BQU8sRUFBRSxRQUFRLFlBQzFDLGFBQWEsRUFBRSxHQUNaLENBQ1AsQ0FBQztBQUNKLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBTcGlubmVyIH0gZnJvbSAnLi4vU3Bpbm5lcic7XG5pbXBvcnQgeyBnZXRGaWxlSWNvbiB9IGZyb20gJy4uL0ZpbGVUeXBlSWNvbic7XG5pbXBvcnQgeyBBdHRhY2htZW50IH0gZnJvbSAnLi4vLi4vdHlwZXMnO1xuXG5pbnRlcmZhY2UgVXBsb2FkRmlsZVByZXZpZXdQcm9wcyB7XG4gIGZpbGU/OiBBdHRhY2htZW50O1xuICBpbmRleD86IG51bWJlcjtcbn1cblxuZXhwb3J0IGNvbnN0IFVwbG9hZEZpbGVQcmV2aWV3OiBSZWFjdC5GQzxVcGxvYWRGaWxlUHJldmlld1Byb3BzPiA9ICh7IGZpbGUsIGluZGV4IH0pID0+IHtcbiAgY29uc3QgZmlsZVR5cGUgPSBmaWxlPy50eXBlO1xuICAvLyBjb25zdCBiYXNlVXJsID0gcHJvY2Vzcy5lbnYuUkVBQ1RfQVBQX0JBU0VfVVJMO1xuXG5cbiAgY29uc3QgY29udGFpbmVyU3R5bGU6IFJlYWN0LkNTU1Byb3BlcnRpZXMgPSB7XG4gICAgY3Vyc29yOiAncG9pbnRlcicsXG4gIH07XG5cbiAgY29uc3QgY29udGVudFN0eWxlOiBSZWFjdC5DU1NQcm9wZXJ0aWVzID0ge1xuICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICBwYWRkaW5nOiAnOHB4JyxcbiAgICBiYWNrZ3JvdW5kQ29sb3I6ICcjZjBmMGYwJyxcbiAgICBib3JkZXJSYWRpdXM6ICc4cHgnLFxuICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgIG1heFdpZHRoOiAnMjUwcHgnLFxuICB9O1xuXG4gIGNvbnN0IGltYWdlU3R5bGU6IFJlYWN0LkNTU1Byb3BlcnRpZXMgPSB7XG4gICAgd2lkdGg6ICc0MHB4JyxcbiAgICBoZWlnaHQ6ICc0MHB4JyxcbiAgICBib3JkZXJSYWRpdXM6ICc0cHgnLFxuICAgIG9iamVjdEZpdDogJ2NvdmVyJyxcbiAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICB9O1xuXG4gIGNvbnN0IGZpbGVOYW1lU3R5bGU6IFJlYWN0LkNTU1Byb3BlcnRpZXMgPSB7XG4gICAgd2lkdGg6ICc5MCUnLFxuICAgIG1heFdpZHRoOiAnMTUwcHgnLFxuICAgIGZvbnRXZWlnaHQ6ICdib2xkJyxcbiAgICBmb250U2l6ZTogJzE0cHgnLFxuICAgIG92ZXJmbG93OiAnaGlkZGVuJyxcbiAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgd2hpdGVTcGFjZTogJ25vd3JhcCcsXG4gIH07XG5cbiAgY29uc3QgZmlsZVNpemVTdHlsZTogUmVhY3QuQ1NTUHJvcGVydGllcyA9IHtcbiAgICBmb250U2l6ZTogJzEycHgnLFxuICAgIGNvbG9yOiAnIzY2NicsXG4gIH07XG5cbiAgY29uc3QgZmlsZUljb25TdHlsZTogUmVhY3QuQ1NTUHJvcGVydGllcyA9IHtcbiAgICB3aWR0aDogNDAsXG4gICAgaGVpZ2h0OiA0MCxcbiAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAganVzdGlmeUNvbnRlbnQ6ICdjZW50ZXInLFxuICB9O1xuXG4gIGNvbnN0IG9wZW5GaWxlID0gKCkgPT4ge1xuICAgIHdpbmRvdy5vcGVuKGZpbGU/LnVybCwgJ19ibGFuaycpO1xuICB9O1xuXG4gIGNvbnN0IHJlbmRlckNvbnRlbnQgPSAoKSA9PiB7XG4gICAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICAgIGtleT17aW5kZXggfHwgTWF0aC5yYW5kb20oKX1cbiAgICAgICAgc3R5bGU9e2NvbnRlbnRTdHlsZX1cbiAgICA+XG4gICAgICAgIHtmaWxlVHlwZT8uc3RhcnRzV2l0aCgnaW1hZ2UvJykgPyAoXG4gICAgICAgIDxpbWdcbiAgICAgICAgICAgIHNyYz17ZmlsZT8udXJsfVxuICAgICAgICAgICAgYWx0PXtmaWxlPy5uYW1lfVxuICAgICAgICAgICAgc3R5bGU9e2ltYWdlU3R5bGV9XG4gICAgICAgIC8+XG4gICAgICAgICkgOiAoXG4gICAgICAgICAgPGRpdiBzdHlsZT17ZmlsZUljb25TdHlsZX0+XG4gICAgICAgICAgICAgIHtnZXRGaWxlSWNvbihmaWxlVHlwZSB8fCAnJyl9XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgICl9XG4gICAgICAgIDxkaXYgc3R5bGU9e3sgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAnY29sdW1uJyB9fT5cbiAgICAgICAgPGRpdiBzdHlsZT17ZmlsZU5hbWVTdHlsZX0gdGl0bGU9e2ZpbGU/Lm5hbWV9PntmaWxlPy5uYW1lfTwvZGl2PlxuICAgICAgICA8ZGl2IHN0eWxlPXtmaWxlU2l6ZVN0eWxlfT5cbiAgICAgICAgICAgIHtmaWxlVHlwZT8uaW5jbHVkZXMoJy8nKSA/IGZpbGVUeXBlPy5zcGxpdCgnLycpWzFdLnRvVXBwZXJDYXNlKCkgOiBmaWxlVHlwZX1cbiAgICAgICAgICAgIHtmaWxlPy5zaXplID8gYCDCtyAkeyhmaWxlPy5zaXplIC8gMTAyNCkudG9GaXhlZCgxKX0gS0JgIDogJyd9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICApO1xuICB9O1xuXG4gIHJldHVybiAoXG4gICAgPGRpdiBzdHlsZT17Y29udGFpbmVyU3R5bGV9IG9uQ2xpY2s9e29wZW5GaWxlfT5cbiAgICAgIHtyZW5kZXJDb250ZW50KCl9XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG4iXX0=
|
package/dist/hooks/useChat.d.ts
CHANGED
|
@@ -4,12 +4,13 @@ export interface UseChatProps {
|
|
|
4
4
|
apiKey: string;
|
|
5
5
|
tenant?: string | undefined;
|
|
6
6
|
metadata?: Record<string, any>;
|
|
7
|
+
useWs?: boolean;
|
|
7
8
|
language?: string;
|
|
8
9
|
onError?: (error: Error) => void;
|
|
9
10
|
onTakeover?: () => void;
|
|
10
11
|
onFinalize?: () => void;
|
|
11
12
|
}
|
|
12
|
-
export declare const useChat: ({ baseUrl, apiKey, tenant, metadata, language, onError, onTakeover, onFinalize }: UseChatProps) => {
|
|
13
|
+
export declare const useChat: ({ baseUrl, apiKey, tenant, metadata, useWs, language, onError, onTakeover, onFinalize }: UseChatProps) => {
|
|
13
14
|
messages: ChatMessage[];
|
|
14
15
|
isLoading: boolean;
|
|
15
16
|
sendMessage: (text: string, files?: File[], extraMetadata?: Record<string, any>, reCaptchaToken?: string) => Promise<void>;
|
package/dist/hooks/useChat.js
CHANGED
|
@@ -57,22 +57,22 @@ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
|
57
57
|
import { useState, useEffect, useCallback, useRef, useMemo } from 'react';
|
|
58
58
|
import { ChatService } from '../services/chatService';
|
|
59
59
|
export var useChat = function (_a) {
|
|
60
|
-
var baseUrl = _a.baseUrl, apiKey = _a.apiKey, tenant = _a.tenant, metadata = _a.metadata, language = _a.language, onError = _a.onError, onTakeover = _a.onTakeover, onFinalize = _a.onFinalize;
|
|
61
|
-
var
|
|
62
|
-
var
|
|
63
|
-
var
|
|
64
|
-
var
|
|
65
|
-
var
|
|
60
|
+
var baseUrl = _a.baseUrl, apiKey = _a.apiKey, tenant = _a.tenant, metadata = _a.metadata, _b = _a.useWs, useWs = _b === void 0 ? true : _b, language = _a.language, onError = _a.onError, onTakeover = _a.onTakeover, onFinalize = _a.onFinalize;
|
|
61
|
+
var _c = useState([]), messages = _c[0], setMessages = _c[1];
|
|
62
|
+
var _d = useState(false), isLoading = _d[0], setIsLoading = _d[1];
|
|
63
|
+
var _e = useState([]), preloadedAttachments = _e[0], setPreloadedAttachments = _e[1];
|
|
64
|
+
var _f = useState('disconnected'), connectionState = _f[0], setConnectionState = _f[1];
|
|
65
|
+
var _g = useState(false), isAgentTyping = _g[0], setIsAgentTyping = _g[1];
|
|
66
66
|
var chatServiceRef = useRef(null);
|
|
67
|
-
var
|
|
68
|
-
var
|
|
69
|
-
var
|
|
70
|
-
var
|
|
71
|
-
var
|
|
72
|
-
var
|
|
73
|
-
var
|
|
74
|
-
var
|
|
75
|
-
var
|
|
67
|
+
var _h = useState(null), conversationId = _h[0], setConversationId = _h[1];
|
|
68
|
+
var _j = useState([]), possibleQueries = _j[0], setPossibleQueries = _j[1];
|
|
69
|
+
var _k = useState(null), welcomeTitle = _k[0], setWelcomeTitle = _k[1];
|
|
70
|
+
var _l = useState(null), welcomeImageUrl = _l[0], setWelcomeImageUrl = _l[1];
|
|
71
|
+
var _m = useState(null), welcomeMessage = _m[0], setWelcomeMessage = _m[1];
|
|
72
|
+
var _o = useState([]), thinkingPhrases = _o[0], setThinkingPhrases = _o[1];
|
|
73
|
+
var _p = useState(1000), thinkingDelayMs = _p[0], setThinkingDelayMs = _p[1];
|
|
74
|
+
var _q = useState(false), isTakenOver = _q[0], setIsTakenOver = _q[1];
|
|
75
|
+
var _r = useState(false), isFinalized = _r[0], setIsFinalized = _r[1];
|
|
76
76
|
// Scoped messages key for apiKey, conversatioId
|
|
77
77
|
var buildMessagesKey = useCallback(function (apiKeyVal, convId) {
|
|
78
78
|
if (!convId)
|
|
@@ -86,6 +86,7 @@ export var useChat = function (_a) {
|
|
|
86
86
|
var prevBaseUrlRef = useRef(baseUrl);
|
|
87
87
|
var prevApiKeyRef = useRef(apiKey);
|
|
88
88
|
var prevTenantRef = useRef(tenant);
|
|
89
|
+
var prevUseWsRef = useRef(useWs);
|
|
89
90
|
// Store callbacks in refs so they don't trigger re-initialization
|
|
90
91
|
var onErrorRef = useRef(onError);
|
|
91
92
|
var onTakeoverRef = useRef(onTakeover);
|
|
@@ -100,15 +101,16 @@ export var useChat = function (_a) {
|
|
|
100
101
|
useEffect(function () {
|
|
101
102
|
onFinalizeRef.current = onFinalize;
|
|
102
103
|
}, [onFinalize]);
|
|
103
|
-
// Initialize chat service - only when baseUrl, apiKey, tenant, or metadata actually change
|
|
104
|
+
// Initialize chat service - only when baseUrl, apiKey, tenant, useWs, or metadata actually change
|
|
104
105
|
useEffect(function () {
|
|
105
106
|
var _a, _b, _c, _d, _e, _f;
|
|
106
107
|
var metadataChanged = metadataRef.current !== metadataString;
|
|
107
108
|
var baseUrlChanged = prevBaseUrlRef.current !== baseUrl;
|
|
108
109
|
var apiKeyChanged = prevApiKeyRef.current !== apiKey;
|
|
109
110
|
var tenantChanged = prevTenantRef.current !== tenant;
|
|
111
|
+
var useWsChanged = prevUseWsRef.current !== useWs;
|
|
110
112
|
// Only re-initialize for connection-related changes, NOT for metadata changes
|
|
111
|
-
var needsReinit = !chatServiceRef.current || baseUrlChanged || apiKeyChanged || tenantChanged;
|
|
113
|
+
var needsReinit = !chatServiceRef.current || baseUrlChanged || apiKeyChanged || tenantChanged || useWsChanged;
|
|
112
114
|
if (needsReinit) {
|
|
113
115
|
// Update refs
|
|
114
116
|
if (baseUrlChanged)
|
|
@@ -117,6 +119,8 @@ export var useChat = function (_a) {
|
|
|
117
119
|
prevApiKeyRef.current = apiKey;
|
|
118
120
|
if (tenantChanged)
|
|
119
121
|
prevTenantRef.current = tenant;
|
|
122
|
+
if (useWsChanged)
|
|
123
|
+
prevUseWsRef.current = useWs;
|
|
120
124
|
if (metadataChanged)
|
|
121
125
|
metadataRef.current = metadataString;
|
|
122
126
|
// Clean up existing service if it exists
|
|
@@ -124,7 +128,7 @@ export var useChat = function (_a) {
|
|
|
124
128
|
chatServiceRef.current.disconnect();
|
|
125
129
|
chatServiceRef.current.setWelcomeDataHandler(null);
|
|
126
130
|
}
|
|
127
|
-
chatServiceRef.current = new ChatService(baseUrl, apiKey, metadata, tenant, language);
|
|
131
|
+
chatServiceRef.current = new ChatService(baseUrl, apiKey, metadata, tenant, language, useWs);
|
|
128
132
|
// Set up handlers
|
|
129
133
|
chatServiceRef.current.setMessageHandler(function (message) {
|
|
130
134
|
var normalizedMessage = __assign(__assign({}, message), { create_time: (!message.create_time || isNaN(message.create_time))
|
|
@@ -222,7 +226,7 @@ export var useChat = function (_a) {
|
|
|
222
226
|
return function () {
|
|
223
227
|
// Only cleanup on unmount, not on every dependency change
|
|
224
228
|
};
|
|
225
|
-
}, [baseUrl, apiKey, tenant, metadataString, language]);
|
|
229
|
+
}, [baseUrl, apiKey, tenant, metadataString, language, useWs]);
|
|
226
230
|
// Update language when it changes (without re-initializing the service)
|
|
227
231
|
useEffect(function () {
|
|
228
232
|
if (chatServiceRef.current) {
|
|
@@ -330,29 +334,33 @@ export var useChat = function (_a) {
|
|
|
330
334
|
});
|
|
331
335
|
}); }, []);
|
|
332
336
|
var uploadFile = useCallback(function (file) { return __awaiter(void 0, void 0, void 0, function () {
|
|
333
|
-
var
|
|
334
|
-
|
|
335
|
-
|
|
337
|
+
var conversationId, uploadResult, file_url, attachment_1, error_2;
|
|
338
|
+
var _a, _b;
|
|
339
|
+
return __generator(this, function (_c) {
|
|
340
|
+
switch (_c.label) {
|
|
336
341
|
case 0:
|
|
337
|
-
|
|
342
|
+
conversationId = (_a = chatServiceRef.current) === null || _a === void 0 ? void 0 : _a.getConversationId();
|
|
343
|
+
if (!conversationId) {
|
|
338
344
|
return [2 /*return*/, null];
|
|
339
345
|
}
|
|
340
|
-
|
|
346
|
+
_c.label = 1;
|
|
341
347
|
case 1:
|
|
342
|
-
|
|
343
|
-
return [4 /*yield*/, chatServiceRef.current.uploadFile(
|
|
348
|
+
_c.trys.push([1, 3, , 4]);
|
|
349
|
+
return [4 /*yield*/, ((_b = chatServiceRef.current) === null || _b === void 0 ? void 0 : _b.uploadFile(conversationId, file))];
|
|
344
350
|
case 2:
|
|
345
|
-
|
|
351
|
+
uploadResult = _c.sent();
|
|
352
|
+
file_url = new URL(uploadResult.file_url, baseUrl).href;
|
|
346
353
|
attachment_1 = {
|
|
347
354
|
name: file.name,
|
|
348
355
|
type: file.type,
|
|
349
356
|
size: file.size,
|
|
350
|
-
url:
|
|
357
|
+
url: file_url,
|
|
358
|
+
file_id: uploadResult === null || uploadResult === void 0 ? void 0 : uploadResult.file_id,
|
|
351
359
|
};
|
|
352
360
|
setPreloadedAttachments(function (prev) { return __spreadArray(__spreadArray([], prev, true), [attachment_1], false); });
|
|
353
361
|
return [2 /*return*/, attachment_1];
|
|
354
362
|
case 3:
|
|
355
|
-
error_2 =
|
|
363
|
+
error_2 = _c.sent();
|
|
356
364
|
if (onErrorRef.current) {
|
|
357
365
|
onErrorRef.current(error_2);
|
|
358
366
|
}
|
|
@@ -542,4 +550,4 @@ export var useChat = function (_a) {
|
|
|
542
550
|
thinkingDelayMs: thinkingDelayMs,
|
|
543
551
|
};
|
|
544
552
|
};
|
|
545
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"useChat.js","sourceRoot":"","sources":["../../src/hooks/useChat.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAC1E,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AActD,MAAM,CAAC,IAAM,OAAO,GAAG,UAAC,EAA8F;QAA5F,OAAO,aAAA,EAAE,MAAM,YAAA,EAAE,MAAM,YAAA,EAAE,QAAQ,cAAA,EAAE,QAAQ,cAAA,EAAE,OAAO,aAAA,EAAE,UAAU,gBAAA,EAAE,UAAU,gBAAA;IAC9F,IAAA,KAA0B,QAAQ,CAAgB,EAAE,CAAC,EAApD,QAAQ,QAAA,EAAE,WAAW,QAA+B,CAAC;IACtD,IAAA,KAA4B,QAAQ,CAAU,KAAK,CAAC,EAAnD,SAAS,QAAA,EAAE,YAAY,QAA4B,CAAC;IACrD,IAAA,KAAkD,QAAQ,CAAe,EAAE,CAAC,EAA3E,oBAAoB,QAAA,EAAE,uBAAuB,QAA8B,CAAC;IAC7E,IAAA,KAAwC,QAAQ,CAA8C,cAAc,CAAC,EAA5G,eAAe,QAAA,EAAE,kBAAkB,QAAyE,CAAC;IAC9G,IAAA,KAAoC,QAAQ,CAAU,KAAK,CAAC,EAA3D,aAAa,QAAA,EAAE,gBAAgB,QAA4B,CAAC;IACnE,IAAM,cAAc,GAAG,MAAM,CAAqB,IAAI,CAAC,CAAC;IAClD,IAAA,KAAsC,QAAQ,CAAgB,IAAI,CAAC,EAAlE,cAAc,QAAA,EAAE,iBAAiB,QAAiC,CAAC;IACpE,IAAA,KAAwC,QAAQ,CAAW,EAAE,CAAC,EAA7D,eAAe,QAAA,EAAE,kBAAkB,QAA0B,CAAC;IAC/D,IAAA,KAAkC,QAAQ,CAAgB,IAAI,CAAC,EAA9D,YAAY,QAAA,EAAE,eAAe,QAAiC,CAAC;IAChE,IAAA,KAAwC,QAAQ,CAAgB,IAAI,CAAC,EAApE,eAAe,QAAA,EAAE,kBAAkB,QAAiC,CAAC;IACtE,IAAA,KAAsC,QAAQ,CAAgB,IAAI,CAAC,EAAlE,cAAc,QAAA,EAAE,iBAAiB,QAAiC,CAAC;IACpE,IAAA,KAAwC,QAAQ,CAAW,EAAE,CAAC,EAA7D,eAAe,QAAA,EAAE,kBAAkB,QAA0B,CAAC;IAC/D,IAAA,KAAwC,QAAQ,CAAS,IAAI,CAAC,EAA7D,eAAe,QAAA,EAAE,kBAAkB,QAA0B,CAAC;IAC/D,IAAA,KAAgC,QAAQ,CAAU,KAAK,CAAC,EAAvD,WAAW,QAAA,EAAE,cAAc,QAA4B,CAAC;IACzD,IAAA,KAAgC,QAAQ,CAAU,KAAK,CAAC,EAAvD,WAAW,QAAA,EAAE,cAAc,QAA4B,CAAC;IAE/D,gDAAgD;IAChD,IAAM,gBAAgB,GAAG,WAAW,CAAC,UAAC,SAAiB,EAAE,MAAqB;QAC5E,IAAI,CAAC,MAAM;YAAE,OAAO,IAAI,CAAC;QACzB,OAAO,0CAAmC,SAAS,cAAI,MAAM,CAAE,CAAC;IAClE,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,kEAAkE;IAClE,4EAA4E;IAC5E,IAAM,cAAc,GAAG,OAAO,CAAC,cAAM,OAAA,IAAI,CAAC,SAAS,CAAC,QAAQ,IAAI,EAAE,CAAC,EAA9B,CAA8B,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;IACjF,IAAM,WAAW,GAAG,MAAM,CAAS,cAAc,CAAC,CAAC;IACnD,IAAM,cAAc,GAAG,MAAM,CAAS,OAAO,CAAC,CAAC;IAC/C,IAAM,aAAa,GAAG,MAAM,CAAS,MAAM,CAAC,CAAC;IAC7C,IAAM,aAAa,GAAG,MAAM,CAAqB,MAAM,CAAC,CAAC;IAEzD,kEAAkE;IAClE,IAAM,UAAU,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC;IACnC,IAAM,aAAa,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IACzC,IAAM,aAAa,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IAEzC,wCAAwC;IACxC,SAAS,CAAC;QACR,UAAU,CAAC,OAAO,GAAG,OAAO,CAAC;IAC/B,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;IAEd,SAAS,CAAC;QACR,aAAa,CAAC,OAAO,GAAG,UAAU,CAAC;IACrC,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;IAEjB,SAAS,CAAC;QACR,aAAa,CAAC,OAAO,GAAG,UAAU,CAAC;IACrC,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;IAEjB,2FAA2F;IAC3F,SAAS,CAAC;;QACR,IAAM,eAAe,GAAG,WAAW,CAAC,OAAO,KAAK,cAAc,CAAC;QAC/D,IAAM,cAAc,GAAG,cAAc,CAAC,OAAO,KAAK,OAAO,CAAC;QAC1D,IAAM,aAAa,GAAG,aAAa,CAAC,OAAO,KAAK,MAAM,CAAC;QACvD,IAAM,aAAa,GAAG,aAAa,CAAC,OAAO,KAAK,MAAM,CAAC;QAEvD,8EAA8E;QAC9E,IAAM,WAAW,GAAG,CAAC,cAAc,CAAC,OAAO,IAAI,cAAc,IAAI,aAAa,IAAI,aAAa,CAAC;QAEhG,IAAI,WAAW,EAAE,CAAC;YAChB,cAAc;YACd,IAAI,cAAc;gBAAE,cAAc,CAAC,OAAO,GAAG,OAAO,CAAC;YACrD,IAAI,aAAa;gBAAE,aAAa,CAAC,OAAO,GAAG,MAAM,CAAC;YAClD,IAAI,aAAa;gBAAE,aAAa,CAAC,OAAO,GAAG,MAAM,CAAC;YAClD,IAAI,eAAe;gBAAE,WAAW,CAAC,OAAO,GAAG,cAAc,CAAC;YAE1D,yCAAyC;YACzC,IAAI,cAAc,CAAC,OAAO,EAAE,CAAC;gBAC3B,cAAc,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC;gBACpC,cAAc,CAAC,OAAO,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;YACrD,CAAC;YAED,cAAc,CAAC,OAAO,GAAG,IAAI,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;YAEtF,kBAAkB;YAClB,cAAc,CAAC,OAAO,CAAC,iBAAiB,CAAC,UAAC,OAAoB;gBAC5D,IAAM,iBAAiB,yBAClB,OAAO,KACV,WAAW,EAAE,CAAC,CAAC,OAAO,CAAC,WAAW,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;wBAC/D,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC;wBAC/B,CAAC,CAAC,OAAO,CAAC,WAAW,GACxB,CAAC;gBAEF,WAAW,CAAC,UAAA,YAAY,IAAI,uCAAI,YAAY,UAAE,iBAAiB,WAAnC,CAAoC,CAAC,CAAC;gBAClE,6DAA6D;gBAC7D,IAAI,iBAAiB,CAAC,OAAO,KAAK,OAAO,IAAI,iBAAiB,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;oBACrF,gBAAgB,CAAC,KAAK,CAAC,CAAC;gBAC1B,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,cAAc,CAAC,OAAO,CAAC,kBAAkB,CAAC;gBACxC,cAAc,CAAC,IAAI,CAAC,CAAC;gBACrB,gBAAgB,CAAC,KAAK,CAAC,CAAC;gBACxB,IAAI,aAAa,CAAC,OAAO,EAAE,CAAC;oBAC1B,aAAa,CAAC,OAAO,EAAE,CAAC;gBAC1B,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,cAAc,CAAC,OAAO,CAAC,mBAAmB,CAAC;gBACzC,cAAc,CAAC,IAAI,CAAC,CAAC;gBACrB,gBAAgB,CAAC,KAAK,CAAC,CAAC;gBACxB,IAAI,aAAa,CAAC,OAAO,EAAE,CAAC;oBAC1B,aAAa,CAAC,OAAO,EAAE,CAAC;gBAC1B,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,cAAc,CAAC,OAAO,CAAC,yBAAyB,CAAC,UAAC,KAAK;gBACrD,kBAAkB,CAAC,KAAK,CAAC,CAAC;gBAC1B,IAAI,KAAK,KAAK,WAAW,EAAE,CAAC;oBAC1B,gBAAgB,CAAC,KAAK,CAAC,CAAC;gBAC1B,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,cAAc,CAAC,OAAO,CAAC,qBAAqB,CAAC,UAAC,IAAI;;gBAChD,eAAe,CAAC,MAAA,IAAI,CAAC,KAAK,mCAAI,IAAI,CAAC,CAAC;gBACpC,kBAAkB,CAAC,MAAA,IAAI,CAAC,QAAQ,mCAAI,IAAI,CAAC,CAAC;gBAC1C,iBAAiB,CAAC,MAAA,IAAI,CAAC,OAAO,mCAAI,IAAI,CAAC,CAAC;gBACxC,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBAC5D,kBAAkB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;gBAC3C,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,mDAAmD;YACnD,IAAM,MAAM,GAAG,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;YAC1D,IAAI,MAAM,EAAE,CAAC;gBACX,iBAAiB,CAAC,MAAM,CAAC,CAAC;gBAC1B,IAAI,cAAc,CAAC,OAAO,CAAC,uBAAuB,EAAE,EAAE,CAAC;oBACrD,cAAc,CAAC,IAAI,CAAC,CAAC;gBACvB,CAAC;qBAAM,CAAC;oBACN,cAAc,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC;gBAC5C,CAAC;YACH,CAAC;YACD,2BAA2B;YAC3B,IAAI,cAAc,CAAC,OAAO,EAAE,CAAC;gBAC3B,IAAM,OAAO,GAAG,CAAA,MAAA,MAAA,cAAc,CAAC,OAAO,EAAC,kBAAkB,kDAAI,KAAI,EAAE,CAAC;gBACpE,IAAI,OAAO,CAAC,MAAM;oBAAE,kBAAkB,CAAC,OAAO,CAAC,CAAC;gBAChD,IAAM,OAAO,GAAG,MAAA,MAAA,cAAc,CAAC,OAAO,EAAC,cAAc,kDAAI,CAAC;gBAC1D,IAAI,OAAO,EAAE,CAAC;oBACZ,eAAe,CAAC,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC;oBACvC,kBAAkB,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC;oBAC7C,iBAAiB,CAAC,OAAO,CAAC,OAAO,IAAI,IAAI,CAAC,CAAC;gBAC7C,CAAC;gBACD,IAAM,QAAQ,GAAG,MAAA,MAAA,cAAc,CAAC,OAAO,EAAC,iBAAiB,kDAAI,CAAC;gBAC9D,IAAI,QAAQ,EAAE,CAAC;oBACb,kBAAkB,CAAC,QAAQ,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC;oBAC3C,kBAAkB,CAAC,QAAQ,CAAC,OAAO,IAAI,IAAI,CAAC,CAAC;gBAC/C,CAAC;YACH,CAAC;QACH,CAAC;aAAM,IAAI,cAAc,CAAC,OAAO,EAAE,CAAC;YAClC,+CAA+C;YAC/C,IAAI,eAAe,EAAE,CAAC;gBACpB,WAAW,CAAC,OAAO,GAAG,cAAc,CAAC;gBACrC,cAAc,CAAC,OAAO,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;YAC/C,CAAC;QACH,CAAC;QAED,yEAAyE;QACzE,IAAI,cAAc,CAAC,OAAO,EAAE,CAAC;YAC3B,cAAc,CAAC,OAAO,CAAC,kBAAkB,CAAC;gBACxC,cAAc,CAAC,IAAI,CAAC,CAAC;gBACrB,gBAAgB,CAAC,KAAK,CAAC,CAAC;gBACxB,IAAI,aAAa,CAAC,OAAO,EAAE,CAAC;oBAC1B,aAAa,CAAC,OAAO,EAAE,CAAC;gBAC1B,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,cAAc,CAAC,OAAO,CAAC,mBAAmB,CAAC;gBACzC,cAAc,CAAC,IAAI,CAAC,CAAC;gBACrB,gBAAgB,CAAC,KAAK,CAAC,CAAC;gBACxB,IAAI,aAAa,CAAC,OAAO,EAAE,CAAC;oBAC1B,aAAa,CAAC,OAAO,EAAE,CAAC;gBAC1B,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC;QAED,0BAA0B;QAC1B,OAAO;YACL,0DAA0D;QAC5D,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,cAAc,EAAE,QAAQ,CAAC,CAAC,CAAC;IAExD,wEAAwE;IACxE,SAAS,CAAC;QACR,IAAI,cAAc,CAAC,OAAO,EAAE,CAAC;YAC3B,cAAc,CAAC,OAAO,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;QAC/C,CAAC;IACH,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;IAEf,gDAAgD;IAChD,SAAS,CAAC;QACR,IAAM,GAAG,GAAG,gBAAgB,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;QACrD,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,WAAW,CAAC,EAAE,CAAC,CAAC;YAChB,OAAO;QACT,CAAC;QACD,IAAI,CAAC;YACH,IAAM,MAAM,GAAG,YAAY,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;YACzC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAChD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,WAAW,CAAC,EAAE,CAAC,CAAC;QAClB,CAAC;IACH,CAAC,EAAE,CAAC,MAAM,EAAE,cAAc,EAAE,gBAAgB,CAAC,CAAC,CAAC;IAE/C,oCAAoC;IACpC,SAAS,CAAC;QACR,IAAM,GAAG,GAAG,gBAAgB,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;QACrD,IAAI,CAAC,GAAG;YAAE,OAAO;QACjB,IAAI,CAAC;YACH,YAAY,CAAC,OAAO,CAAC,GAAG,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;QACtD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,SAAS;QACX,CAAC;IACH,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,cAAc,EAAE,gBAAgB,CAAC,CAAC,CAAC;IAEzD,qBAAqB;IACrB,IAAM,iBAAiB,GAAG,WAAW,CAAC,UAAO,cAAkC;;;;;oBAC7E,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;wBAC5B,sBAAO;oBACT,CAAC;oBAED,kBAAkB,CAAC,YAAY,CAAC,CAAC;oBACjC,YAAY,CAAC,IAAI,CAAC,CAAC;oBACnB,WAAW,CAAC,EAAE,CAAC,CAAC;oBAChB,kBAAkB,CAAC,EAAE,CAAC,CAAC;oBACvB,eAAe,CAAC,IAAI,CAAC,CAAC;oBACtB,kBAAkB,CAAC,IAAI,CAAC,CAAC;oBACzB,iBAAiB,CAAC,IAAI,CAAC,CAAC;oBACxB,kBAAkB,CAAC,EAAE,CAAC,CAAC;oBACvB,kBAAkB,CAAC,IAAI,CAAC,CAAC;oBACnB,GAAG,GAAG,gBAAgB,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;oBACrD,IAAI,GAAG,EAAE,CAAC;wBACR,YAAY,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;oBAC/B,CAAC;oBACD,cAAc,CAAC,KAAK,CAAC,CAAC;oBACtB,cAAc,CAAC,KAAK,CAAC,CAAC;oBACtB,gBAAgB,CAAC,KAAK,CAAC,CAAC;;;;oBAGtB,6CAA6C;oBAC7C,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;oBAG5B,qBAAM,cAAc,CAAC,OAAO,CAAC,iBAAiB,CAAC,cAAc,CAAC,EAAA;;oBAAvE,MAAM,GAAG,SAA8D;oBAC7E,iBAAiB,CAAC,MAAM,CAAC,CAAC;oBAC1B,kBAAkB,CAAC,WAAW,CAAC,CAAC;oBAEhC,yCAAyC;oBACzC,IAAI,cAAc,CAAC,OAAO,CAAC,kBAAkB,EAAE,CAAC;wBACxC,OAAO,GAAG,cAAc,CAAC,OAAO,CAAC,kBAAkB,EAAE,CAAC;wBAC5D,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;4BAClC,kBAAkB,CAAC,OAAO,CAAC,CAAC;wBAC9B,CAAC;oBACH,CAAC;oBACD,4BAA4B;oBAC5B,IAAI,cAAc,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC;wBACpC,OAAO,GAAG,cAAc,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC;wBACxD,eAAe,CAAC,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC;wBACvC,kBAAkB,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC;wBAC7C,iBAAiB,CAAC,OAAO,CAAC,OAAO,IAAI,IAAI,CAAC,CAAC;oBAC7C,CAAC;oBACD,IAAI,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;wBACvC,QAAQ,GAAG,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;wBAC5D,kBAAkB,CAAC,QAAQ,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC;wBAC3C,kBAAkB,CAAC,QAAQ,CAAC,OAAO,IAAI,IAAI,CAAC,CAAC;oBAC/C,CAAC;;;;oBAED,kBAAkB,CAAC,cAAc,CAAC,CAAC;oBACnC,gBAAgB,CAAC,KAAK,CAAC,CAAC;oBACxB,IAAI,UAAU,CAAC,OAAO,IAAI,OAAK,YAAY,KAAK,EAAE,CAAC;wBACjD,UAAU,CAAC,OAAO,CAAC,OAAK,CAAC,CAAC;oBAC5B,CAAC;yBAAM,CAAC;wBACN,SAAS;oBACX,CAAC;;;oBAED,YAAY,CAAC,KAAK,CAAC,CAAC;;;;;SAEvB,EAAE,EAAE,CAAC,CAAC;IAEP,IAAM,UAAU,GAAG,WAAW,CAAC,UAAO,IAAU;;;;;oBAC9C,IAAI,CAAC,cAAc,CAAC,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,EAAE,CAAC;wBAC3E,sBAAO,IAAI,EAAC;oBACd,CAAC;;;;oBAGqB,qBAAM,cAAc,CAAC,OAAO,CAAC,UAAU,CACzD,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAY,EACpD,IAAI,CACL,EAAA;;oBAHO,OAAO,GAAK,CAAA,SAGnB,CAAA,QAHc;oBAKT,eAAyB;wBAC7B,IAAI,EAAE,IAAI,CAAC,IAAI;wBACf,IAAI,EAAE,IAAI,CAAC,IAAI;wBACf,IAAI,EAAE,IAAI,CAAC,IAAI;wBACf,GAAG,EAAE,OAAO;qBACb,CAAC;oBAEF,uBAAuB,CAAC,UAAA,IAAI,IAAI,uCAAI,IAAI,UAAE,YAAU,WAApB,CAAqB,CAAC,CAAC;oBACvD,sBAAO,YAAU,EAAC;;;oBAElB,IAAI,UAAU,CAAC,OAAO,EAAE,CAAC;wBACvB,UAAU,CAAC,OAAO,CAAC,OAAc,CAAC,CAAC;oBACrC,CAAC;oBACD,sBAAO,IAAI,EAAC;;;;SAEf,EAAE,EAAE,CAAC,CAAC;IAEP,eAAe;IACf,IAAM,WAAW,GAAG,WAAW,CAAC;;;;;0FAAO,IAAY,EAAE,KAAkB,EAAE,aAAmC,EAAE,cAAuB;;YAAhF,sBAAA,EAAA,UAAkB;;;;wBACrE,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;4BAC5B,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;wBAClD,CAAC;;;;wBAGC,YAAY,CAAC,IAAI,CAAC,CAAC;wBAEb,cAAc,GAAiB,EAAE,CAAC;wBAExC,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;4BACf,aAAa,GAAG,KAAK,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,oBAAoB,CAAC,IAAI,CAAC,UAAA,EAAE,IAAI,OAAA,EAAE,CAAC,IAAI,KAAK,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC,IAAI,KAAK,CAAC,CAAC,IAAI,EAAxC,CAAwC,CAAC,EAAzE,CAAyE,CAAC,CAAC,MAAM,CAAC,OAAO,CAAiB,CAAC;4BAChJ,cAAc,CAAC,IAAI,OAAnB,cAAc,EAAS,aAAa,EAAE;wBACxC,CAAC;wBAED,yFAAyF;wBACzF,IAAI,CAAC,WAAW,EAAE,CAAC;4BACjB,gBAAgB,CAAC,IAAI,CAAC,CAAC;wBACzB,CAAC;wBACD,qBAAM,cAAc,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,EAAE,cAAc,EAAE,aAAa,EAAE,cAAc,CAAC,EAAA;;wBAA7F,SAA6F,CAAC;wBAE9F,uBAAuB,CAAC,EAAE,CAAC,CAAC;;;;wBAG5B,gBAAgB,CAAC,KAAK,CAAC,CAAC;wBACxB,IAAI,UAAU,CAAC,OAAO,IAAI,OAAK,YAAY,KAAK,EAAE,CAAC;4BACjD,UAAU,CAAC,OAAO,CAAC,OAAK,CAAC,CAAC;wBAC5B,CAAC;6BAAM,CAAC;4BACN,SAAS;wBACX,CAAC;;;wBAED,YAAY,CAAC,KAAK,CAAC,CAAC;;;;;;KAEvB,EAAE,CAAC,oBAAoB,EAAE,WAAW,CAAC,CAAC,CAAC;IAExC,IAAM,iBAAiB,GAAG,WAAW,CAAC,UAAO,cAAkC;;;;;oBAC7E,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;wBAC5B,sBAAO;oBACT,CAAC;;;;oBAEC,kBAAkB,CAAC,YAAY,CAAC,CAAC;oBACjC,YAAY,CAAC,IAAI,CAAC,CAAC;oBAEnB,mCAAmC;oBACnC,WAAW,CAAC,EAAE,CAAC,CAAC;oBAChB,kBAAkB,CAAC,EAAE,CAAC,CAAC;oBACjB,GAAG,GAAG,gBAAgB,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;oBACrD,IAAI,GAAG,EAAE,CAAC;wBACR,YAAY,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;oBAC/B,CAAC;oBACD,cAAc,CAAC,KAAK,CAAC,CAAC;oBACtB,cAAc,CAAC,KAAK,CAAC,CAAC;oBACtB,gBAAgB,CAAC,KAAK,CAAC,CAAC;oBACxB,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;oBAE5B,qBAAM,cAAc,CAAC,OAAO,CAAC,iBAAiB,CAAC,cAAc,CAAC,EAAA;;oBAAvE,MAAM,GAAG,SAA8D;oBAC7E,iBAAiB,CAAC,MAAM,CAAC,CAAC;oBAC1B,kBAAkB,CAAC,WAAW,CAAC,CAAC;oBAEhC,IAAI,cAAc,CAAC,OAAO,CAAC,kBAAkB,EAAE,CAAC;wBACxC,OAAO,GAAG,cAAc,CAAC,OAAO,CAAC,kBAAkB,EAAE,CAAC;wBAC5D,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;4BAClC,kBAAkB,CAAC,OAAO,CAAC,CAAC;wBAC9B,CAAC;oBACH,CAAC;oBACD,IAAI,cAAc,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC;wBACpC,OAAO,GAAG,cAAc,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC;wBACxD,eAAe,CAAC,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC;wBACvC,kBAAkB,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC;wBAC7C,iBAAiB,CAAC,OAAO,CAAC,OAAO,IAAI,IAAI,CAAC,CAAC;oBAC7C,CAAC;oBACD,IAAI,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;wBACvC,QAAQ,GAAG,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;wBAC5D,kBAAkB,CAAC,QAAQ,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC;wBAC3C,kBAAkB,CAAC,QAAQ,CAAC,OAAO,IAAI,IAAI,CAAC,CAAC;oBAC/C,CAAC;;;;oBAED,kBAAkB,CAAC,cAAc,CAAC,CAAC;oBACnC,gBAAgB,CAAC,KAAK,CAAC,CAAC;oBACxB,IAAI,UAAU,CAAC,OAAO,IAAI,OAAK,YAAY,KAAK,EAAE,CAAC;wBACjD,UAAU,CAAC,OAAO,CAAC,OAAK,CAAC,CAAC;oBAC5B,CAAC;yBAAM,CAAC;wBACN,SAAS;oBACX,CAAC;;;oBAED,YAAY,CAAC,KAAK,CAAC,CAAC;;;;;SAEvB,EAAE,EAAE,CAAC,CAAC;IAEP,mCAAmC;IACnC,IAAM,WAAW,GAAG,WAAW,CAC7B,UAAO,SAAiB,EAAE,KAAqB,EAAE,eAAwB;;;;;oBACvE,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;wBAC5B,OAAO,CAAC,KAAK,CAAC,mDAAmD,CAAC,CAAC;wBACnE,sBAAO;oBACT,CAAC;oBACD,IAAI,CAAC,SAAS,EAAE,CAAC;wBACf,OAAO,CAAC,KAAK,CAAC,6CAA6C,CAAC,CAAC;wBAC7D,sBAAO;oBACT,CAAC;;;;oBAGC,qBAAM,cAAc,CAAC,OAAO,CAAC,WAAW,CAAC,SAAS,EAAE,KAAK,EAAE,eAAe,CAAC,EAAA;;oBAA3E,SAA2E,CAAC;oBAEtE,gBAA+B;wBACnC,QAAQ,EAAE,KAAK;wBACf,gBAAgB,EAAE,eAAe;wBACjC,kBAAkB,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;qBAC7C,CAAC;oBAEF,WAAW,CAAC,UAAA,IAAI;wBACd,OAAA,IAAI,CAAC,GAAG,CAAC,UAAA,CAAC;4BACR,kCAAkC;4BAClC,IAAM,KAAK,GAAG,CAAC,CAAC,UAAU,IAAK,CAAS,CAAC,EAAE,CAAC;4BAC5C,OAAO,KAAK,KAAK,SAAS;gCACxB,CAAC,uBAAM,CAAC,KAAE,QAAQ,kCAAM,CAAC,CAAC,CAAC,QAAQ,IAAI,EAAE,CAAC,UAAE,aAAW,aACvD,CAAC,CAAC,CAAC,CAAC;wBACR,CAAC,CAAC;oBANF,CAME,CACH,CAAC;;;;oBAEF,IAAI,UAAU,CAAC,OAAO,EAAE,CAAC;wBACvB,UAAU,CAAC,OAAO,CAAC,OAAc,CAAC,CAAC;oBACrC,CAAC;;;;;SAEJ,EACD,EAAE,CACH,CAAC;IAEF,OAAO;QACL,QAAQ,UAAA;QACR,SAAS,WAAA;QACT,WAAW,aAAA;QACX,UAAU,YAAA;QACV,iBAAiB,mBAAA;QACjB,iBAAiB,mBAAA;QACjB,eAAe,iBAAA;QACf,cAAc,gBAAA;QACd,eAAe,iBAAA;QACf,WAAW,aAAA;QACX,WAAW,aAAA;QACX,aAAa,eAAA;QACb,WAAW,aAAA;QACX,YAAY,cAAA;QACZ,eAAe,iBAAA;QACf,cAAc,gBAAA;QACd,eAAe,iBAAA;QACf,eAAe,iBAAA;KAChB,CAAC;AACJ,CAAC,CAAC","sourcesContent":["import { useState, useEffect, useCallback, useRef, useMemo } from 'react';\nimport { ChatService } from '../services/chatService';\nimport { ChatMessage, Attachment, MessageFeedback } from '../types';\n\nexport interface UseChatProps {\n  baseUrl: string;\n  apiKey: string;\n  tenant?: string | undefined;\n  metadata?: Record<string, any>;\n  language?: string;\n  onError?: (error: Error) => void;\n  onTakeover?: () => void;\n  onFinalize?: () => void;\n}\n\nexport const useChat = ({ baseUrl, apiKey, tenant, metadata, language, onError, onTakeover, onFinalize }: UseChatProps) => {\n  const [messages, setMessages] = useState<ChatMessage[]>([]);\n  const [isLoading, setIsLoading] = useState<boolean>(false);\n  const [preloadedAttachments, setPreloadedAttachments] = useState<Attachment[]>([]);\n  const [connectionState, setConnectionState] = useState<'connecting' | 'connected' | 'disconnected'>('disconnected');\n  const [isAgentTyping, setIsAgentTyping] = useState<boolean>(false);\n  const chatServiceRef = useRef<ChatService | null>(null);\n  const [conversationId, setConversationId] = useState<string | null>(null);\n  const [possibleQueries, setPossibleQueries] = useState<string[]>([]);\n  const [welcomeTitle, setWelcomeTitle] = useState<string | null>(null);\n  const [welcomeImageUrl, setWelcomeImageUrl] = useState<string | null>(null);\n  const [welcomeMessage, setWelcomeMessage] = useState<string | null>(null);\n  const [thinkingPhrases, setThinkingPhrases] = useState<string[]>([]);\n  const [thinkingDelayMs, setThinkingDelayMs] = useState<number>(1000);\n  const [isTakenOver, setIsTakenOver] = useState<boolean>(false);\n  const [isFinalized, setIsFinalized] = useState<boolean>(false);\n\n  // Scoped messages key for apiKey, conversatioId\n  const buildMessagesKey = useCallback((apiKeyVal: string, convId: string | null) => {\n    if (!convId) return null;\n    return `genassist_conversation_messages:${apiKeyVal}:${convId}`;\n  }, []);\n\n  // Deep compare metadata to prevent unnecessary re-initializations\n  // Only re-initialize if metadata actually changes (by value, not reference)\n  const metadataString = useMemo(() => JSON.stringify(metadata || {}), [metadata]);\n  const metadataRef = useRef<string>(metadataString);\n  const prevBaseUrlRef = useRef<string>(baseUrl);\n  const prevApiKeyRef = useRef<string>(apiKey);\n  const prevTenantRef = useRef<string | undefined>(tenant);\n\n  // Store callbacks in refs so they don't trigger re-initialization\n  const onErrorRef = useRef(onError);\n  const onTakeoverRef = useRef(onTakeover);\n  const onFinalizeRef = useRef(onFinalize);\n\n  // Update callback refs when they change\n  useEffect(() => {\n    onErrorRef.current = onError;\n  }, [onError]);\n\n  useEffect(() => {\n    onTakeoverRef.current = onTakeover;\n  }, [onTakeover]);\n\n  useEffect(() => {\n    onFinalizeRef.current = onFinalize;\n  }, [onFinalize]);\n\n  // Initialize chat service - only when baseUrl, apiKey, tenant, or metadata actually change\n  useEffect(() => {\n    const metadataChanged = metadataRef.current !== metadataString;\n    const baseUrlChanged = prevBaseUrlRef.current !== baseUrl;\n    const apiKeyChanged = prevApiKeyRef.current !== apiKey;\n    const tenantChanged = prevTenantRef.current !== tenant;\n    \n    // Only re-initialize for connection-related changes, NOT for metadata changes\n    const needsReinit = !chatServiceRef.current || baseUrlChanged || apiKeyChanged || tenantChanged;\n\n    if (needsReinit) {\n      // Update refs\n      if (baseUrlChanged) prevBaseUrlRef.current = baseUrl;\n      if (apiKeyChanged) prevApiKeyRef.current = apiKey;\n      if (tenantChanged) prevTenantRef.current = tenant;\n      if (metadataChanged) metadataRef.current = metadataString;\n\n      // Clean up existing service if it exists\n      if (chatServiceRef.current) {\n        chatServiceRef.current.disconnect();\n        chatServiceRef.current.setWelcomeDataHandler(null);\n      }\n      \n      chatServiceRef.current = new ChatService(baseUrl, apiKey, metadata, tenant, language);\n      \n      // Set up handlers\n      chatServiceRef.current.setMessageHandler((message: ChatMessage) => {\n        const normalizedMessage: ChatMessage = {\n          ...message,\n          create_time: (!message.create_time || isNaN(message.create_time))\n            ? Math.floor(Date.now() / 1000)\n            : message.create_time,\n        };\n\n        setMessages(prevMessages => [...prevMessages, normalizedMessage]);\n        // Stop typing animation when agent or system message arrives\n        if (normalizedMessage.speaker === 'agent' || normalizedMessage.speaker === 'special') {\n          setIsAgentTyping(false);\n        }\n      });\n\n      chatServiceRef.current.setTakeoverHandler(() => {\n        setIsTakenOver(true);\n        setIsAgentTyping(false);\n        if (onTakeoverRef.current) {\n          onTakeoverRef.current();\n        }\n      });\n\n      chatServiceRef.current.setFinalizedHandler(() => {\n        setIsFinalized(true);\n        setIsAgentTyping(false);\n        if (onFinalizeRef.current) {\n          onFinalizeRef.current();\n        }\n      });\n\n      chatServiceRef.current.setConnectionStateHandler((state) => {\n        setConnectionState(state);\n        if (state !== 'connected') {\n          setIsAgentTyping(false);\n        }\n      });\n\n      chatServiceRef.current.setWelcomeDataHandler((data) => {\n        setWelcomeTitle(data.title ?? null);\n        setWelcomeImageUrl(data.imageUrl ?? null);\n        setWelcomeMessage(data.message ?? null);\n        if (data.possibleQueries && data.possibleQueries.length > 0) {\n          setPossibleQueries(data.possibleQueries);\n        }\n      });\n\n      // Check for a saved conversation and connect to it\n      const convId = chatServiceRef.current.getConversationId();\n      if (convId) {\n        setConversationId(convId);\n        if (chatServiceRef.current.isConversationFinalized()) {\n          setIsFinalized(true);\n        } else {\n          chatServiceRef.current.connectWebSocket();\n        }\n      }\n      // Pull initial static data\n      if (chatServiceRef.current) {\n        const queries = chatServiceRef.current.getPossibleQueries?.() || [];\n        if (queries.length) setPossibleQueries(queries);\n        const welcome = chatServiceRef.current.getWelcomeData?.();\n        if (welcome) {\n          setWelcomeTitle(welcome.title || null);\n          setWelcomeImageUrl(welcome.imageUrl || null);\n          setWelcomeMessage(welcome.message || null);\n        }\n        const thinking = chatServiceRef.current.getThinkingConfig?.();\n        if (thinking) {\n          setThinkingPhrases(thinking.phrases || []);\n          setThinkingDelayMs(thinking.delayMs || 1000);\n        }\n      }\n    } else if (chatServiceRef.current) {\n      // Just update metadata without re-initializing\n      if (metadataChanged) {\n        metadataRef.current = metadataString;\n        chatServiceRef.current.setMetadata(metadata);\n      }\n    }\n\n    // Always update handlers when callbacks change (without re-initializing)\n    if (chatServiceRef.current) {\n      chatServiceRef.current.setTakeoverHandler(() => {\n        setIsTakenOver(true);\n        setIsAgentTyping(false);\n        if (onTakeoverRef.current) {\n          onTakeoverRef.current();\n        }\n      });\n\n      chatServiceRef.current.setFinalizedHandler(() => {\n        setIsFinalized(true);\n        setIsAgentTyping(false);\n        if (onFinalizeRef.current) {\n          onFinalizeRef.current();\n        }\n      });\n    }\n\n    // Cleanup only on unmount\n    return () => {\n      // Only cleanup on unmount, not on every dependency change\n    };\n  }, [baseUrl, apiKey, tenant, metadataString, language]);\n\n  // Update language when it changes (without re-initializing the service)\n  useEffect(() => {\n    if (chatServiceRef.current) {\n      chatServiceRef.current.setLanguage(language);\n    }\n  }, [language]);\n\n  // Load messages for current pair when available\n  useEffect(() => {\n    const key = buildMessagesKey(apiKey, conversationId);\n    if (!key) {\n      setMessages([]);\n      return;\n    }\n    try {\n      const stored = localStorage.getItem(key);\n      setMessages(stored ? JSON.parse(stored) : []);\n    } catch (error) {\n      setMessages([]);\n    }\n  }, [apiKey, conversationId, buildMessagesKey]);\n\n  // Persist messages for current pair\n  useEffect(() => {\n    const key = buildMessagesKey(apiKey, conversationId);\n    if (!key) return;\n    try {\n      localStorage.setItem(key, JSON.stringify(messages));\n    } catch (error) {\n      // ignore\n    }\n  }, [messages, apiKey, conversationId, buildMessagesKey]);\n\n  // Reset conversation\n  const resetConversation = useCallback(async (reCaptchaToken: string | undefined) => {\n    if (!chatServiceRef.current) {\n      return;\n    }\n    \n    setConnectionState('connecting');\n    setIsLoading(true);\n    setMessages([]);\n    setPossibleQueries([]);\n    setWelcomeTitle(null);\n    setWelcomeImageUrl(null);\n    setWelcomeMessage(null);\n    setThinkingPhrases([]);\n    setThinkingDelayMs(1000);\n    const key = buildMessagesKey(apiKey, conversationId);\n    if (key) {\n      localStorage.removeItem(key);\n    }\n    setIsFinalized(false);\n    setIsTakenOver(false);\n    setIsAgentTyping(false);\n    \n    try {\n      // Reset the conversation in the chat service\n      chatServiceRef.current.resetConversation();\n      \n      // Start a new conversation\n      const convId = await chatServiceRef.current.startConversation(reCaptchaToken);\n      setConversationId(convId);\n      setConnectionState('connected');\n\n      // Get possible queries from API response\n      if (chatServiceRef.current.getPossibleQueries) {\n        const queries = chatServiceRef.current.getPossibleQueries();\n        if (queries && queries.length > 0) {\n          setPossibleQueries(queries);\n        }\n      }\n      // welcome and thinking data\n      if (chatServiceRef.current.getWelcomeData) {\n        const welcome = chatServiceRef.current.getWelcomeData();\n        setWelcomeTitle(welcome.title || null);\n        setWelcomeImageUrl(welcome.imageUrl || null);\n        setWelcomeMessage(welcome.message || null);\n      }\n      if (chatServiceRef.current.getThinkingConfig) {\n        const thinking = chatServiceRef.current.getThinkingConfig();\n        setThinkingPhrases(thinking.phrases || []);\n        setThinkingDelayMs(thinking.delayMs || 1000);\n      }\n    } catch (error) {\n      setConnectionState('disconnected');\n      setIsAgentTyping(false);\n      if (onErrorRef.current && error instanceof Error) {\n        onErrorRef.current(error);\n      } else {\n        // ignore\n      }\n    } finally {\n      setIsLoading(false);\n    }\n  }, []);\n\n  const uploadFile = useCallback(async (file: File): Promise<Attachment | null> => {\n    if (!chatServiceRef.current || !chatServiceRef.current.getConversationId()) {\n      return null;\n    }\n\n    try {\n      const { fileUrl } = await chatServiceRef.current.uploadFile(\n        chatServiceRef.current.getConversationId() as string,\n        file\n      );\n      \n      const attachment: Attachment = {\n        name: file.name,\n        type: file.type,\n        size: file.size,\n        url: fileUrl,\n      };\n\n      setPreloadedAttachments(prev => [...prev, attachment]);\n      return attachment;\n    } catch (error) {\n      if (onErrorRef.current) {\n        onErrorRef.current(error as Error);\n      }\n      return null;\n    }\n  }, []);\n\n  // Send message\n  const sendMessage = useCallback(async (text: string, files: File[] = [], extraMetadata?: Record<string, any>, reCaptchaToken?: string) => {\n    if (!chatServiceRef.current) {\n      throw new Error('Chat service not initialized');\n    }\n\n    try {\n      setIsLoading(true);\n\n      const newAttachments: Attachment[] = [];\n      \n      if (files.length > 0) {\n        const uploadedFiles = files.map(f => preloadedAttachments.find(pa => pa.name === f.name && pa.size === f.size)).filter(Boolean) as Attachment[];\n        newAttachments.push(...uploadedFiles);\n      }\n\n      // Start typing immediately when user sends, unless conversation is taken over by a human\n      if (!isTakenOver) {\n        setIsAgentTyping(true);\n      }\n      await chatServiceRef.current.sendMessage(text, newAttachments, extraMetadata, reCaptchaToken);\n\n      setPreloadedAttachments([]);\n\n    } catch (error) {\n      setIsAgentTyping(false);\n      if (onErrorRef.current && error instanceof Error) {\n        onErrorRef.current(error);\n      } else {\n        // ignore\n      }\n    } finally {\n      setIsLoading(false);\n    }\n  }, [preloadedAttachments, isTakenOver]);\n\n  const startConversation = useCallback(async (reCaptchaToken: string | undefined) => {\n    if (!chatServiceRef.current) {\n      return;\n    }\n    try {\n      setConnectionState('connecting');\n      setIsLoading(true);\n      \n      // Reset state for new conversation\n      setMessages([]);\n      setPossibleQueries([]);\n      const key = buildMessagesKey(apiKey, conversationId);\n      if (key) {\n        localStorage.removeItem(key);\n      }\n      setIsFinalized(false);\n      setIsTakenOver(false);\n      setIsAgentTyping(false);\n      chatServiceRef.current.resetConversation();\n\n      const convId = await chatServiceRef.current.startConversation(reCaptchaToken);\n      setConversationId(convId);\n      setConnectionState('connected');\n\n      if (chatServiceRef.current.getPossibleQueries) {\n        const queries = chatServiceRef.current.getPossibleQueries();\n        if (queries && queries.length > 0) {\n          setPossibleQueries(queries);\n        }\n      }\n      if (chatServiceRef.current.getWelcomeData) {\n        const welcome = chatServiceRef.current.getWelcomeData();\n        setWelcomeTitle(welcome.title || null);\n        setWelcomeImageUrl(welcome.imageUrl || null);\n        setWelcomeMessage(welcome.message || null);\n      }\n      if (chatServiceRef.current.getThinkingConfig) {\n        const thinking = chatServiceRef.current.getThinkingConfig();\n        setThinkingPhrases(thinking.phrases || []);\n        setThinkingDelayMs(thinking.delayMs || 1000);\n      }\n    } catch (error) {\n      setConnectionState('disconnected');\n      setIsAgentTyping(false);\n      if (onErrorRef.current && error instanceof Error) {\n        onErrorRef.current(error);\n      } else {\n        // ignore\n      }\n    } finally {\n      setIsLoading(false);\n    }\n  }, []);\n\n  // Add feedback to an agent message\n  const addFeedback = useCallback(\n    async (messageId: string, value: 'good' | 'bad', feedbackMessage?: string) => {\n      if (!chatServiceRef.current) {\n        console.error('Cannot send feedback: ChatService not initialized');\n        return;\n      }\n      if (!messageId) {\n        console.error('Cannot send feedback: messageId is required');\n        return;\n      }\n      \n      try {\n        await chatServiceRef.current.addFeedback(messageId, value, feedbackMessage);\n\n        const newFeedback: MessageFeedback = {\n          feedback: value,\n          feedback_message: feedbackMessage,\n          feedback_timestamp: new Date().toISOString(),\n        };\n\n        setMessages(prev =>\n          prev.map(m => {\n            // Match by message_id or id field\n            const msgId = m.message_id || (m as any).id;\n            return msgId === messageId\n              ? { ...m, feedback: [...(m.feedback || []), newFeedback] }\n              : m;\n          })\n        );\n      } catch (error) {\n        if (onErrorRef.current) {\n          onErrorRef.current(error as Error);\n        }\n      }\n    },\n    []\n  );\n\n  return {\n    messages,\n    isLoading,\n    sendMessage,\n    uploadFile,\n    resetConversation,\n    startConversation,\n    connectionState,\n    conversationId,\n    possibleQueries,\n    isTakenOver,\n    isFinalized,\n    isAgentTyping,\n    addFeedback,\n    welcomeTitle,\n    welcomeImageUrl,\n    welcomeMessage,\n    thinkingPhrases,\n    thinkingDelayMs,\n  };\n};\n"]}
|
|
553
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"useChat.js","sourceRoot":"","sources":["../../src/hooks/useChat.ts"],"names":[],"mappings":"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","sourcesContent":["import { useState, useEffect, useCallback, useRef, useMemo } from 'react';\nimport { ChatService } from '../services/chatService';\nimport { ChatMessage, Attachment, MessageFeedback } from '../types';\n\nexport interface UseChatProps {\n  baseUrl: string;\n  apiKey: string;\n  tenant?: string | undefined;\n  metadata?: Record<string, any>;\n  //  If false, the chat will run in HTTP-only mode (no WebSocket connection).\n  useWs?: boolean;\n  language?: string;\n  onError?: (error: Error) => void;\n  onTakeover?: () => void;\n  onFinalize?: () => void;\n}\n\nexport const useChat = ({ baseUrl, apiKey, tenant, metadata, useWs = true, language, onError, onTakeover, onFinalize }: UseChatProps) => {\n  const [messages, setMessages] = useState<ChatMessage[]>([]);\n  const [isLoading, setIsLoading] = useState<boolean>(false);\n  const [preloadedAttachments, setPreloadedAttachments] = useState<Attachment[]>([]);\n  const [connectionState, setConnectionState] = useState<'connecting' | 'connected' | 'disconnected'>('disconnected');\n  const [isAgentTyping, setIsAgentTyping] = useState<boolean>(false);\n  const chatServiceRef = useRef<ChatService | null>(null);\n  const [conversationId, setConversationId] = useState<string | null>(null);\n  const [possibleQueries, setPossibleQueries] = useState<string[]>([]);\n  const [welcomeTitle, setWelcomeTitle] = useState<string | null>(null);\n  const [welcomeImageUrl, setWelcomeImageUrl] = useState<string | null>(null);\n  const [welcomeMessage, setWelcomeMessage] = useState<string | null>(null);\n  const [thinkingPhrases, setThinkingPhrases] = useState<string[]>([]);\n  const [thinkingDelayMs, setThinkingDelayMs] = useState<number>(1000);\n  const [isTakenOver, setIsTakenOver] = useState<boolean>(false);\n  const [isFinalized, setIsFinalized] = useState<boolean>(false);\n\n  // Scoped messages key for apiKey, conversatioId\n  const buildMessagesKey = useCallback((apiKeyVal: string, convId: string | null) => {\n    if (!convId) return null;\n    return `genassist_conversation_messages:${apiKeyVal}:${convId}`;\n  }, []);\n\n  // Deep compare metadata to prevent unnecessary re-initializations\n  // Only re-initialize if metadata actually changes (by value, not reference)\n  const metadataString = useMemo(() => JSON.stringify(metadata || {}), [metadata]);\n  const metadataRef = useRef<string>(metadataString);\n  const prevBaseUrlRef = useRef<string>(baseUrl);\n  const prevApiKeyRef = useRef<string>(apiKey);\n  const prevTenantRef = useRef<string | undefined>(tenant);\n  const prevUseWsRef = useRef<boolean>(useWs);\n\n  // Store callbacks in refs so they don't trigger re-initialization\n  const onErrorRef = useRef(onError);\n  const onTakeoverRef = useRef(onTakeover);\n  const onFinalizeRef = useRef(onFinalize);\n\n  // Update callback refs when they change\n  useEffect(() => {\n    onErrorRef.current = onError;\n  }, [onError]);\n\n  useEffect(() => {\n    onTakeoverRef.current = onTakeover;\n  }, [onTakeover]);\n\n  useEffect(() => {\n    onFinalizeRef.current = onFinalize;\n  }, [onFinalize]);\n\n  // Initialize chat service - only when baseUrl, apiKey, tenant, useWs, or metadata actually change\n  useEffect(() => {\n    const metadataChanged = metadataRef.current !== metadataString;\n    const baseUrlChanged = prevBaseUrlRef.current !== baseUrl;\n    const apiKeyChanged = prevApiKeyRef.current !== apiKey;\n    const tenantChanged = prevTenantRef.current !== tenant;\n    const useWsChanged = prevUseWsRef.current !== useWs;\n    \n    // Only re-initialize for connection-related changes, NOT for metadata changes\n    const needsReinit = !chatServiceRef.current || baseUrlChanged || apiKeyChanged || tenantChanged || useWsChanged;\n\n    if (needsReinit) {\n      // Update refs\n      if (baseUrlChanged) prevBaseUrlRef.current = baseUrl;\n      if (apiKeyChanged) prevApiKeyRef.current = apiKey;\n      if (tenantChanged) prevTenantRef.current = tenant;\n      if (useWsChanged) prevUseWsRef.current = useWs;\n      if (metadataChanged) metadataRef.current = metadataString;\n\n      // Clean up existing service if it exists\n      if (chatServiceRef.current) {\n        chatServiceRef.current.disconnect();\n        chatServiceRef.current.setWelcomeDataHandler(null);\n      }\n      \n      chatServiceRef.current = new ChatService(baseUrl, apiKey, metadata, tenant, language, useWs);\n      \n      // Set up handlers\n      chatServiceRef.current.setMessageHandler((message: ChatMessage) => {\n        const normalizedMessage: ChatMessage = {\n          ...message,\n          create_time: (!message.create_time || isNaN(message.create_time))\n            ? Math.floor(Date.now() / 1000)\n            : message.create_time,\n        };\n\n        setMessages(prevMessages => [...prevMessages, normalizedMessage]);\n        // Stop typing animation when agent or system message arrives\n        if (normalizedMessage.speaker === 'agent' || normalizedMessage.speaker === 'special') {\n          setIsAgentTyping(false);\n        }\n      });\n\n      chatServiceRef.current.setTakeoverHandler(() => {\n        setIsTakenOver(true);\n        setIsAgentTyping(false);\n        if (onTakeoverRef.current) {\n          onTakeoverRef.current();\n        }\n      });\n\n      chatServiceRef.current.setFinalizedHandler(() => {\n        setIsFinalized(true);\n        setIsAgentTyping(false);\n        if (onFinalizeRef.current) {\n          onFinalizeRef.current();\n        }\n      });\n\n      chatServiceRef.current.setConnectionStateHandler((state) => {\n        setConnectionState(state);\n        if (state !== 'connected') {\n          setIsAgentTyping(false);\n        }\n      });\n\n      chatServiceRef.current.setWelcomeDataHandler((data) => {\n        setWelcomeTitle(data.title ?? null);\n        setWelcomeImageUrl(data.imageUrl ?? null);\n        setWelcomeMessage(data.message ?? null);\n        if (data.possibleQueries && data.possibleQueries.length > 0) {\n          setPossibleQueries(data.possibleQueries);\n        }\n      });\n\n      // Check for a saved conversation and connect to it\n      const convId = chatServiceRef.current.getConversationId();\n      if (convId) {\n        setConversationId(convId);\n        if (chatServiceRef.current.isConversationFinalized()) {\n          setIsFinalized(true);\n        } else {\n          chatServiceRef.current.connectWebSocket();\n        }\n      }\n      // Pull initial static data\n      if (chatServiceRef.current) {\n        const queries = chatServiceRef.current.getPossibleQueries?.() || [];\n        if (queries.length) setPossibleQueries(queries);\n        const welcome = chatServiceRef.current.getWelcomeData?.();\n        if (welcome) {\n          setWelcomeTitle(welcome.title || null);\n          setWelcomeImageUrl(welcome.imageUrl || null);\n          setWelcomeMessage(welcome.message || null);\n        }\n        const thinking = chatServiceRef.current.getThinkingConfig?.();\n        if (thinking) {\n          setThinkingPhrases(thinking.phrases || []);\n          setThinkingDelayMs(thinking.delayMs || 1000);\n        }\n      }\n    } else if (chatServiceRef.current) {\n      // Just update metadata without re-initializing\n      if (metadataChanged) {\n        metadataRef.current = metadataString;\n        chatServiceRef.current.setMetadata(metadata);\n      }\n    }\n\n    // Always update handlers when callbacks change (without re-initializing)\n    if (chatServiceRef.current) {\n      chatServiceRef.current.setTakeoverHandler(() => {\n        setIsTakenOver(true);\n        setIsAgentTyping(false);\n        if (onTakeoverRef.current) {\n          onTakeoverRef.current();\n        }\n      });\n\n      chatServiceRef.current.setFinalizedHandler(() => {\n        setIsFinalized(true);\n        setIsAgentTyping(false);\n        if (onFinalizeRef.current) {\n          onFinalizeRef.current();\n        }\n      });\n    }\n\n    // Cleanup only on unmount\n    return () => {\n      // Only cleanup on unmount, not on every dependency change\n    };\n  }, [baseUrl, apiKey, tenant, metadataString, language, useWs]);\n\n  // Update language when it changes (without re-initializing the service)\n  useEffect(() => {\n    if (chatServiceRef.current) {\n      chatServiceRef.current.setLanguage(language);\n    }\n  }, [language]);\n\n  // Load messages for current pair when available\n  useEffect(() => {\n    const key = buildMessagesKey(apiKey, conversationId);\n    if (!key) {\n      setMessages([]);\n      return;\n    }\n    try {\n      const stored = localStorage.getItem(key);\n      setMessages(stored ? JSON.parse(stored) : []);\n    } catch (error) {\n      setMessages([]);\n    }\n  }, [apiKey, conversationId, buildMessagesKey]);\n\n  // Persist messages for current pair\n  useEffect(() => {\n    const key = buildMessagesKey(apiKey, conversationId);\n    if (!key) return;\n    try {\n      localStorage.setItem(key, JSON.stringify(messages));\n    } catch (error) {\n      // ignore\n    }\n  }, [messages, apiKey, conversationId, buildMessagesKey]);\n\n  // Reset conversation\n  const resetConversation = useCallback(async (reCaptchaToken: string | undefined) => {\n    if (!chatServiceRef.current) {\n      return;\n    }\n    \n    setConnectionState('connecting');\n    setIsLoading(true);\n    setMessages([]);\n    setPossibleQueries([]);\n    setWelcomeTitle(null);\n    setWelcomeImageUrl(null);\n    setWelcomeMessage(null);\n    setThinkingPhrases([]);\n    setThinkingDelayMs(1000);\n    const key = buildMessagesKey(apiKey, conversationId);\n    if (key) {\n      localStorage.removeItem(key);\n    }\n    setIsFinalized(false);\n    setIsTakenOver(false);\n    setIsAgentTyping(false);\n    \n    try {\n      // Reset the conversation in the chat service\n      chatServiceRef.current.resetConversation();\n      \n      // Start a new conversation\n      const convId = await chatServiceRef.current.startConversation(reCaptchaToken);\n      setConversationId(convId);\n      setConnectionState('connected');\n\n      // Get possible queries from API response\n      if (chatServiceRef.current.getPossibleQueries) {\n        const queries = chatServiceRef.current.getPossibleQueries();\n        if (queries && queries.length > 0) {\n          setPossibleQueries(queries);\n        }\n      }\n      // welcome and thinking data\n      if (chatServiceRef.current.getWelcomeData) {\n        const welcome = chatServiceRef.current.getWelcomeData();\n        setWelcomeTitle(welcome.title || null);\n        setWelcomeImageUrl(welcome.imageUrl || null);\n        setWelcomeMessage(welcome.message || null);\n      }\n      if (chatServiceRef.current.getThinkingConfig) {\n        const thinking = chatServiceRef.current.getThinkingConfig();\n        setThinkingPhrases(thinking.phrases || []);\n        setThinkingDelayMs(thinking.delayMs || 1000);\n      }\n    } catch (error) {\n      setConnectionState('disconnected');\n      setIsAgentTyping(false);\n      if (onErrorRef.current && error instanceof Error) {\n        onErrorRef.current(error);\n      } else {\n        // ignore\n      }\n    } finally {\n      setIsLoading(false);\n    }\n  }, []);\n\n  const uploadFile = useCallback(async (file: File): Promise<Attachment | null> => {\n    const conversationId = chatServiceRef.current?.getConversationId(); \n    if (!conversationId) {\n      return null;\n    }\n\n    try {\n      const uploadResult = await chatServiceRef.current?.uploadFile(conversationId, file);\n\n      // construct the file url with the base url\n      const file_url = new URL(uploadResult!.file_url!, baseUrl).href;\n      \n      const attachment: Attachment = {\n        name: file.name,\n        type: file.type,\n        size: file.size,\n        url: file_url,\n        file_id: uploadResult?.file_id,\n      };\n\n      setPreloadedAttachments(prev => [...prev, attachment]);\n      return attachment;\n    } catch (error) {\n      if (onErrorRef.current) {\n        onErrorRef.current(error as Error);\n      }\n      return null;\n    }\n  }, []);\n\n  // Send message\n  const sendMessage = useCallback(async (text: string, files: File[] = [], extraMetadata?: Record<string, any>, reCaptchaToken?: string) => {\n    if (!chatServiceRef.current) {\n      throw new Error('Chat service not initialized');\n    }\n\n    try {\n      setIsLoading(true);\n\n      const newAttachments: Attachment[] = [];\n      \n      if (files.length > 0) {\n        const uploadedFiles = files.map(f => preloadedAttachments.find(pa => pa.name === f.name && pa.size === f.size)).filter(Boolean) as Attachment[];\n        newAttachments.push(...uploadedFiles);\n      }\n\n      // Start typing immediately when user sends, unless conversation is taken over by a human\n      if (!isTakenOver) {\n        setIsAgentTyping(true);\n      }\n      \n      await chatServiceRef.current.sendMessage(text, newAttachments, extraMetadata, reCaptchaToken);\n\n      setPreloadedAttachments([]);\n\n    } catch (error) {\n      setIsAgentTyping(false);\n      if (onErrorRef.current && error instanceof Error) {\n        onErrorRef.current(error);\n      } else {\n        // ignore\n      }\n    } finally {\n      setIsLoading(false);\n    }\n  }, [preloadedAttachments, isTakenOver]);\n\n  const startConversation = useCallback(async (reCaptchaToken: string | undefined) => {\n    if (!chatServiceRef.current) {\n      return;\n    }\n    try {\n      setConnectionState('connecting');\n      setIsLoading(true);\n      \n      // Reset state for new conversation\n      setMessages([]);\n      setPossibleQueries([]);\n      const key = buildMessagesKey(apiKey, conversationId);\n      if (key) {\n        localStorage.removeItem(key);\n      }\n      setIsFinalized(false);\n      setIsTakenOver(false);\n      setIsAgentTyping(false);\n      chatServiceRef.current.resetConversation();\n\n      const convId = await chatServiceRef.current.startConversation(reCaptchaToken);\n      setConversationId(convId);\n      setConnectionState('connected');\n\n      if (chatServiceRef.current.getPossibleQueries) {\n        const queries = chatServiceRef.current.getPossibleQueries();\n        if (queries && queries.length > 0) {\n          setPossibleQueries(queries);\n        }\n      }\n      if (chatServiceRef.current.getWelcomeData) {\n        const welcome = chatServiceRef.current.getWelcomeData();\n        setWelcomeTitle(welcome.title || null);\n        setWelcomeImageUrl(welcome.imageUrl || null);\n        setWelcomeMessage(welcome.message || null);\n      }\n      if (chatServiceRef.current.getThinkingConfig) {\n        const thinking = chatServiceRef.current.getThinkingConfig();\n        setThinkingPhrases(thinking.phrases || []);\n        setThinkingDelayMs(thinking.delayMs || 1000);\n      }\n    } catch (error) {\n      setConnectionState('disconnected');\n      setIsAgentTyping(false);\n      if (onErrorRef.current && error instanceof Error) {\n        onErrorRef.current(error);\n      } else {\n        // ignore\n      }\n    } finally {\n      setIsLoading(false);\n    }\n  }, []);\n\n  // Add feedback to an agent message\n  const addFeedback = useCallback(\n    async (messageId: string, value: 'good' | 'bad', feedbackMessage?: string) => {\n      if (!chatServiceRef.current) {\n        console.error('Cannot send feedback: ChatService not initialized');\n        return;\n      }\n      if (!messageId) {\n        console.error('Cannot send feedback: messageId is required');\n        return;\n      }\n      \n      try {\n        await chatServiceRef.current.addFeedback(messageId, value, feedbackMessage);\n\n        const newFeedback: MessageFeedback = {\n          feedback: value,\n          feedback_message: feedbackMessage,\n          feedback_timestamp: new Date().toISOString(),\n        };\n\n        setMessages(prev =>\n          prev.map(m => {\n            // Match by message_id or id field\n            const msgId = m.message_id || (m as any).id;\n            return msgId === messageId\n              ? { ...m, feedback: [...(m.feedback || []), newFeedback] }\n              : m;\n          })\n        );\n      } catch (error) {\n        if (onErrorRef.current) {\n          onErrorRef.current(error as Error);\n        }\n      }\n    },\n    []\n  );\n\n  return {\n    messages,\n    isLoading,\n    sendMessage,\n    uploadFile,\n    resetConversation,\n    startConversation,\n    connectionState,\n    conversationId,\n    possibleQueries,\n    isTakenOver,\n    isFinalized,\n    isAgentTyping,\n    addFeedback,\n    welcomeTitle,\n    welcomeImageUrl,\n    welcomeMessage,\n    thinkingPhrases,\n    thinkingDelayMs,\n  };\n};\n"]}
|