@stack-spot/ai-chat-widget 1.28.0 → 1.28.1-beta.1
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/app-metadata.json +3 -3
- package/dist/components/AgentCard/dictionary.d.ts +4 -2
- package/dist/components/AgentCard/dictionary.d.ts.map +1 -1
- package/dist/components/AgentCard/dictionary.js +4 -2
- package/dist/components/AgentCard/dictionary.js.map +1 -1
- package/dist/components/Selector/index.d.ts +2 -2
- package/dist/components/Selector/index.d.ts.map +1 -1
- package/dist/components/Selector/index.js +2 -2
- package/dist/components/Selector/index.js.map +1 -1
- package/dist/layout.css +17 -0
- package/dist/state/types.d.ts +1 -1
- package/dist/state/types.d.ts.map +1 -1
- package/dist/utils/tools.d.ts +2 -2
- package/dist/utils/tools.d.ts.map +1 -1
- package/dist/utils/tools.js +3 -6
- package/dist/utils/tools.js.map +1 -1
- package/dist/utils/upload/UploadManager.d.ts +2 -0
- package/dist/utils/upload/UploadManager.d.ts.map +1 -1
- package/dist/utils/upload/UploadManager.js +32 -25
- package/dist/utils/upload/UploadManager.js.map +1 -1
- package/dist/utils/upload/use-paste-upload.d.ts +8 -0
- package/dist/utils/upload/use-paste-upload.d.ts.map +1 -0
- package/dist/utils/upload/use-paste-upload.js +19 -0
- package/dist/utils/upload/use-paste-upload.js.map +1 -0
- package/dist/views/Agents/AgentDescription.d.ts +2 -9
- package/dist/views/Agents/AgentDescription.d.ts.map +1 -1
- package/dist/views/Agents/AgentDescription.js +12 -9
- package/dist/views/Agents/AgentDescription.js.map +1 -1
- package/dist/views/Agents/AgentsPanel.d.ts.map +1 -1
- package/dist/views/Agents/AgentsPanel.js +11 -11
- package/dist/views/Agents/AgentsPanel.js.map +1 -1
- package/dist/views/Agents/AgentsTab.d.ts +2 -2
- package/dist/views/Agents/AgentsTab.d.ts.map +1 -1
- package/dist/views/Agents/AgentsTab.js +6 -6
- package/dist/views/Agents/AgentsTab.js.map +1 -1
- package/dist/views/Agents/useAgentFavorites.d.ts +1 -1
- package/dist/views/Agents/useAgentFavorites.js +4 -4
- package/dist/views/Agents/useAgentFavorites.js.map +1 -1
- package/dist/views/Chat/ChatMessage.js +3 -3
- package/dist/views/Chat/ChatMessage.js.map +1 -1
- package/dist/views/ChatHistory/HistoryItem.d.ts.map +1 -1
- package/dist/views/ChatHistory/HistoryItem.js +8 -5
- package/dist/views/ChatHistory/HistoryItem.js.map +1 -1
- package/dist/views/ChatHistory/utils.d.ts +0 -6
- package/dist/views/ChatHistory/utils.d.ts.map +1 -1
- package/dist/views/ChatHistory/utils.js +1 -16
- package/dist/views/ChatHistory/utils.js.map +1 -1
- package/dist/views/Home/CustomAgent.js +3 -3
- package/dist/views/Home/CustomAgent.js.map +1 -1
- package/dist/views/MessageInput/AgentSelector.js +4 -4
- package/dist/views/MessageInput/AgentSelector.js.map +1 -1
- package/dist/views/MessageInput/ButtonAgent.js +2 -2
- package/dist/views/MessageInput/ButtonAgent.js.map +1 -1
- package/dist/views/MessageInput/UploadDragNDrop.d.ts +14 -0
- package/dist/views/MessageInput/UploadDragNDrop.d.ts.map +1 -0
- package/dist/views/MessageInput/UploadDragNDrop.js +52 -0
- package/dist/views/MessageInput/UploadDragNDrop.js.map +1 -0
- package/dist/views/MessageInput/dictionary.d.ts +1 -1
- package/dist/views/MessageInput/dictionary.d.ts.map +1 -1
- package/dist/views/MessageInput/dictionary.js +9 -0
- package/dist/views/MessageInput/dictionary.js.map +1 -1
- package/dist/views/MessageInput/index.d.ts.map +1 -1
- package/dist/views/MessageInput/index.js +13 -1
- package/dist/views/MessageInput/index.js.map +1 -1
- package/dist/views/Tools.js +3 -3
- package/dist/views/Tools.js.map +1 -1
- package/dist/views/Workspaces/WorkspacesTab.js +1 -1
- package/package.json +2 -2
- package/src/app-metadata.json +3 -3
- package/src/components/AgentCard/dictionary.ts +4 -2
- package/src/components/Selector/index.tsx +4 -5
- package/src/layout.css +17 -0
- package/src/state/types.ts +1 -1
- package/src/utils/tools.ts +5 -7
- package/src/utils/upload/UploadManager.ts +32 -23
- package/src/utils/upload/use-paste-upload.tsx +30 -0
- package/src/views/Agents/AgentDescription.tsx +19 -25
- package/src/views/Agents/AgentsPanel.tsx +11 -12
- package/src/views/Agents/AgentsTab.tsx +12 -17
- package/src/views/Agents/useAgentFavorites.ts +4 -4
- package/src/views/Chat/ChatMessage.tsx +3 -3
- package/src/views/ChatHistory/HistoryItem.tsx +10 -5
- package/src/views/ChatHistory/utils.ts +1 -18
- package/src/views/Home/CustomAgent.tsx +4 -4
- package/src/views/MessageInput/AgentSelector.tsx +4 -4
- package/src/views/MessageInput/ButtonAgent.tsx +2 -2
- package/src/views/MessageInput/UploadDragNDrop.tsx +83 -0
- package/src/views/MessageInput/dictionary.ts +9 -0
- package/src/views/MessageInput/index.tsx +17 -1
- package/src/views/Tools.tsx +4 -3
- package/src/views/Workspaces/WorkspacesTab.tsx +1 -1
|
@@ -8,6 +8,7 @@ const dictionary = {
|
|
|
8
8
|
agent: 'Select agent',
|
|
9
9
|
send: 'Send message',
|
|
10
10
|
placeholder: 'Send a message to $0. For commands, use @ or /',
|
|
11
|
+
typing: 'Type your message...',
|
|
11
12
|
cancel: 'Cancel',
|
|
12
13
|
removeConfig: 'Remove all the configuration',
|
|
13
14
|
removeStack: 'Stop using the current stack',
|
|
@@ -21,6 +22,10 @@ const dictionary = {
|
|
|
21
22
|
collapse: 'Collapse options',
|
|
22
23
|
uploadSizeError: 'The following files were not added to the upload list because they\'re larger than $1:',
|
|
23
24
|
uploadItemLimitError: 'The following files were not added because no more than $1 items may be uploaded at a time:',
|
|
25
|
+
uploadError: 'An error occurred while uploading the file "$0".',
|
|
26
|
+
uploadDragging: 'Drop the file here to upload',
|
|
27
|
+
uploadDragDropTitle: 'Arraste e solte arquivos',
|
|
28
|
+
uploadDragDropDescription: 'Solte arquivos aqui para enviá-los na conversa',
|
|
24
29
|
cantSendBecauseOfUploadError: 'Can\'t send the message because one of the files in the upload list could not be uploaded. Please, retry it or remove it from the list.',
|
|
25
30
|
cantSendBecauseOfUploadProgress: 'Please wait until all files are uploaded before sending the message. You can also cancel the upload by removing it from the list of uploads.',
|
|
26
31
|
cantSendBecauseOfEmptyContent: 'You can\'t send empty messages. Please write some text or upload a file.',
|
|
@@ -34,6 +39,7 @@ const dictionary = {
|
|
|
34
39
|
agent: 'Selecionar agente',
|
|
35
40
|
send: 'Enviar mensagem',
|
|
36
41
|
placeholder: 'Envie uma mensagem para $0. Para comandos, use @ ou /',
|
|
42
|
+
typing: 'Digite sua mensagem...',
|
|
37
43
|
cancel: 'Cancelar',
|
|
38
44
|
removeConfig: 'Remover todas as configurações',
|
|
39
45
|
removeStack: 'Parar de usar a stack atual',
|
|
@@ -48,6 +54,9 @@ const dictionary = {
|
|
|
48
54
|
uploadSizeError: 'Os seguintes arquivos não foram adicionados à lista de upload porque eles são maiores que $0:',
|
|
49
55
|
uploadItemLimitError: 'Os seguintes arquivos não foram adicionados à lista de upload porque é permitido enviar no máximo $0 arquivos por vez:',
|
|
50
56
|
uploadError: 'Ocorreu um erro ao enviar o arquivo "$0".',
|
|
57
|
+
uploadDragging: 'Solte o arquivo aqui para fazer upload',
|
|
58
|
+
uploadDragDropTitle: 'Solte seus arquivos aqui',
|
|
59
|
+
uploadDragDropDescription: 'Arraste ou solte arquivos para compartilhar na conversa',
|
|
51
60
|
unknownUploadError: 'Ocorreu um erro ao enviar os arquivos.',
|
|
52
61
|
cantSendBecauseOfUploadError: 'Não é possível enviar a mensagem, pois um dos arquivos na lista de uploads não pôde ser enviado. Por favor, tente enviá-lo novamente ou remova-o da lista.',
|
|
53
62
|
cantSendBecauseOfUploadProgress: 'Por favor aguarde todos os uploads de arquivos antes de enviar a mensagem. Você pode cancelar o upload removendo o arquivo da lista de uploads.',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dictionary.js","sourceRoot":"","sources":["../../../src/views/MessageInput/dictionary.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,YAAY,EAAE,MAAM,8BAA8B,CAAA;AAEvE,MAAM,UAAU,GAAG;IACjB,EAAE,EAAE;QACF,KAAK,EAAE,cAAc;QACrB,IAAI,EAAE,kBAAkB;QACxB,IAAI,EAAE,aAAa;QACnB,eAAe,EAAE,0BAA0B;QAC3C,KAAK,EAAE,cAAc;QACrB,IAAI,EAAE,cAAc;QACpB,WAAW,EAAE,gDAAgD;QAC7D,MAAM,EAAE,QAAQ;QAChB,YAAY,EAAE,8BAA8B;QAC5C,WAAW,EAAE,8BAA8B;QAC3C,eAAe,EAAE,6BAA6B;QAC9C,QAAQ,EAAE,kCAAkC;QAC5C,QAAQ,EAAE,UAAU;QACpB,eAAe,EAAE,+BAA+B;QAChD,MAAM,EAAE,QAAQ;QAChB,MAAM,EAAE,aAAa;QACrB,MAAM,EAAE,gBAAgB;QACxB,QAAQ,EAAE,kBAAkB;QAC5B,eAAe,EAAE,wFAAwF;QACzG,oBAAoB,EAAE,6FAA6F;QACnH,4BAA4B,EAAE,yIAAyI;QACvK,+BAA+B,EAAE,8IAA8I;QAC/K,6BAA6B,EAAE,0EAA0E;QACzG,SAAS,EAAE,QAAQ;KACpB;IACD,EAAE,EAAE;QACF,KAAK,EAAE,kBAAkB;QACzB,IAAI,EAAE,wBAAwB;QAC9B,IAAI,EAAE,iBAAiB;QACvB,eAAe,EAAE,8BAA8B;QAC/C,KAAK,EAAE,mBAAmB;QAC1B,IAAI,EAAE,iBAAiB;QACvB,WAAW,EAAE,uDAAuD;QACpE,MAAM,EAAE,UAAU;QAClB,YAAY,EAAE,gCAAgC;QAC9C,WAAW,EAAE,6BAA6B;QAC1C,eAAe,EAAE,4BAA4B;QAC7C,QAAQ,EAAE,qCAAqC;QAC/C,QAAQ,EAAE,aAAa;QACvB,eAAe,EAAE,4BAA4B;QAC7C,MAAM,EAAE,SAAS;QACjB,MAAM,EAAE,gBAAgB;QACxB,MAAM,EAAE,gBAAgB;QACxB,QAAQ,EAAE,iBAAiB;QAC3B,eAAe,EAAE,+FAA+F;QAChH,oBAAoB,EAAE,wHAAwH;QAC9I,WAAW,EAAE,2CAA2C;QACxD,kBAAkB,EAAE,wCAAwC;QAC5D,4BAA4B,EAAE,4JAA4J;QAC1L,+BAA+B,EAAE,iJAAiJ;QAClL,6BAA6B,EAAE,6FAA6F;QAC5H,SAAS,EAAE,SAAS;KACrB;CACmB,CAAA;AAEtB,MAAM,CAAC,MAAM,yBAAyB,GAAG,GAAG,EAAE,CAAC,YAAY,CAAC,UAAU,CAAC,CAAA"}
|
|
1
|
+
{"version":3,"file":"dictionary.js","sourceRoot":"","sources":["../../../src/views/MessageInput/dictionary.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,YAAY,EAAE,MAAM,8BAA8B,CAAA;AAEvE,MAAM,UAAU,GAAG;IACjB,EAAE,EAAE;QACF,KAAK,EAAE,cAAc;QACrB,IAAI,EAAE,kBAAkB;QACxB,IAAI,EAAE,aAAa;QACnB,eAAe,EAAE,0BAA0B;QAC3C,KAAK,EAAE,cAAc;QACrB,IAAI,EAAE,cAAc;QACpB,WAAW,EAAE,gDAAgD;QAC7D,MAAM,EAAE,sBAAsB;QAC9B,MAAM,EAAE,QAAQ;QAChB,YAAY,EAAE,8BAA8B;QAC5C,WAAW,EAAE,8BAA8B;QAC3C,eAAe,EAAE,6BAA6B;QAC9C,QAAQ,EAAE,kCAAkC;QAC5C,QAAQ,EAAE,UAAU;QACpB,eAAe,EAAE,+BAA+B;QAChD,MAAM,EAAE,QAAQ;QAChB,MAAM,EAAE,aAAa;QACrB,MAAM,EAAE,gBAAgB;QACxB,QAAQ,EAAE,kBAAkB;QAC5B,eAAe,EAAE,wFAAwF;QACzG,oBAAoB,EAAE,6FAA6F;QACnH,WAAW,EAAE,kDAAkD;QAC/D,cAAc,EAAE,8BAA8B;QAC9C,mBAAmB,EAAE,0BAA0B;QAC/C,yBAAyB,EAAE,gDAAgD;QAC3E,4BAA4B,EAAE,yIAAyI;QACvK,+BAA+B,EAAE,8IAA8I;QAC/K,6BAA6B,EAAE,0EAA0E;QACzG,SAAS,EAAE,QAAQ;KACpB;IACD,EAAE,EAAE;QACF,KAAK,EAAE,kBAAkB;QACzB,IAAI,EAAE,wBAAwB;QAC9B,IAAI,EAAE,iBAAiB;QACvB,eAAe,EAAE,8BAA8B;QAC/C,KAAK,EAAE,mBAAmB;QAC1B,IAAI,EAAE,iBAAiB;QACvB,WAAW,EAAE,uDAAuD;QACpE,MAAM,EAAE,wBAAwB;QAChC,MAAM,EAAE,UAAU;QAClB,YAAY,EAAE,gCAAgC;QAC9C,WAAW,EAAE,6BAA6B;QAC1C,eAAe,EAAE,4BAA4B;QAC7C,QAAQ,EAAE,qCAAqC;QAC/C,QAAQ,EAAE,aAAa;QACvB,eAAe,EAAE,4BAA4B;QAC7C,MAAM,EAAE,SAAS;QACjB,MAAM,EAAE,gBAAgB;QACxB,MAAM,EAAE,gBAAgB;QACxB,QAAQ,EAAE,iBAAiB;QAC3B,eAAe,EAAE,+FAA+F;QAChH,oBAAoB,EAAE,wHAAwH;QAC9I,WAAW,EAAE,2CAA2C;QACxD,cAAc,EAAE,wCAAwC;QACxD,mBAAmB,EAAE,0BAA0B;QAC/C,yBAAyB,EAAE,yDAAyD;QACpF,kBAAkB,EAAE,wCAAwC;QAC5D,4BAA4B,EAAE,4JAA4J;QAC1L,+BAA+B,EAAE,iJAAiJ;QAClL,6BAA6B,EAAE,6FAA6F;QAC5H,SAAS,EAAE,SAAS;KACrB;CACmB,CAAA;AAEtB,MAAM,CAAC,MAAM,yBAAyB,GAAG,GAAG,EAAE,CAAC,YAAY,CAAC,UAAU,CAAC,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/MessageInput/index.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/MessageInput/index.tsx"],"names":[],"mappings":"AAsBA;;;;GAIG;AACH,eAAO,MAAM,YAAY,+CA4HxB,CAAA"}
|
|
@@ -9,6 +9,7 @@ import { quickCommandRegex } from '../../regex.js';
|
|
|
9
9
|
import { ChatEntry } from '../../state/ChatEntry.js';
|
|
10
10
|
import { checkIsTrial } from '../../utils/check-is-trial.js';
|
|
11
11
|
import { UploadProvider } from '../../utils/upload/context.js';
|
|
12
|
+
import { usePasteUpload } from '../../utils/upload/use-paste-upload.js';
|
|
12
13
|
import { AgentSelector } from './AgentSelector.js';
|
|
13
14
|
import { ButtonAgent } from './ButtonAgent.js';
|
|
14
15
|
import { ButtonBar } from './ButtonBar.js';
|
|
@@ -18,6 +19,7 @@ import { useMessageInputDictionary } from './dictionary.js';
|
|
|
18
19
|
import { QuickCommandSelector } from './QuickCommandSelector.js';
|
|
19
20
|
import { MAX_INPUT_HEIGHT, MessageInputBox, MIN_INPUT_HEIGHT } from './styled.js';
|
|
20
21
|
import { UploadBar } from './UploadBar.js';
|
|
22
|
+
import { UploadDragNDrop, useUploadDragDrop } from './UploadDragNDrop.js';
|
|
21
23
|
/**
|
|
22
24
|
* This renders the MessageInput part of the layout which includes the progress bar, the actual textarea, the badges telling what is
|
|
23
25
|
* going to be used for the question and the buttons to send, cancel, set the workspace, among others. This also includes the Quick
|
|
@@ -36,6 +38,12 @@ export const MessageInput = () => {
|
|
|
36
38
|
const agentLabel = useCurrentChatState('agent')?.label;
|
|
37
39
|
const { handleKeyDown, handleKeyUp } = useUserEntryHistoryShortcut();
|
|
38
40
|
const isTrial = checkIsTrial();
|
|
41
|
+
const { isDragging, handleDrop, handleDragLeave } = useUploadDragDrop();
|
|
42
|
+
usePasteUpload({
|
|
43
|
+
textAreaRef,
|
|
44
|
+
onUploadFiles: files => chat.uploadManager.add(files),
|
|
45
|
+
enabled: !isLoading,
|
|
46
|
+
});
|
|
39
47
|
const checkSendRequirements = useCallback(() => {
|
|
40
48
|
if (chat.uploadManager.status === 'error') {
|
|
41
49
|
chat.pushMessage(new ChatEntry({
|
|
@@ -96,6 +104,10 @@ export const MessageInput = () => {
|
|
|
96
104
|
if (!isLoading)
|
|
97
105
|
textAreaRef.current?.focus();
|
|
98
106
|
}, [isLoading]);
|
|
99
|
-
return (_jsx(UploadProvider, { value: chat.uploadManager, children: _jsxs(MessageInputBox, { "aria-busy": isLoading, className: "message-input", "$inputFocused": focused, children: [_jsxs("div", { className: "wrapper-action", children: [_jsx(QuickCommandSelector, { inputRef: textAreaRef, isTrial: isTrial }), _jsx(AgentSelector, { inputRef: textAreaRef, isTrial: isTrial }), _jsxs("div", { className: listToClass(['action-box', focused && 'focused', isLoading && 'disabled']), children: [_jsx(ButtonAgent, {}), _jsx(AdaptiveTextArea, { ref: textAreaRef, placeholder:
|
|
107
|
+
return (_jsx(UploadProvider, { value: chat.uploadManager, children: _jsxs(MessageInputBox, { "aria-busy": isLoading, className: "message-input", "$inputFocused": focused, children: [_jsxs("div", { className: "wrapper-action", children: [_jsx(QuickCommandSelector, { inputRef: textAreaRef, isTrial: isTrial }), _jsx(AgentSelector, { inputRef: textAreaRef, isTrial: isTrial }), _jsxs("div", { className: listToClass(['action-box', focused && 'focused', isLoading && 'disabled']), children: [_jsx(ButtonAgent, {}), _jsx(AdaptiveTextArea, { ref: textAreaRef, placeholder: isDragging
|
|
108
|
+
? t.uploadDragging
|
|
109
|
+
: agentLabel
|
|
110
|
+
? interpolate(t.placeholder, agentLabel)
|
|
111
|
+
: t.typing, onChange: e => chat.set('nextMessage', e.target.value), value: value, onFocus: () => setFocused(true), onBlur: () => setFocused(false), onKeyDown: onKeyDown, onKeyUp: handleKeyUp, onIncreaseSize: () => setExpanded(false), onResetSize: () => !expansionLocked.current && setExpanded(true), maxHeight: isMinimized ? MIN_INPUT_HEIGHT : MAX_INPUT_HEIGHT })] })] }), _jsx(ProgressBar, { visible: true, animate: isLoading, backgroundColor: isLoading || !focused ? theme.color.light[500] : theme.color.primary[500] }), _jsx(ContextBar, {}), chat.get('features').upload && _jsx(UploadBar, {}), _jsx(ButtonBar, { onSend: onSend, isLoading: isLoading }), _jsx(UploadDragNDrop, { isDragging: isDragging, onDrop: handleDrop, onDragLeave: handleDragLeave })] }) }));
|
|
100
112
|
};
|
|
101
113
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/views/MessageInput/index.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,0BAA0B,CAAA;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAA;AAC1D,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAChE,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAA;AACpE,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAA;AAC1D,OAAO,EAAE,cAAc,EAAE,mBAAmB,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAA;AACzF,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAA;AAC/C,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAA;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AACzD,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAA;AAC3D,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAC3C,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AACvC,OAAO,EAAE,2BAA2B,EAAE,MAAM,sBAAsB,CAAA;AAClE,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAA;AACzC,OAAO,EAAE,yBAAyB,EAAE,MAAM,cAAc,CAAA;AACxD,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAA;AAC7D,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAA;AAC9E,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/views/MessageInput/index.tsx"],"names":[],"mappings":"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"}
|
package/dist/views/Tools.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import {
|
|
2
|
+
import { agentToolsClient } from '@stack-spot/portal-network';
|
|
3
3
|
import { useTranslate } from '@stack-spot/portal-translate';
|
|
4
4
|
import { useEffect, useMemo } from 'react';
|
|
5
5
|
import styled from 'styled-components';
|
|
@@ -34,8 +34,8 @@ const ToolsPanel = () => {
|
|
|
34
34
|
const chat = widget.chatTabs.getAll().find(c => c.id === chatId);
|
|
35
35
|
return chat?.getMessages().find(m => m.id === messageId)?.getValue();
|
|
36
36
|
}, [messageId]);
|
|
37
|
-
const [
|
|
38
|
-
const tools = useMemo(() => message?.tools?.map(id => toolById(id,
|
|
37
|
+
const [toolKits] = agentToolsClient.tools.useStatefulQuery({}, { enabled: !!message?.agent?.id });
|
|
38
|
+
const tools = useMemo(() => message?.tools?.map(id => toolById(id, toolKits) ?? { id }), [messageId, toolKits]);
|
|
39
39
|
return !!tools?.length && (_jsx(ToolList, { children: tools.map((tool) => (_jsx("li", { children: _jsx(ToolBadge, { name: tool.name || tool.id, image: tool.image, description: tool.description, backgroundColor: "light.500" }) }, tool.id))) }));
|
|
40
40
|
};
|
|
41
41
|
const dictionary = {
|
package/dist/views/Tools.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Tools.js","sourceRoot":"","sources":["../../src/views/Tools.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"Tools.js","sourceRoot":"","sources":["../../src/views/Tools.tsx"],"names":[],"mappings":"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"}
|
|
@@ -28,7 +28,7 @@ export const WorkspaceResources = ({ workspaceId, allKS, agent, stack }) => {
|
|
|
28
28
|
const handleNavigate = (resource) => {
|
|
29
29
|
startTransition(() => {
|
|
30
30
|
if (resource.resourceType === 'agent')
|
|
31
|
-
navigate({ component: 'agent', props: { visibility: '
|
|
31
|
+
navigate({ component: 'agent', props: { visibility: 'workspace', agent, workspaceId, showSubmitButton }, fullScreen: true });
|
|
32
32
|
if (resource.resourceType === 'ks')
|
|
33
33
|
navigate({ component: 'ks', props: { visibility: 'workspace', allKS, workspaceId, showSubmitButton }, fullScreen: true });
|
|
34
34
|
if (resource.resourceType === 'stack')
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@stack-spot/ai-chat-widget",
|
|
3
|
-
"version": "1.28.
|
|
3
|
+
"version": "1.28.1-beta.1",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -13,7 +13,7 @@
|
|
|
13
13
|
"@citric/core": "^6.4.0",
|
|
14
14
|
"@stack-spot/portal-components": "^2.22.1",
|
|
15
15
|
"@citric/icons": "^5.13.0",
|
|
16
|
-
"@stack-spot/portal-network": "
|
|
16
|
+
"@stack-spot/portal-network": "0.149.0-beta.2",
|
|
17
17
|
"@citric/ui": "^6.10.2",
|
|
18
18
|
"@stack-spot/portal-theme": "^1.0.0",
|
|
19
19
|
"@stack-spot/portal-translate": "^1.1.0",
|
package/src/app-metadata.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@stack-spot/ai-chat-widget",
|
|
3
|
-
"version": "1.28.
|
|
4
|
-
"date": "
|
|
3
|
+
"version": "1.28.1-beta.1",
|
|
4
|
+
"date": "Wed Jul 02 2025 15:15:28 GMT-0300 (Horário Padrão de Brasília)",
|
|
5
5
|
"dependencies": [
|
|
6
6
|
{
|
|
7
7
|
"name": "@stack-spot/app-metadata",
|
|
@@ -113,7 +113,7 @@
|
|
|
113
113
|
},
|
|
114
114
|
{
|
|
115
115
|
"name": "@stack-spot/portal-network",
|
|
116
|
-
"version": "0.
|
|
116
|
+
"version": "0.149.0-beta.2(@stack-spot/auth@5.3.2)(@stack-spot/opa@2.5.0(@stack-spot/auth@5.3.2)(react-dom@18.2.0(react@18.2.0))(react@18.2.0))(@stack-spot/portal-translate@1.1.0(react-dom@18.2.0(react@18.2.0))(react@18.2.0))(@tanstack/react-query@5.59.16(react@18.2.0))(react-dom@18.2.0(react@18.2.0))(react@18.2.0)"
|
|
117
117
|
},
|
|
118
118
|
{
|
|
119
119
|
"name": "@stack-spot/portal-theme",
|
|
@@ -2,7 +2,8 @@ import { Dictionary } from '@stack-spot/portal-translate'
|
|
|
2
2
|
|
|
3
3
|
export const dictionary = {
|
|
4
4
|
en: {
|
|
5
|
-
|
|
5
|
+
'built_in': 'Built-in',
|
|
6
|
+
workspace: 'Spot',
|
|
6
7
|
personal: 'Personal',
|
|
7
8
|
account: 'Account',
|
|
8
9
|
shared: 'Shared',
|
|
@@ -10,7 +11,8 @@ export const dictionary = {
|
|
|
10
11
|
create: 'Create',
|
|
11
12
|
},
|
|
12
13
|
pt: {
|
|
13
|
-
|
|
14
|
+
'built_in': 'Embutido',
|
|
15
|
+
workspace: 'Spot',
|
|
14
16
|
personal: 'Personal',
|
|
15
17
|
account: 'Conta',
|
|
16
18
|
shared: 'Compartilhado',
|
|
@@ -2,7 +2,7 @@ import { IconBox, Text } from '@citric/core'
|
|
|
2
2
|
import { ExternalLink } from '@citric/icons'
|
|
3
3
|
import { IconButton } from '@citric/ui'
|
|
4
4
|
import { useKeyboardControls } from '@stack-spot/portal-components'
|
|
5
|
-
import {
|
|
5
|
+
import { AgentVisibilityLevel } from '@stack-spot/portal-network'
|
|
6
6
|
import { Dictionary, interpolate, useTranslate } from '@stack-spot/portal-translate'
|
|
7
7
|
import React, { FC, useCallback, useEffect, useMemo, useRef, useState } from 'react'
|
|
8
8
|
import { useCurrentChatState } from '../../context/hooks'
|
|
@@ -12,8 +12,7 @@ import { Fading } from '../Fading'
|
|
|
12
12
|
import { FallbackBoundary } from '../FallbackBoundary'
|
|
13
13
|
import { SelectorBox } from './styled'
|
|
14
14
|
|
|
15
|
-
type SectionVisibility =
|
|
16
|
-
|
|
15
|
+
type SectionVisibility = AgentVisibilityLevel
|
|
17
16
|
type SelectorShortcut = '/' | '@'
|
|
18
17
|
|
|
19
18
|
interface Item {
|
|
@@ -268,7 +267,7 @@ const dictionary = {
|
|
|
268
267
|
personal: 'Personal',
|
|
269
268
|
account: 'Account',
|
|
270
269
|
shared: 'Shared',
|
|
271
|
-
'
|
|
270
|
+
'built_in': 'Built-in',
|
|
272
271
|
workspace: 'Spot',
|
|
273
272
|
error: 'Could not load the $0s.',
|
|
274
273
|
noData: 'You don\'t have any $0 yet.',
|
|
@@ -282,7 +281,7 @@ const dictionary = {
|
|
|
282
281
|
account: 'Conta',
|
|
283
282
|
shared: 'Compartilhado',
|
|
284
283
|
workspace: 'Spot',
|
|
285
|
-
'
|
|
284
|
+
'built_in': 'Embutido',
|
|
286
285
|
error: 'Não foi possível carregar os $0s.',
|
|
287
286
|
noData: 'Você ainda não possui $0s.',
|
|
288
287
|
noResults: 'Não $0s para mostrar aqui.',
|
package/src/layout.css
CHANGED
|
@@ -94,6 +94,7 @@
|
|
|
94
94
|
}
|
|
95
95
|
|
|
96
96
|
.chat-container {
|
|
97
|
+
position: relative;
|
|
97
98
|
padding: 20px;
|
|
98
99
|
max-width: 1200px;
|
|
99
100
|
width: calc(100% - 40px);
|
|
@@ -186,4 +187,20 @@
|
|
|
186
187
|
border: 1px solid var(--primary-500);
|
|
187
188
|
border-left: none;
|
|
188
189
|
color: var(--light-contrastText);
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
.upload-drag-drop {
|
|
193
|
+
display: flex;
|
|
194
|
+
background: #00000090;
|
|
195
|
+
position: absolute;
|
|
196
|
+
width: 99%;
|
|
197
|
+
height: 99%;
|
|
198
|
+
top: 0;
|
|
199
|
+
left: 0;
|
|
200
|
+
flex-direction: column;
|
|
201
|
+
justify-content: center;
|
|
202
|
+
align-items: center;
|
|
203
|
+
border: 2px dashed var(--secondary-500);
|
|
204
|
+
z-index: 9999;
|
|
205
|
+
pointer-events: auto;
|
|
189
206
|
}
|
package/src/state/types.ts
CHANGED
package/src/utils/tools.ts
CHANGED
|
@@ -1,11 +1,9 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { BuiltinToolkitResponse, BuiltinToolResponse } from '@stack-spot/portal-network/api/agent'
|
|
2
|
+
import { keyBy } from 'lodash'
|
|
2
3
|
|
|
3
4
|
export type ToolWithImage = BuiltinToolResponse & { id: string, image?: string }
|
|
4
5
|
|
|
5
|
-
export function toolById(id: string, toolkits:
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
if (tool.id === id) return { ...tool, id, image: toolkit.image_url }
|
|
9
|
-
}
|
|
10
|
-
}
|
|
6
|
+
export function toolById(id: string, toolkits: BuiltinToolkitResponse[] | undefined): ToolWithImage | undefined {
|
|
7
|
+
const tools = toolkits?.map(({ image_url, tools }) => tools?.map((tool) => ({ ...tool, id: tool.id!, image: image_url! }))).flat()
|
|
8
|
+
return keyBy(tools, 'id')[id]
|
|
11
9
|
}
|
|
@@ -43,31 +43,35 @@ export class UploadManager {
|
|
|
43
43
|
return this.value.some(f => id === f.id)
|
|
44
44
|
}
|
|
45
45
|
|
|
46
|
+
private processFiles(files: FileList | File[]) {
|
|
47
|
+
const newFiles: FileUpload[] = []
|
|
48
|
+
const errors: UploadError[] = []
|
|
49
|
+
for (const f of files ?? []) {
|
|
50
|
+
if (this.maxSize && f.size > this.maxSize.value * Math.pow(1024, unitPower[this.maxSize?.unit])) {
|
|
51
|
+
errors.push(new FileIsTooLarge(f.name, this.maxSize))
|
|
52
|
+
} else if (this.maxItems && this.value.length + newFiles.length === this.maxItems) {
|
|
53
|
+
errors.push(new MaxFilesReached(f.name, this.maxItems))
|
|
54
|
+
} else if (this.hasEquivalentFile(f)) {
|
|
55
|
+
errors.push(new FileAlreadyExists(f.name))
|
|
56
|
+
} else {
|
|
57
|
+
const upload = new FileUpload(f)
|
|
58
|
+
newFiles.push(upload)
|
|
59
|
+
upload.onChange(() => this.runStatusListeners())
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
if (newFiles.length) {
|
|
63
|
+
this.value = [...this.value, ...newFiles]
|
|
64
|
+
this.runChangeListeners()
|
|
65
|
+
this.runStatusListeners()
|
|
66
|
+
}
|
|
67
|
+
if (errors.length) {
|
|
68
|
+
this.errorListeners.forEach(l => l(errors))
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
|
|
46
72
|
private attachEventListeners() {
|
|
47
73
|
const handleChange = () => {
|
|
48
|
-
|
|
49
|
-
const errors: UploadError[] = []
|
|
50
|
-
for (const f of this.input?.files ?? []) {
|
|
51
|
-
if (this.maxSize && f.size > this.maxSize.value * Math.pow(1024, unitPower[this.maxSize?.unit])) {
|
|
52
|
-
errors.push(new FileIsTooLarge(f.name, this.maxSize))
|
|
53
|
-
} else if (this.maxItems && this.value.length + newFiles.length === this.maxItems) {
|
|
54
|
-
errors.push(new MaxFilesReached(f.name, this.maxItems))
|
|
55
|
-
} else if (this.hasEquivalentFile(f)) {
|
|
56
|
-
errors.push(new FileAlreadyExists(f.name))
|
|
57
|
-
} else {
|
|
58
|
-
const upload = new FileUpload(f)
|
|
59
|
-
newFiles.push(upload)
|
|
60
|
-
upload.onChange(() => this.runStatusListeners())
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
if (newFiles.length) {
|
|
64
|
-
this.value = [...this.value, ...newFiles]
|
|
65
|
-
this.runChangeListeners()
|
|
66
|
-
this.runStatusListeners()
|
|
67
|
-
}
|
|
68
|
-
if (errors.length) {
|
|
69
|
-
this.errorListeners.forEach(l => l(errors))
|
|
70
|
-
}
|
|
74
|
+
this.processFiles(this.input?.files || [])
|
|
71
75
|
this.destroy()
|
|
72
76
|
}
|
|
73
77
|
this.onDestroy = () => this.input?.removeEventListener('change', handleChange)
|
|
@@ -108,6 +112,11 @@ export class UploadManager {
|
|
|
108
112
|
this.runChangeListeners()
|
|
109
113
|
}
|
|
110
114
|
|
|
115
|
+
add(files: File | File[] = []) {
|
|
116
|
+
const fileList = Array.isArray(files) ? files : [files]
|
|
117
|
+
this.processFiles(fileList)
|
|
118
|
+
}
|
|
119
|
+
|
|
111
120
|
remove(file: FileUpload) {
|
|
112
121
|
file.destroy()
|
|
113
122
|
this.value = this.value.filter(f => f !== file)
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { useEffect } from 'react'
|
|
2
|
+
|
|
3
|
+
interface UsePasteUploadProps {
|
|
4
|
+
textAreaRef: React.RefObject<HTMLTextAreaElement>,
|
|
5
|
+
onUploadFiles: (files: File[]) => void,
|
|
6
|
+
enabled?: boolean,
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export const usePasteUpload = ({
|
|
10
|
+
textAreaRef,
|
|
11
|
+
onUploadFiles,
|
|
12
|
+
enabled = true,
|
|
13
|
+
}: UsePasteUploadProps) => {
|
|
14
|
+
useEffect(() => {
|
|
15
|
+
const textarea = textAreaRef.current
|
|
16
|
+
if (!textarea || !enabled) return
|
|
17
|
+
|
|
18
|
+
const handlePaste = (e: ClipboardEvent) => {
|
|
19
|
+
if (e.clipboardData?.files?.length) {
|
|
20
|
+
onUploadFiles(Array.from(e.clipboardData.files))
|
|
21
|
+
e.preventDefault()
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
textarea.addEventListener('paste', handlePaste)
|
|
26
|
+
return () => {
|
|
27
|
+
textarea.removeEventListener('paste', handlePaste)
|
|
28
|
+
}
|
|
29
|
+
}, [onUploadFiles, textAreaRef, enabled])
|
|
30
|
+
}
|
|
@@ -1,29 +1,21 @@
|
|
|
1
1
|
import { Text } from '@citric/core'
|
|
2
2
|
import { Badge, Skeleton } from '@citric/ui'
|
|
3
|
-
import {
|
|
3
|
+
import { agentToolsClient } from '@stack-spot/portal-network'
|
|
4
4
|
import { useMemo } from 'react'
|
|
5
5
|
import { ToolBadge } from '../../components/ToolBadge'
|
|
6
|
+
import { toolById } from '../../utils/tools'
|
|
6
7
|
import { useAgentsDictionary } from './dictionary'
|
|
7
8
|
import { AgentDescriptionBox } from './styled'
|
|
8
9
|
|
|
9
|
-
|
|
10
|
-
agentId?: string,
|
|
11
|
-
llm?: string,
|
|
12
|
-
description?: string,
|
|
13
|
-
numberOfKnowledgeSources: number,
|
|
14
|
-
visibility: AgentVisibilityLevel,
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
export const AgentDescription = ({ agentId, llm, description, numberOfKnowledgeSources, visibility }: Props) => {
|
|
10
|
+
export const AgentDescription = ({ agentId }: { agentId?: string }) => {
|
|
18
11
|
const t = useAgentsDictionary()
|
|
19
|
-
const [agent, , , { isLoading }] =
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
)
|
|
12
|
+
const [agent, , , { isLoading }] = agentToolsClient.agent.useStatefulQuery({ agentId: agentId! }, { enabled: !!agentId })
|
|
13
|
+
const [toolKits, , , { isLoading: isLoadingToolKit }] = agentToolsClient.tools.useStatefulQuery({})
|
|
14
|
+
const numberOfKnowledgeSources = agent?.knowledge_source_config?.knowledge_sources.length ?? 0
|
|
23
15
|
|
|
24
16
|
const knowledgeSources = useMemo(
|
|
25
|
-
() => agent?.
|
|
26
|
-
<li key={index}><Badge palette="teal" appearance="square">{ks
|
|
17
|
+
() => agent?.knowledge_source_config?.knowledge_sources?.map((ks, index) => (
|
|
18
|
+
<li key={index}><Badge palette="teal" appearance="square">{ks}</Badge></li>
|
|
27
19
|
)),
|
|
28
20
|
[agent],
|
|
29
21
|
)
|
|
@@ -36,31 +28,33 @@ export const AgentDescription = ({ agentId, llm, description, numberOfKnowledgeS
|
|
|
36
28
|
}, [numberOfKnowledgeSources])
|
|
37
29
|
const tools = useMemo(() => {
|
|
38
30
|
const result: React.ReactElement[] = []
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
}
|
|
31
|
+
const builtInTools = agent?.toolkits?.builtin_toolkits?.[0].tools
|
|
32
|
+
for (const tool of builtInTools ?? []) {
|
|
33
|
+
const toolWithImage = toolById(tool.id, toolKits)
|
|
34
|
+
result.push(<li key={tool.id}>
|
|
35
|
+
<ToolBadge name={toolWithImage?.name || toolWithImage?.id || 'unknown'} image={toolWithImage?.image} />
|
|
36
|
+
</li>)
|
|
43
37
|
}
|
|
44
38
|
return result
|
|
45
39
|
}, [agent])
|
|
46
40
|
|
|
47
41
|
return (
|
|
48
42
|
<AgentDescriptionBox>
|
|
49
|
-
{description && <section>
|
|
43
|
+
{agent?.description && <section>
|
|
50
44
|
<Text appearance="microtext1" className="title">{t.description}</Text>
|
|
51
|
-
<Text>{description}</Text>
|
|
45
|
+
<Text>{agent?.description}</Text>
|
|
52
46
|
</section>}
|
|
53
47
|
{(!!numberOfKnowledgeSources || !!knowledgeSources?.length) && <section>
|
|
54
48
|
<Text appearance="microtext1" className="title">Knowledge sources</Text>
|
|
55
|
-
<ul>{isLoading ? skeleton : knowledgeSources}</ul>
|
|
49
|
+
<ul>{isLoading || isLoadingToolKit ? skeleton : knowledgeSources}</ul>
|
|
56
50
|
</section>}
|
|
57
51
|
{!!tools.length && <section>
|
|
58
52
|
<Text appearance="microtext1" className="title">{t.tools}</Text>
|
|
59
53
|
<ul>{tools}</ul>
|
|
60
54
|
</section>}
|
|
61
|
-
{
|
|
55
|
+
{agent?.model_name && <section>
|
|
62
56
|
<Text appearance="microtext1" className="title">LLM</Text>
|
|
63
|
-
<Badge palette="orange" appearance="square">{
|
|
57
|
+
<Badge palette="orange" appearance="square">{agent?.model_name}</Badge>
|
|
64
58
|
</section>}
|
|
65
59
|
</AgentDescriptionBox>
|
|
66
60
|
)
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { agentToolsClient } from '@stack-spot/portal-network'
|
|
1
2
|
import { useEffect, useMemo, useRef } from 'react'
|
|
2
3
|
import { RightPanelTabs } from '../../components/RightPanelTabs'
|
|
3
4
|
import { useCurrentChat } from '../../context/hooks'
|
|
@@ -5,8 +6,6 @@ import { checkIsTrial } from '../../utils/check-is-trial'
|
|
|
5
6
|
import { AgentsTab, AgentsTabWorkspace } from './AgentsTab'
|
|
6
7
|
import { useAgentsDictionary } from './dictionary'
|
|
7
8
|
|
|
8
|
-
const agentDefaultSlug = 'stk_code_buddy'
|
|
9
|
-
|
|
10
9
|
/**
|
|
11
10
|
* Renders the Agent selection form in the Right Panel if this is the panel that is currently opened.
|
|
12
11
|
*/
|
|
@@ -17,22 +16,22 @@ export const AgentsPanel = () => {
|
|
|
17
16
|
const agent = useRef(chat.get('agent'))
|
|
18
17
|
|
|
19
18
|
useEffect(() => {
|
|
20
|
-
if (agentDefaultSlug !== chat.get('agent')?.slug) {
|
|
19
|
+
if (agentToolsClient.agentDefaultSlug !== chat.get('agent')?.slug) {
|
|
21
20
|
agent.current = chat.get('agent')
|
|
22
21
|
}
|
|
23
22
|
}, [chat])
|
|
24
23
|
|
|
25
24
|
const tabs= useMemo(() => isTrial ? [
|
|
26
|
-
{ title: t.favorites, content: <AgentsTab key="favorite" visibility="
|
|
27
|
-
{ title: t.builtin, content: <AgentsTab key="builtin" visibility="
|
|
28
|
-
{ title: t.personal, content: <AgentsTab key="personal" visibility="
|
|
25
|
+
{ title: t.favorites, content: <AgentsTab key="favorite" visibility="favorite" agent={agent} /> },
|
|
26
|
+
{ title: t.builtin, content: <AgentsTab key="builtin" visibility="built_in" agent={agent} /> },
|
|
27
|
+
{ title: t.personal, content: <AgentsTab key="personal" visibility="personal" agent={agent} /> },
|
|
29
28
|
]: [
|
|
30
|
-
{ title: t.favorites, content: <AgentsTab key="favorite" visibility="
|
|
31
|
-
{ title: t.builtin, content: <AgentsTab key="builtin" visibility="
|
|
32
|
-
{ title: t.personal, content: <AgentsTab key="personal" visibility="
|
|
33
|
-
{ title: t.shared, content: <AgentsTab key="shared" visibility="
|
|
34
|
-
{ title: t.spots, content: <AgentsTabWorkspace key="workspace" visibility="
|
|
35
|
-
{ title: t.account, content: <AgentsTab key="account" visibility="
|
|
29
|
+
{ title: t.favorites, content: <AgentsTab key="favorite" visibility="favorite" agent={agent} /> },
|
|
30
|
+
{ title: t.builtin, content: <AgentsTab key="builtin" visibility="built_in" agent={agent} /> },
|
|
31
|
+
{ title: t.personal, content: <AgentsTab key="personal" visibility="personal" agent={agent} /> },
|
|
32
|
+
{ title: t.shared, content: <AgentsTab key="shared" visibility="shared" agent={agent} /> },
|
|
33
|
+
{ title: t.spots, content: <AgentsTabWorkspace key="workspace" visibility="workspace" agent={agent} /> },
|
|
34
|
+
{ title: t.account, content: <AgentsTab key="account" visibility="account" agent={agent} /> },
|
|
36
35
|
|
|
37
36
|
], [t, isTrial, agent])
|
|
38
37
|
|
|
@@ -2,8 +2,7 @@ import { Button, IconBox, Text } from '@citric/core'
|
|
|
2
2
|
import { Agent, Search } from '@citric/icons'
|
|
3
3
|
import { Placeholder } from '@stack-spot/portal-components/Placeholder'
|
|
4
4
|
import { MiniLogo } from '@stack-spot/portal-components/svg'
|
|
5
|
-
import {
|
|
6
|
-
import { VisibilityLevel } from '@stack-spot/portal-network/api/agent'
|
|
5
|
+
import { AgentResponseWithBuiltIn, agentToolsClient, AgentVisibilityLevel, workspaceAiClient } from '@stack-spot/portal-network'
|
|
7
6
|
import { WorkspaceResponse } from '@stack-spot/portal-network/api/workspace-ai'
|
|
8
7
|
import { useCallback, useMemo, useState } from 'react'
|
|
9
8
|
import { ButtonFavorite } from '../../components/ButtonFavorite'
|
|
@@ -20,7 +19,7 @@ import { AgentLabel } from './styled'
|
|
|
20
19
|
import { useAgentFavorites } from './useAgentFavorites'
|
|
21
20
|
|
|
22
21
|
export interface AgentTabProps {
|
|
23
|
-
visibility:
|
|
22
|
+
visibility: AgentVisibilityLevel,
|
|
24
23
|
workspaceId?: string,
|
|
25
24
|
agent: React.MutableRefObject<ChatProperties['agent']>,
|
|
26
25
|
showSubmitButton?: boolean,
|
|
@@ -33,16 +32,15 @@ export const AgentsTab = ({ visibility, workspaceId, agent, showSubmitButton = t
|
|
|
33
32
|
const [filter, setFilter] = useState('')
|
|
34
33
|
const { useFavorites, onAddFavorite, onRemoveFavorite } = useAgentFavorites()
|
|
35
34
|
const listFavorites = useFavorites()
|
|
36
|
-
const agentDefault =
|
|
35
|
+
const agentDefault = agentToolsClient.agentDefault.useQuery()
|
|
37
36
|
const agents = workspaceId
|
|
38
|
-
? workspaceAiClient.getAgentFromWorkspaceAi.useQuery({ workspaceId })
|
|
39
|
-
:
|
|
40
|
-
|
|
37
|
+
? workspaceAiClient.getAgentFromWorkspaceAi.useQuery({ workspaceId }) as AgentResponseWithBuiltIn[]
|
|
38
|
+
: agentToolsClient.agents.useQuery({ visibility })
|
|
41
39
|
|
|
42
40
|
const [value, setValue] = useState<AgentResponseWithBuiltIn | undefined>(
|
|
43
41
|
agent.current
|
|
44
42
|
? agents.find(a => a.id === agent.current?.id)
|
|
45
|
-
: chat.get('agent') ? agents.find(a => a.id === chat.get('agent')?.id) : agentDefault,
|
|
43
|
+
: chat.get('agent') ? agents.find(a => a.id === chat.get('agent')?.id) : agentDefault as unknown as AgentResponseWithBuiltIn,
|
|
46
44
|
)
|
|
47
45
|
|
|
48
46
|
const filtered = useMemo(
|
|
@@ -53,14 +51,17 @@ export const AgentsTab = ({ visibility, workspaceId, agent, showSubmitButton = t
|
|
|
53
51
|
|
|
54
52
|
function submit() {
|
|
55
53
|
if (value) {
|
|
56
|
-
chat.set(
|
|
54
|
+
chat.set(
|
|
55
|
+
'agent',
|
|
56
|
+
{ id: value.id, label: value.name, image: value.avatar!, builtIn: value.visibility_level === 'built_in', slug: value.slug },
|
|
57
|
+
)
|
|
57
58
|
}
|
|
58
59
|
close()
|
|
59
60
|
}
|
|
60
61
|
|
|
61
62
|
const onChange = useCallback((newValue: AgentResponseWithBuiltIn) => {
|
|
62
63
|
setValue(newValue)
|
|
63
|
-
agent.current = { ...newValue, label: newValue.name, builtIn:
|
|
64
|
+
agent.current = { ...newValue, label: newValue.name, builtIn: newValue.visibility_level === 'built_in' }
|
|
64
65
|
}, [])
|
|
65
66
|
|
|
66
67
|
return (
|
|
@@ -83,13 +84,7 @@ export const AgentsTab = ({ visibility, workspaceId, agent, showSubmitButton = t
|
|
|
83
84
|
<Text>{name}</Text>
|
|
84
85
|
</AgentLabel>
|
|
85
86
|
)}
|
|
86
|
-
renderDescription={a => <AgentDescription
|
|
87
|
-
agentId={a.id}
|
|
88
|
-
visibility={visibility}
|
|
89
|
-
description={a.description}
|
|
90
|
-
llm={a.llm_config?.model_slug}
|
|
91
|
-
numberOfKnowledgeSources={a.knowledge_sources_config?.knowledge_sources?.length ?? 0}
|
|
92
|
-
/>}
|
|
87
|
+
renderDescription={a => <AgentDescription agentId={a.id} />}
|
|
93
88
|
optionClassName={a => (a === value && filter && !a.name.toLocaleLowerCase().includes(filter.toLocaleLowerCase()))
|
|
94
89
|
? 'filtered-out'
|
|
95
90
|
: ''
|