@stack-spot/ai-chat-widget 1.1.1 → 1.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +16 -0
- package/dist/StackspotAIWidget.d.ts +1 -12
- package/dist/StackspotAIWidget.d.ts.map +1 -1
- package/dist/StackspotAIWidget.js +5 -18
- package/dist/StackspotAIWidget.js.map +1 -1
- package/dist/chat-interceptors/quick-commands.js +1 -1
- package/dist/chat-interceptors/quick-commands.js.map +1 -1
- package/dist/chat-interceptors/send-message.d.ts.map +1 -1
- package/dist/chat-interceptors/send-message.js +21 -2
- package/dist/chat-interceptors/send-message.js.map +1 -1
- package/dist/components/AutoFocus.d.ts.map +1 -1
- package/dist/components/AutoFocus.js +8 -1
- package/dist/components/AutoFocus.js.map +1 -1
- package/dist/components/FadingOverflow.js +2 -2
- package/dist/components/FadingOverflow.js.map +1 -1
- package/dist/components/QuickStartButton.d.ts +6 -1
- package/dist/components/QuickStartButton.d.ts.map +1 -1
- package/dist/components/QuickStartButton.js +6 -2
- package/dist/components/QuickStartButton.js.map +1 -1
- package/dist/components/RightPanelForm.d.ts.map +1 -1
- package/dist/components/RightPanelForm.js +2 -1
- package/dist/components/RightPanelForm.js.map +1 -1
- package/dist/context/hooks.d.ts +2 -7
- package/dist/context/hooks.d.ts.map +1 -1
- package/dist/context/hooks.js +4 -16
- package/dist/context/hooks.js.map +1 -1
- package/dist/features.d.ts +16 -17
- package/dist/features.d.ts.map +1 -1
- package/dist/features.js +17 -9
- package/dist/features.js.map +1 -1
- package/dist/index.d.ts +4 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -0
- package/dist/index.js.map +1 -1
- package/dist/layout.css +7 -0
- package/dist/state/ChatState.d.ts +23 -3
- package/dist/state/ChatState.d.ts.map +1 -1
- package/dist/state/ChatState.js +5 -2
- package/dist/state/ChatState.js.map +1 -1
- package/dist/state/ChatTabsController.d.ts +21 -3
- package/dist/state/ChatTabsController.d.ts.map +1 -1
- package/dist/state/ChatTabsController.js +49 -11
- package/dist/state/ChatTabsController.js.map +1 -1
- package/dist/state/WidgetState.d.ts +50 -1
- package/dist/state/WidgetState.d.ts.map +1 -1
- package/dist/state/WidgetState.js +55 -2
- package/dist/state/WidgetState.js.map +1 -1
- package/dist/utils/chat.d.ts +1 -8
- package/dist/utils/chat.d.ts.map +1 -1
- package/dist/utils/chat.js +0 -15
- package/dist/utils/chat.js.map +1 -1
- package/dist/views/Agents/AgentDescription.d.ts +9 -0
- package/dist/views/Agents/AgentDescription.d.ts.map +1 -0
- package/dist/views/Agents/AgentDescription.js +21 -0
- package/dist/views/Agents/AgentDescription.js.map +1 -0
- package/dist/views/Agents/AgentsPanel.d.ts +5 -0
- package/dist/views/Agents/AgentsPanel.d.ts.map +1 -0
- package/dist/views/Agents/AgentsPanel.js +19 -0
- package/dist/views/Agents/AgentsPanel.js.map +1 -0
- package/dist/views/Agents/AgentsTab.d.ts +5 -0
- package/dist/views/Agents/AgentsTab.d.ts.map +1 -0
- package/dist/views/Agents/AgentsTab.js +43 -0
- package/dist/views/Agents/AgentsTab.js.map +1 -0
- package/dist/views/Agents/dictionary.d.ts +2 -0
- package/dist/views/Agents/dictionary.d.ts.map +1 -0
- package/dist/views/Agents/dictionary.js +35 -0
- package/dist/views/Agents/dictionary.js.map +1 -0
- package/dist/views/Agents/index.d.ts +5 -0
- package/dist/views/Agents/index.d.ts.map +1 -0
- package/dist/views/Agents/index.js +21 -0
- package/dist/views/Agents/index.js.map +1 -0
- package/dist/views/Agents/styled.d.ts +3 -0
- package/dist/views/Agents/styled.d.ts.map +1 -0
- package/dist/views/Agents/styled.js +58 -0
- package/dist/views/Agents/styled.js.map +1 -0
- package/dist/views/Chat/ChatMessage.d.ts.map +1 -1
- package/dist/views/Chat/ChatMessage.js +1 -1
- package/dist/views/Chat/ChatMessage.js.map +1 -1
- package/dist/views/Chat/index.js +1 -1
- package/dist/views/Chat/index.js.map +1 -1
- package/dist/views/Chat/styled.js +1 -1
- package/dist/views/ChatHistory/ChatHistoryPanel.d.ts +1 -4
- package/dist/views/ChatHistory/ChatHistoryPanel.d.ts.map +1 -1
- package/dist/views/ChatHistory/ChatHistoryPanel.js +2 -2
- package/dist/views/ChatHistory/ChatHistoryPanel.js.map +1 -1
- package/dist/views/ChatHistory/HistoryItem.d.ts +1 -3
- package/dist/views/ChatHistory/HistoryItem.d.ts.map +1 -1
- package/dist/views/ChatHistory/HistoryItem.js +2 -2
- package/dist/views/ChatHistory/HistoryItem.js.map +1 -1
- package/dist/views/ChatHistory/index.d.ts +1 -9
- package/dist/views/ChatHistory/index.d.ts.map +1 -1
- package/dist/views/ChatHistory/index.js +2 -2
- package/dist/views/ChatHistory/index.js.map +1 -1
- package/dist/views/ChatTabSelection.d.ts +1 -7
- package/dist/views/ChatTabSelection.d.ts.map +1 -1
- package/dist/views/ChatTabSelection.js +7 -7
- package/dist/views/ChatTabSelection.js.map +1 -1
- package/dist/views/Editor.d.ts.map +1 -1
- package/dist/views/Editor.js +4 -1
- package/dist/views/Editor.js.map +1 -1
- package/dist/views/Home/BuiltInAgent.d.ts +6 -0
- package/dist/views/Home/BuiltInAgent.d.ts.map +1 -0
- package/dist/views/{Home.js → Home/BuiltInAgent.js} +7 -41
- package/dist/views/Home/BuiltInAgent.js.map +1 -0
- package/dist/views/Home/CustomAgent.d.ts +5 -0
- package/dist/views/Home/CustomAgent.d.ts.map +1 -0
- package/dist/views/Home/CustomAgent.js +24 -0
- package/dist/views/Home/CustomAgent.js.map +1 -0
- package/dist/views/Home/index.d.ts +8 -0
- package/dist/views/Home/index.d.ts.map +1 -0
- package/dist/views/Home/index.js +15 -0
- package/dist/views/Home/index.js.map +1 -0
- package/dist/views/Home/styled.d.ts +2 -0
- package/dist/views/Home/styled.d.ts.map +1 -0
- package/dist/views/Home/styled.js +59 -0
- package/dist/views/Home/styled.js.map +1 -0
- package/dist/views/Home/types.d.ts +7 -0
- package/dist/views/Home/types.d.ts.map +1 -0
- package/dist/views/Home/types.js +2 -0
- package/dist/views/Home/types.js.map +1 -0
- package/dist/views/KnowledgeSources.js +1 -1
- package/dist/views/KnowledgeSources.js.map +1 -1
- package/dist/views/MessageInput/ButtonGroup.d.ts +1 -6
- package/dist/views/MessageInput/ButtonGroup.d.ts.map +1 -1
- package/dist/views/MessageInput/ButtonGroup.js +12 -4
- package/dist/views/MessageInput/ButtonGroup.js.map +1 -1
- package/dist/views/MessageInput/InfoBar.d.ts.map +1 -1
- package/dist/views/MessageInput/InfoBar.js +16 -6
- package/dist/views/MessageInput/InfoBar.js.map +1 -1
- package/dist/views/MessageInput/QuickCommandSelector.d.ts.map +1 -1
- package/dist/views/MessageInput/QuickCommandSelector.js +2 -1
- package/dist/views/MessageInput/QuickCommandSelector.js.map +1 -1
- package/dist/views/MessageInput/dictionary.d.ts +1 -1
- package/dist/views/MessageInput/index.d.ts +1 -9
- package/dist/views/MessageInput/index.d.ts.map +1 -1
- package/dist/views/MessageInput/index.js +2 -2
- package/dist/views/MessageInput/index.js.map +1 -1
- package/dist/views/MessageInput/styled.d.ts.map +1 -1
- package/dist/views/MessageInput/styled.js +6 -2
- package/dist/views/MessageInput/styled.js.map +1 -1
- package/dist/views/MinimizedHeader.d.ts.map +1 -1
- package/dist/views/MinimizedHeader.js +2 -3
- package/dist/views/MinimizedHeader.js.map +1 -1
- package/dist/views/Stacks.js +2 -1
- package/dist/views/Stacks.js.map +1 -1
- package/dist/views/Workspaces.js +2 -1
- package/dist/views/Workspaces.js.map +1 -1
- package/package.json +2 -2
- package/src/StackspotAIWidget.tsx +6 -32
- package/src/chat-interceptors/quick-commands.ts +1 -1
- package/src/chat-interceptors/send-message.ts +22 -2
- package/src/components/AutoFocus.tsx +9 -1
- package/src/components/FadingOverflow.tsx +2 -2
- package/src/components/QuickStartButton.tsx +17 -5
- package/src/components/RightPanelForm.tsx +2 -1
- package/src/context/hooks.ts +8 -20
- package/src/features.ts +27 -24
- package/src/index.ts +6 -0
- package/src/layout.css +7 -0
- package/src/state/ChatState.ts +26 -4
- package/src/state/ChatTabsController.ts +50 -11
- package/src/state/WidgetState.ts +88 -2
- package/src/utils/chat.ts +1 -18
- package/src/views/Agents/AgentDescription.tsx +48 -0
- package/src/views/Agents/AgentsPanel.tsx +19 -0
- package/src/views/Agents/AgentsTab.tsx +80 -0
- package/src/views/Agents/dictionary.ts +36 -0
- package/src/views/Agents/index.tsx +26 -0
- package/src/views/Agents/styled.ts +59 -0
- package/src/views/Chat/ChatMessage.tsx +19 -17
- package/src/views/Chat/index.tsx +1 -1
- package/src/views/Chat/styled.ts +1 -1
- package/src/views/ChatHistory/ChatHistoryPanel.tsx +2 -3
- package/src/views/ChatHistory/HistoryItem.tsx +3 -3
- package/src/views/ChatHistory/index.tsx +2 -10
- package/src/views/ChatTabSelection.tsx +8 -13
- package/src/views/Editor.tsx +4 -1
- package/src/views/{Home.tsx → Home/BuiltInAgent.tsx} +7 -48
- package/src/views/Home/CustomAgent.tsx +39 -0
- package/src/views/Home/index.tsx +20 -0
- package/src/views/Home/styled.ts +59 -0
- package/src/views/Home/types.ts +6 -0
- package/src/views/KnowledgeSources.tsx +2 -2
- package/src/views/MessageInput/ButtonGroup.tsx +15 -12
- package/src/views/MessageInput/InfoBar.tsx +25 -9
- package/src/views/MessageInput/QuickCommandSelector.tsx +2 -1
- package/src/views/MessageInput/index.tsx +1 -10
- package/src/views/MessageInput/styled.ts +6 -2
- package/src/views/MinimizedHeader.tsx +2 -3
- package/src/views/Stacks.tsx +3 -2
- package/src/views/Workspaces.tsx +3 -2
- package/dist/views/Agents.d.ts +0 -2
- package/dist/views/Agents.d.ts.map +0 -1
- package/dist/views/Agents.js +0 -146
- package/dist/views/Agents.js.map +0 -1
- package/dist/views/Home.d.ts +0 -14
- package/dist/views/Home.d.ts.map +0 -1
- package/dist/views/Home.js.map +0 -1
- package/src/views/Agents.tsx +0 -203
|
@@ -11,6 +11,7 @@ export const MessageInputBox = styled.div `
|
|
|
11
11
|
|
|
12
12
|
> .info-bar {
|
|
13
13
|
margin-top: 8px;
|
|
14
|
+
margin-bottom: -3px;
|
|
14
15
|
position: relative;
|
|
15
16
|
overflow: hidden;
|
|
16
17
|
|
|
@@ -33,15 +34,18 @@ export const MessageInputBox = styled.div `
|
|
|
33
34
|
border-top-left-radius: 10px;
|
|
34
35
|
border-top-right-radius: 10px;
|
|
35
36
|
height: ${INFO_BAR_HEIGHT}px;
|
|
36
|
-
padding:
|
|
37
|
+
padding: 6px 4px 0;
|
|
37
38
|
background-color: ${theme.color.light[500]};
|
|
38
39
|
display: flex;
|
|
39
40
|
flex-direction: row;
|
|
40
|
-
align-items: center;
|
|
41
41
|
gap: 6px;
|
|
42
42
|
|
|
43
43
|
.list-overflow {
|
|
44
44
|
max-width: calc(100% - 30px); // close button + gap
|
|
45
|
+
height: 24px;
|
|
46
|
+
&:first-child {
|
|
47
|
+
margin-left: 0.25rem; // space added to the left when the close all button isn't rendered
|
|
48
|
+
}
|
|
45
49
|
}
|
|
46
50
|
|
|
47
51
|
ul {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"styled.js","sourceRoot":"","sources":["../../../src/views/MessageInput/styled.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAA;AACvC,OAAO,EAAE,KAAK,EAAE,MAAM,0BAA0B,CAAA;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAE1C,MAAM,eAAe,GAAG,EAAE,CAAA;AAC1B,MAAM,qBAAqB,GAAG,CAAC,CAAA;AAC/B,MAAM,CAAC,MAAM,gBAAgB,GAAG,GAAG,CAAA;AACnC,MAAM,CAAC,MAAM,gBAAgB,GAAG,EAAE,CAAA;AAElC,MAAM,CAAC,MAAM,eAAe,GAAG,MAAM,CAAC,GAAG,CAAA
|
|
1
|
+
{"version":3,"file":"styled.js","sourceRoot":"","sources":["../../../src/views/MessageInput/styled.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAA;AACvC,OAAO,EAAE,KAAK,EAAE,MAAM,0BAA0B,CAAA;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAE1C,MAAM,eAAe,GAAG,EAAE,CAAA;AAC1B,MAAM,qBAAqB,GAAG,CAAC,CAAA;AAC/B,MAAM,CAAC,MAAM,gBAAgB,GAAG,GAAG,CAAA;AACnC,MAAM,CAAC,MAAM,gBAAgB,GAAG,EAAE,CAAA;AAElC,MAAM,CAAC,MAAM,eAAe,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;;;;;;;;kBAYvB,eAAe,GAAG,qBAAqB;;;;;;;;;;;;;;;;gBAgBzC,eAAe;;0BAEL,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UA+BtC,UAAU;;;;;;;;;;;;;;;;;;;;;;;wBAuBI,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;wBACtB,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;;;;;sBAKxB,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC;;;;0BAIpB,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;;;;;;;;;;;;;;;;;;;;gBAoBhC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;;;;;;4BAMV,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;;;;4BAItB,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC;;;;;kBAKlC,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;MAmD5C,UAAU;;;;;;;;;;;cAWF,gBAAgB;;;;;;;;;;;;wBAYN,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;wBACtB,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBA0D7B,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;;;;;;;;;;;;;;8BAcT,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;;;;mCAIjB,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY;mBAC9C,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY;;;;;;;;;;;;;;;;;;;;;;;8BAuBnB,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;;;;;;;;;;;;;;;;qBAgB/B,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY;;;;;;;qBAO9B,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;;;;;;;;CAQ1C,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MinimizedHeader.d.ts","sourceRoot":"","sources":["../../src/views/MinimizedHeader.tsx"],"names":[],"mappings":"AASA,OAAO,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAA;AAwC3C;;;GAGG;AACH,eAAO,MAAM,eAAe,sCAAuC,gBAAgB,
|
|
1
|
+
{"version":3,"file":"MinimizedHeader.d.ts","sourceRoot":"","sources":["../../src/views/MinimizedHeader.tsx"],"names":[],"mappings":"AASA,OAAO,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAA;AAwC3C;;;GAGG;AACH,eAAO,MAAM,eAAe,sCAAuC,gBAAgB,4CA6BlF,CAAA"}
|
|
@@ -7,7 +7,7 @@ import { useTranslate } from '@stack-spot/portal-translate';
|
|
|
7
7
|
import { useCallback, useRef, useState } from 'react';
|
|
8
8
|
import { styled } from 'styled-components';
|
|
9
9
|
import { FadingOverflow } from '../components/FadingOverflow.js';
|
|
10
|
-
import {
|
|
10
|
+
import { useCurrentChatState } from '../context/hooks.js';
|
|
11
11
|
const Header = styled.header `
|
|
12
12
|
display: flex;
|
|
13
13
|
flex-direction: row;
|
|
@@ -51,8 +51,7 @@ const Header = styled.header `
|
|
|
51
51
|
*/
|
|
52
52
|
export const MinimizedHeader = ({ onClose, onCollapse, onExpand }) => {
|
|
53
53
|
const t = useTranslate(dictionary);
|
|
54
|
-
const
|
|
55
|
-
const label = useChatState(active, 'label');
|
|
54
|
+
const label = useCurrentChatState('label');
|
|
56
55
|
const [collapsed, setCollapsed] = useState(false);
|
|
57
56
|
const ref = useRef(null);
|
|
58
57
|
const showButtons = onClose || onCollapse || onExpand;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MinimizedHeader.js","sourceRoot":"","sources":["../../src/views/MinimizedHeader.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAA;AACnC,OAAO,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAA;AACvC,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAA;AACtD,OAAO,EAAc,YAAY,EAAE,MAAM,8BAA8B,CAAA;AACvE,OAAO,EAAE,WAAW,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AACrD,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAC1C,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAA;AAC7D,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"MinimizedHeader.js","sourceRoot":"","sources":["../../src/views/MinimizedHeader.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAA;AACnC,OAAO,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAA;AACvC,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAA;AACtD,OAAO,EAAc,YAAY,EAAE,MAAM,8BAA8B,CAAA;AACvE,OAAO,EAAE,WAAW,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AACrD,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAC1C,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAA;AAC7D,OAAO,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAA;AAGtD,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAoC3B,CAAA;AAED;;;GAGG;AACH,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAoB,EAAE,EAAE;IACrF,MAAM,CAAC,GAAG,YAAY,CAAC,UAAU,CAAC,CAAA;IAClC,MAAM,KAAK,GAAG,mBAAmB,CAAC,OAAO,CAAC,CAAA;IAC1C,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IACjD,MAAM,GAAG,GAAG,MAAM,CAAc,IAAI,CAAC,CAAA;IACrC,MAAM,WAAW,GAAG,OAAO,IAAI,UAAU,IAAI,QAAQ,CAAA;IAErD,MAAM,eAAe,GAAG,WAAW,CAAC,GAAG,EAAE;QACvC,IAAI,SAAS;YAAE,QAAQ,EAAE,EAAE,CAAA;;YACtB,UAAU,EAAE,EAAE,CAAA;QACnB,YAAY,CAAC,CAAC,SAAS,CAAC,CAAA;IAC1B,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAA;IAEf,OAAO,CACL,MAAC,MAAM,IAAC,GAAG,EAAE,GAAG,EAAE,SAAS,EAAC,kBAAkB,aAC5C,KAAC,cAAc,IAAC,SAAS,EAAC,OAAO,YAAC,KAAC,IAAI,IAAC,KAAK,EAAE,KAAK,YAAG,KAAK,GAAQ,GAAiB,EACpF,WAAW,IAAI,eAAK,SAAS,EAAC,cAAc,aAC1C,CAAC,QAAQ,IAAI,UAAU,CAAC,IAAI,KAAC,UAAU,IACtC,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,gBAC5B,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,EAC7C,SAAS,EAAE,WAAW,CAAC,CAAC,UAAU,EAAE,SAAS,IAAI,WAAW,CAAC,CAAC,EAC9D,OAAO,EAAE,eAAe,YAExB,KAAC,WAAW,KAAG,GACJ,EACZ,OAAO,IAAI,KAAC,UAAU,IAAC,KAAK,EAAE,CAAC,CAAC,KAAK,gBAAc,CAAC,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,YAAE,KAAC,KAAK,KAAG,GAAa,IACjG,IACC,CACV,CAAA;AACH,CAAC,CAAA;AAED,MAAM,UAAU,GAAG;IACjB,EAAE,EAAE;QACF,QAAQ,EAAE,UAAU;QACpB,MAAM,EAAE,QAAQ;QAChB,KAAK,EAAE,OAAO;KACf;IACD,EAAE,EAAE;QACF,QAAQ,EAAE,WAAW;QACrB,MAAM,EAAE,UAAU;QAClB,KAAK,EAAE,QAAQ;KAChB;CACmB,CAAA"}
|
package/dist/views/Stacks.js
CHANGED
|
@@ -48,7 +48,8 @@ const StacksTab = ({ visibility }) => {
|
|
|
48
48
|
}
|
|
49
49
|
return (_jsxs(_Fragment, { children: [_jsxs("div", { className: "content", children: [_jsx(IconInput, { icon: _jsx(Search, {}), value: filter, onChange: setFilter, className: "search" }), !!filtered.length && _jsx(DescribedRadioGroup, { options: filtered, keygen: s => s.id, value: value, onChange: setValue, renderLabel: s => s.name, renderDescription: s => s.use_case, optionClassName: s => (s === value && filter && !s.name.toLocaleLowerCase().includes(filter.toLocaleLowerCase()))
|
|
50
50
|
? 'filtered-out'
|
|
51
|
-
: '', className: "option-list" }), !!stacks.length && !filtered.length &&
|
|
51
|
+
: '', className: "option-list" }), !!stacks.length && !filtered.length &&
|
|
52
|
+
_jsx(Placeholder, { title: t.noSearchResults, description: t.noSearchResultsDescription, className: "no-data-placeholder" }), !stacks.length && _jsx(Placeholder, { title: t.noData, description: t.noDataDescription })] }), !!filtered.length && _jsx(Button, { onClick: submit, disabled: !value, children: t.apply })] }));
|
|
52
53
|
};
|
|
53
54
|
const dictionary = {
|
|
54
55
|
en: {
|
package/dist/views/Stacks.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Stacks.js","sourceRoot":"","sources":["../../src/views/Stacks.tsx"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"Stacks.js","sourceRoot":"","sources":["../../src/views/Stacks.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AACrC,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAA;AACtC,OAAO,EAAE,WAAW,EAAE,MAAM,2CAA2C,CAAA;AACvE,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAErD,OAAO,EAAc,YAAY,EAAE,MAAM,8BAA8B,CAAA;AACvE,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AACpD,OAAO,EAAE,mBAAmB,EAAE,MAAM,wCAAwC,CAAA;AAC5E,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAA;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAA;AAC7D,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAC5E,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AAEpD;;GAEG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,EAAE;IACzB,MAAM,CAAC,GAAG,YAAY,CAAC,UAAU,CAAC,CAAA;IAClC,MAAM,KAAK,GAAG,cAAc,CAAC,OAAO,CAAC,CAAA;IACrC,MAAM,EAAE,IAAI,EAAE,GAAG,aAAa,EAAE,CAAA;IAChC,MAAM,MAAM,GAAG,SAAS,EAAE,CAAA;IAE1B,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,KAAK,KAAK,OAAO;YAAE,IAAI,CACzB,KAAC,WAAW,KAAG,EACf,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,WAAW,EAAE,CAAC,CAAC,WAAW,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,SAAS,CAAC,EAAE,CAC9F,CAAA;IACH,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAA;IAEd,OAAO,IAAI,CAAA;AACb,CAAC,CAAA;AAED,MAAM,WAAW,GAAG,GAAG,EAAE;IACvB,MAAM,CAAC,GAAG,YAAY,CAAC,UAAU,CAAC,CAAA;IAClC,MAAM,IAAI,GAAG,cAAc,EAAE,CAAA;IAE7B,OAAO,KAAC,cAAc,IAAe,IAAI,EAAE;YACzC,EAAE,KAAK,EAAE,CAAC,CAAC,QAAQ,EAAE,OAAO,EAAE,KAAC,SAAS,IAAgB,UAAU,EAAC,UAAU,IAAhC,UAAU,CAAyB,EAAE;YAClF,EAAE,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,OAAO,EAAE,KAAC,SAAS,IAAc,UAAU,EAAC,QAAQ,IAA5B,QAAQ,CAAuB,EAAE;YAC5E,EAAE,KAAK,EAAE,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,KAAC,SAAS,IAAe,UAAU,EAAC,SAAS,IAA9B,SAAS,CAAwB,EAAE;SAChF,IAJ2B,IAAI,CAAC,EAAE,CAI9B,CAAA;AACP,CAAC,CAAA;AAED,MAAM,SAAS,GAAG,CAAC,EAAE,UAAU,EAAuC,EAAE,EAAE;IACxE,MAAM,CAAC,GAAG,YAAY,CAAC,UAAU,CAAC,CAAA;IAClC,MAAM,EAAE,KAAK,EAAE,GAAG,aAAa,EAAE,CAAA;IACjC,MAAM,IAAI,GAAG,cAAc,EAAE,CAAA;IAC7B,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAA;IACxC,MAAM,MAAM,GAAG,QAAQ,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,UAAU,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAA;IAC1E,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAiC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC,CAAA;IACpH,MAAM,QAAQ,GAAG,OAAO,CACtB,GAAG,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,EAC1H,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,CACxB,CAAA;IAED,SAAS,MAAM;QACb,IAAI,KAAK;YAAE,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,EAAE,EAAE,EAAE,KAAK,CAAC,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,CAAC,CAAA;QACjE,KAAK,EAAE,CAAA;IACT,CAAC;IAED,OAAO,CACL,8BACE,eAAK,SAAS,EAAC,SAAS,aACtB,KAAC,SAAS,IAAC,IAAI,EAAE,KAAC,MAAM,KAAG,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAC,QAAQ,GAAG,EACrF,CAAC,CAAC,QAAQ,CAAC,MAAM,IAAI,KAAC,mBAAmB,IACxC,OAAO,EAAE,QAAQ,EACjB,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EACjB,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,QAAQ,EAClB,WAAW,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EACxB,iBAAiB,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAClC,eAAe,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,MAAM,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC,CAAC;4BAC/G,CAAC,CAAC,cAAc;4BAChB,CAAC,CAAC,EAAE,EAEN,SAAS,EAAC,aAAa,GACvB,EACD,CAAC,CAAC,MAAM,CAAC,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM;wBAClC,KAAC,WAAW,IAAC,KAAK,EAAE,CAAC,CAAC,eAAe,EAAE,WAAW,EAAE,CAAC,CAAC,0BAA0B,EAAE,SAAS,EAAC,qBAAqB,GAAE,EACpH,CAAC,MAAM,CAAC,MAAM,IAAI,KAAC,WAAW,IAAC,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,WAAW,EAAE,CAAC,CAAC,iBAAiB,GAAI,IACjF,EACL,CAAC,CAAC,QAAQ,CAAC,MAAM,IAAI,KAAC,MAAM,IAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,KAAK,YAAG,CAAC,CAAC,KAAK,GAAU,IAClF,CACJ,CAAA;AACH,CAAC,CAAA;AAED,MAAM,UAAU,GAAG;IACjB,EAAE,EAAE;QACF,KAAK,EAAE,WAAW;QAClB,WAAW,EAAE,yEAAyE;QACtF,QAAQ,EAAE,UAAU;QACpB,MAAM,EAAE,QAAQ;QAChB,OAAO,EAAE,SAAS;QAClB,KAAK,EAAE,OAAO;QACd,eAAe,EAAE,mCAAmC;QACpD,0BAA0B,EAAE,kCAAkC;QAC9D,MAAM,EAAE,2CAA2C;QACnD,iBAAiB,EAAE,uFAAuF;KAC3G;IACD,EAAE,EAAE;QACF,KAAK,EAAE,WAAW;QAClB,WAAW,EAAE,0EAA0E;QACvF,QAAQ,EAAE,SAAS;QACnB,MAAM,EAAE,eAAe;QACvB,OAAO,EAAE,OAAO;QAChB,KAAK,EAAE,SAAS;QAChB,eAAe,EAAE,oCAAoC;QACrD,0BAA0B,EAAE,+BAA+B;QAC3D,MAAM,EAAE,sCAAsC;QAC9C,iBAAiB,EAAE,6FAA6F;KACjH;CACmB,CAAA"}
|
package/dist/views/Workspaces.js
CHANGED
|
@@ -40,7 +40,8 @@ const WorkspacesPanel = () => {
|
|
|
40
40
|
}
|
|
41
41
|
return (_jsxs(_Fragment, { children: [_jsxs("div", { className: "content", children: [_jsx(IconInput, { icon: _jsx(Search, {}), value: filter, onChange: setFilter, className: "search" }), !!filtered.length && _jsx(DescribedRadioGroup, { options: filtered, keygen: w => w.id, value: value, onChange: setValue, renderLabel: w => w.name, renderDescription: w => w.description, optionClassName: w => (w === value && filter && !w.name.toLocaleLowerCase().includes(filter.toLocaleLowerCase()))
|
|
42
42
|
? 'filtered-out'
|
|
43
|
-
: '', className: "option-list" }), !!workspaces.length && !filtered.length &&
|
|
43
|
+
: '', className: "option-list" }), !!workspaces.length && !filtered.length &&
|
|
44
|
+
_jsx(Placeholder, { title: t.noSearchResults, description: t.noSearchResultsDescription, className: "no-data-placeholder" }), !workspaces.length && _jsx(Placeholder, { title: t.noData, description: t.noDataDescription })] }), !!filtered.length && _jsx(Button, { onClick: submit, disabled: !value, children: t.apply })] }));
|
|
44
45
|
};
|
|
45
46
|
const dictionary = {
|
|
46
47
|
en: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Workspaces.js","sourceRoot":"","sources":["../../src/views/Workspaces.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AACrC,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAA;AACtC,OAAO,EAAE,WAAW,EAAE,MAAM,2CAA2C,CAAA;AACvE,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AAE5D,OAAO,EAAc,YAAY,EAAE,MAAM,8BAA8B,CAAA;AACvE,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AACpD,OAAO,EAAE,mBAAmB,EAAE,MAAM,wCAAwC,CAAA;AAC5E,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAA;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAA;AAC7D,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAC5E,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AAEpD;;GAEG;AACH,MAAM,CAAC,MAAM,UAAU,GAAG,GAAG,EAAE;IAC7B,MAAM,CAAC,GAAG,YAAY,CAAC,UAAU,CAAC,CAAA;IAClC,MAAM,KAAK,GAAG,cAAc,CAAC,OAAO,CAAC,CAAA;IACrC,MAAM,EAAE,IAAI,EAAE,GAAG,aAAa,EAAE,CAAA;IAChC,MAAM,MAAM,GAAG,SAAS,EAAE,CAAA;IAC1B,MAAM,IAAI,GAAG,cAAc,EAAE,CAAA;IAE7B,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,KAAK,KAAK,WAAW;YAAE,IAAI,CAC7B,KAAC,cAAc,cAAC,KAAC,eAAe,MAAM,IAAI,CAAC,EAAE,CAAI,GAAiB,EAClE,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,WAAW,EAAE,CAAC,CAAC,WAAW,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,SAAS,CAAC,EAAE,CAC9F,CAAA;IACH,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,CAAA;IAEvB,OAAO,IAAI,CAAA;AACb,CAAC,CAAA;AAED,MAAM,eAAe,GAAG,GAAG,EAAE;IAC3B,MAAM,CAAC,GAAG,YAAY,CAAC,UAAU,CAAC,CAAA;IAClC,MAAM,EAAE,KAAK,EAAE,GAAG,aAAa,EAAE,CAAA;IACjC,MAAM,IAAI,GAAG,cAAc,EAAE,CAAA;IAC7B,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAA;IACxC,MAAM,UAAU,GAAG,eAAe,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAA;IAC1E,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAoC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE,EAAE,CAAC,CAAC,CAAA;IAC/H,MAAM,QAAQ,GAAG,OAAO,CACtB,GAAG,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,EAClI,CAAC,UAAU,EAAE,MAAM,EAAE,KAAK,CAAC,CAC5B,CAAA;IAED,SAAS,MAAM;QACb,IAAI,KAAK;YAAE,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,EAAE,EAAE,EAAE,KAAK,CAAC,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,CAAC,CAAA;QACrE,KAAK,EAAE,CAAA;IACT,CAAC;IAED,OAAO,CACL,8BACE,eAAK,SAAS,EAAC,SAAS,aACtB,KAAC,SAAS,IAAC,IAAI,EAAE,KAAC,MAAM,KAAG,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAC,QAAQ,GAAG,EACrF,CAAC,CAAC,QAAQ,CAAC,MAAM,IAAI,KAAC,mBAAmB,IACxC,OAAO,EAAE,QAAQ,EACjB,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EACjB,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,QAAQ,EAClB,WAAW,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EACxB,iBAAiB,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EACrC,eAAe,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,MAAM,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC,CAAC;4BAC/G,CAAC,CAAC,cAAc;4BAChB,CAAC,CAAC,EAAE,EAEN,SAAS,EAAC,aAAa,GACvB,EACD,CAAC,CAAC,UAAU,CAAC,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,
|
|
1
|
+
{"version":3,"file":"Workspaces.js","sourceRoot":"","sources":["../../src/views/Workspaces.tsx"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@stack-spot/ai-chat-widget",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.3.0",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -15,7 +15,7 @@
|
|
|
15
15
|
"@citric/icons": "^5.4.0 || ^6.0.0",
|
|
16
16
|
"@citric/ui": "^5.4.0 || ^6.0.0",
|
|
17
17
|
"@stack-spot/portal-components": "^2.8.1",
|
|
18
|
-
"@stack-spot/portal-network": "^0.
|
|
18
|
+
"@stack-spot/portal-network": "^0.48.0",
|
|
19
19
|
"@stack-spot/portal-theme": "^1.0.0",
|
|
20
20
|
"@stack-spot/portal-translate": "^1.1.0",
|
|
21
21
|
"lodash": "^4.17.0",
|
|
@@ -1,16 +1,10 @@
|
|
|
1
|
-
import { loader } from '@monaco-editor/react'
|
|
2
1
|
import { listToClass } from '@stack-spot/portal-theme'
|
|
3
2
|
import { useMemo, useRef } from 'react'
|
|
4
|
-
import { quickCommandQuestionsInterceptor } from './chat-interceptors/quick-command-questions'
|
|
5
|
-
import { createQuickCommandInterceptor } from './chat-interceptors/quick-commands'
|
|
6
|
-
import { sendMessageInterceptor } from './chat-interceptors/send-message'
|
|
7
3
|
import { TooltipProvider } from './components/Tooltip'
|
|
8
|
-
import { useCurrentChatMessages,
|
|
9
|
-
import { AIWidgetFeatures, defaultFeatures } from './features'
|
|
4
|
+
import { useCurrentChatMessages, useWidgetState } from './context/hooks'
|
|
10
5
|
import './layout.css'
|
|
11
6
|
import { RightPanel } from './right-panel/RightPanel'
|
|
12
7
|
import { RightPanelProvider } from './right-panel/RightPanelProvider'
|
|
13
|
-
import { MessageInterceptor } from './state/ChatState'
|
|
14
8
|
import { MinimizedActions } from './types'
|
|
15
9
|
import { Agents } from './views/Agents'
|
|
16
10
|
import { Chat } from './views/Chat'
|
|
@@ -26,19 +20,10 @@ import { Stacks } from './views/Stacks'
|
|
|
26
20
|
import { Workspaces } from './views/Workspaces'
|
|
27
21
|
|
|
28
22
|
export interface AIWidgetProps {
|
|
29
|
-
/**
|
|
30
|
-
* The features to enable or disable.
|
|
31
|
-
*/
|
|
32
|
-
features?: AIWidgetFeatures,
|
|
33
23
|
/**
|
|
34
24
|
* The name of the user currently logged in.
|
|
35
25
|
*/
|
|
36
26
|
username: string,
|
|
37
|
-
/**
|
|
38
|
-
* Chat interceptors allows you to intercept chat messages, interpret them, modify them and even change the chat flow. See
|
|
39
|
-
* {@link ChatState} for more details.
|
|
40
|
-
*/
|
|
41
|
-
interceptors?: MessageInterceptor[],
|
|
42
27
|
/**
|
|
43
28
|
* A custom view to show when the chat has no messages to display.
|
|
44
29
|
*/
|
|
@@ -54,19 +39,8 @@ export interface AIWidgetProps {
|
|
|
54
39
|
* of the Chat Widget will be instantiated and used.
|
|
55
40
|
*/
|
|
56
41
|
export const StackspotAIWidget = (
|
|
57
|
-
{ username,
|
|
42
|
+
{ username, minimizedActions = {}, children }: AIWidgetProps,
|
|
58
43
|
) => {
|
|
59
|
-
const widget = useWidget()
|
|
60
|
-
const interceptors: MessageInterceptor[] = useMemo(
|
|
61
|
-
() => features.quickCommands ? [
|
|
62
|
-
...userInterceptors,
|
|
63
|
-
quickCommandQuestionsInterceptor,
|
|
64
|
-
createQuickCommandInterceptor(widget, () => loader.__getMonacoInstance()?.editor),
|
|
65
|
-
sendMessageInterceptor,
|
|
66
|
-
] : [...userInterceptors, sendMessageInterceptor],
|
|
67
|
-
[],
|
|
68
|
-
)
|
|
69
|
-
useFirstChat(interceptors)
|
|
70
44
|
const rightPanelRef = useRef<HTMLDivElement>(null)
|
|
71
45
|
const chatWindowRef = useRef<HTMLDivElement>(null)
|
|
72
46
|
const currentChat = useCurrentChatMessages()
|
|
@@ -80,13 +54,13 @@ export const StackspotAIWidget = (
|
|
|
80
54
|
<div className="chat-window" ref={chatWindowRef}>
|
|
81
55
|
{isMinimized
|
|
82
56
|
? <MinimizedHeader {...minimizedActions} />
|
|
83
|
-
: <ChatTabSelection
|
|
57
|
+
: <ChatTabSelection />
|
|
84
58
|
}
|
|
85
59
|
<div className="chat-container">
|
|
86
60
|
<div className="chat-content">
|
|
87
61
|
{isCurrentChatEmpty ? (children ?? <Home username={username} />) : <Chat username={username} />}
|
|
88
62
|
</div>
|
|
89
|
-
<MessageInput
|
|
63
|
+
<MessageInput />
|
|
90
64
|
</div>
|
|
91
65
|
</div>
|
|
92
66
|
<Stacks />
|
|
@@ -95,10 +69,10 @@ export const StackspotAIWidget = (
|
|
|
95
69
|
<KSDocument />
|
|
96
70
|
<Agents />
|
|
97
71
|
<Editor />
|
|
98
|
-
<ChatHistory
|
|
72
|
+
<ChatHistory />
|
|
99
73
|
<div className="chat-right-panel" ref={rightPanelRef}><RightPanel /></div>
|
|
100
74
|
</div>
|
|
101
75
|
</RightPanelProvider>
|
|
102
76
|
</TooltipProvider>
|
|
103
|
-
), [isCurrentChatEmpty,
|
|
77
|
+
), [isCurrentChatEmpty, username, isMinimized, children])
|
|
104
78
|
}
|
|
@@ -257,7 +257,7 @@ export function createQuickCommandInterceptor(widget: WidgetState, getEditor: ()
|
|
|
257
257
|
*/
|
|
258
258
|
async function quickCommandInterceptor(entry: ChatEntry, chat: ChatState, signal: AbortSignal) {
|
|
259
259
|
const { agentType, content } = entry.getValue()
|
|
260
|
-
if (agentType !== 'user' || !quickCommandRegex.test(content.trim())) return
|
|
260
|
+
if (!chat.get('features')?.quickCommands || agentType !== 'user' || !quickCommandRegex.test(content.trim())) return
|
|
261
261
|
const t = translate(dictionary)
|
|
262
262
|
const slug = content.trim().substring(1)
|
|
263
263
|
const ctx: QCContext = {
|
|
@@ -46,8 +46,12 @@ export async function sendMessageInterceptor(entry: ChatEntry, chat: ChatState,
|
|
|
46
46
|
if (agentType !== 'user') return
|
|
47
47
|
const context = buildConversationContext(chat)
|
|
48
48
|
chat.set('isLoading', true)
|
|
49
|
+
const untitled = chat.untitled
|
|
49
50
|
const isFirstMessage = chat.getMessages().length === 1
|
|
50
|
-
if (
|
|
51
|
+
if (untitled) {
|
|
52
|
+
chat.set('label', content)
|
|
53
|
+
chat.untitled = false
|
|
54
|
+
}
|
|
51
55
|
const stream = aiClient.sendChatMessage({ context, user_prompt: content.replace(/^\s*\\(\\|\/)/, '$1') })
|
|
52
56
|
signal.addEventListener('abort', () => stream.cancel())
|
|
53
57
|
const botEntry = ChatEntry.createStreamedBotEntry()
|
|
@@ -63,7 +67,23 @@ export async function sendMessageInterceptor(entry: ChatEntry, chat: ChatState,
|
|
|
63
67
|
const finalValue = await stream.getValue()
|
|
64
68
|
botEntry.setValue(createEntryValueFromChatResponse(finalValue, knowledgeSources, chat.get('agent'), true))
|
|
65
69
|
aiClient.chat.invalidate({ conversationId: chat.id })
|
|
66
|
-
if (isFirstMessage)
|
|
70
|
+
if (isFirstMessage) {
|
|
71
|
+
// if the chat has a title and this was its first message, we need to rename it according to the title, otherwise, the backend will
|
|
72
|
+
// keep the name generated by default.
|
|
73
|
+
if (!untitled) {
|
|
74
|
+
try {
|
|
75
|
+
await aiClient.renameChat.mutate({
|
|
76
|
+
conversationId: chat.id,
|
|
77
|
+
conversationUpdateTitleRequest: { title: chat.get('label') },
|
|
78
|
+
})
|
|
79
|
+
} catch (error) {
|
|
80
|
+
// eslint-disable-next-line no-console
|
|
81
|
+
console.warn('Failed to rename chat:', chat.get('label'), error)
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
// this makes sure to update the chat history
|
|
85
|
+
aiClient.chats.invalidate()
|
|
86
|
+
}
|
|
67
87
|
} catch (error: any) {
|
|
68
88
|
botEntry.setValue({
|
|
69
89
|
...botEntry.getValue(),
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
/* eslint-disable react/display-name */
|
|
2
2
|
import { focusFirstChild, TagPriorityElement } from '@stack-spot/portal-components'
|
|
3
3
|
import { forwardRef, RefObject, useEffect, useRef } from 'react'
|
|
4
|
+
import { styled } from 'styled-components'
|
|
4
5
|
|
|
5
6
|
interface Props extends React.HTMLAttributes<HTMLDivElement> {
|
|
6
7
|
/**
|
|
@@ -19,6 +20,13 @@ interface Props extends React.HTMLAttributes<HTMLDivElement> {
|
|
|
19
20
|
ignore?: string,
|
|
20
21
|
}
|
|
21
22
|
|
|
23
|
+
const FlexibleDiv = styled.div`
|
|
24
|
+
overflow: hidden;
|
|
25
|
+
flex: 1;
|
|
26
|
+
display: flex;
|
|
27
|
+
flex-direction: column;
|
|
28
|
+
`
|
|
29
|
+
|
|
22
30
|
/**
|
|
23
31
|
* Focus the first focusable child as soon as the component mounts.
|
|
24
32
|
*/
|
|
@@ -30,5 +38,5 @@ export const AutoFocus = forwardRef<HTMLDivElement, Props>(({ children, delay =
|
|
|
30
38
|
setTimeout(() => focusFirstChild(ref.current, { priority, ignore }), delay)
|
|
31
39
|
}, [])
|
|
32
40
|
|
|
33
|
-
return <
|
|
41
|
+
return <FlexibleDiv ref={ref} {...props}>{children}</FlexibleDiv>
|
|
34
42
|
})
|
|
@@ -45,8 +45,8 @@ const SCROLL_PX = 4
|
|
|
45
45
|
const masks = {
|
|
46
46
|
right: 'linear-gradient(to left, rgb(0, 0, 0, 0) 0%, rgb(0, 0, 0) min(30%, 100px), rgba(0, 0, 0) 100%)',
|
|
47
47
|
left: 'linear-gradient(to right, rgb(0, 0, 0, 0) 0%, rgb(0, 0, 0) min(30%, 100px), rgba(0, 0, 0) 100%)',
|
|
48
|
-
top: 'linear-gradient(to
|
|
49
|
-
bottom: 'linear-gradient(to
|
|
48
|
+
top: 'linear-gradient(to top, rgb(0, 0, 0, 0) 0%, rgb(0, 0, 0) min(30%, 100px), rgba(0, 0, 0) 100%)',
|
|
49
|
+
bottom: 'linear-gradient(to bottom, rgb(0, 0, 0, 0) 0%, rgb(0, 0, 0) min(30%, 100px), rgba(0, 0, 0) 100%)',
|
|
50
50
|
horizontal: 'linear-gradient(to left, rgb(0, 0, 0, 0) 0%, rgb(0, 0, 0) min(30%, 100px), rgb(0, 0, 0) max(70%, calc(100% - 100px)), rgba(0, 0, 0, 0) 100%)',
|
|
51
51
|
vertical: 'linear-gradient(to top, rgb(0, 0, 0, 0) 0%, rgb(0, 0, 0) min(30%, 100px), rgb(0, 0, 0) max(70%, calc(100% - 100px)), rgba(0, 0, 0, 0) 100%)',
|
|
52
52
|
}
|
|
@@ -2,9 +2,15 @@ import { IconBox, Text } from '@citric/core'
|
|
|
2
2
|
import { theme, WithStyle } from '@stack-spot/portal-theme'
|
|
3
3
|
import { styled } from 'styled-components'
|
|
4
4
|
import { ButtonAction } from '../types'
|
|
5
|
+
import { FadingOverflow } from './FadingOverflow'
|
|
5
6
|
|
|
6
7
|
interface Props extends ButtonAction, WithStyle {
|
|
7
8
|
background?: string,
|
|
9
|
+
/**
|
|
10
|
+
* Whether or not the vertical overflow of this button should be managed by the component {@link FadingOverflow}.
|
|
11
|
+
* @default false
|
|
12
|
+
*/
|
|
13
|
+
manageOverflow?: boolean,
|
|
8
14
|
}
|
|
9
15
|
|
|
10
16
|
/**
|
|
@@ -46,9 +52,15 @@ const QuickButton = styled.button<{ $color?: string, $bg?: string }>`
|
|
|
46
52
|
}
|
|
47
53
|
`
|
|
48
54
|
|
|
49
|
-
export const QuickStartButton = ({ label, onClick, background, className, color, icon, style }: Props) =>
|
|
50
|
-
|
|
51
|
-
<IconBox aria-hidden>{icon}</IconBox>
|
|
55
|
+
export const QuickStartButton = ({ label, onClick, background, className, color, icon, style, manageOverflow }: Props) => {
|
|
56
|
+
const content = <>
|
|
57
|
+
{icon && <IconBox aria-hidden>{icon}</IconBox>}
|
|
52
58
|
<Text>{label}</Text>
|
|
53
|
-
|
|
54
|
-
|
|
59
|
+
</>
|
|
60
|
+
|
|
61
|
+
return (
|
|
62
|
+
<QuickButton className={className} style={style} onClick={onClick} $color={color} $bg={background}>
|
|
63
|
+
{manageOverflow ? <FadingOverflow sides={['top', 'bottom']} scroll="wheel">{content}</FadingOverflow> : content}
|
|
64
|
+
</QuickButton>
|
|
65
|
+
)
|
|
66
|
+
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Card } from '@citric/ui'
|
|
2
2
|
import { styled } from 'styled-components'
|
|
3
|
+
import { panelAnimationTime } from '../right-panel/constants'
|
|
3
4
|
import { PropsOf } from '../types'
|
|
4
5
|
import { AutoFocus } from './AutoFocus'
|
|
5
6
|
import { FallbackBoundary } from './FallbackBoundary'
|
|
@@ -46,7 +47,7 @@ const Form = styled.form`
|
|
|
46
47
|
*/
|
|
47
48
|
export const RightPanelForm = ({ children, onSubmit, ...props }: PropsOf<typeof Form>) => (
|
|
48
49
|
<FallbackBoundary>
|
|
49
|
-
<AutoFocus>
|
|
50
|
+
<AutoFocus delay={panelAnimationTime}>
|
|
50
51
|
<Form
|
|
51
52
|
{...props}
|
|
52
53
|
onSubmit={(e) => {
|
package/src/context/hooks.ts
CHANGED
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
import { useContext, useEffect, useState } from 'react'
|
|
2
2
|
import { ChatEntry } from '../state/ChatEntry'
|
|
3
|
-
import { ChatProperties, ChatState
|
|
3
|
+
import { ChatProperties, ChatState } from '../state/ChatState'
|
|
4
4
|
import { ObservableState } from '../state/ObservableState'
|
|
5
5
|
import { WidgetProperties, WidgetState } from '../state/WidgetState'
|
|
6
|
-
import { createNewChat } from '../utils/chat'
|
|
7
6
|
import { AIWidgetContext } from './AIWidgetProvider'
|
|
8
7
|
|
|
9
8
|
let globalWidgetState: WidgetState | undefined
|
|
@@ -40,11 +39,11 @@ export function useWidgetState<K extends keyof WidgetProperties>(key: K): Widget
|
|
|
40
39
|
/**
|
|
41
40
|
* Watches the tabs of a ChatState. The value is updated whenever a tab is added, removed or selected.
|
|
42
41
|
*/
|
|
43
|
-
export function useChatTabs(): { chats: ChatState[], active:
|
|
42
|
+
export function useChatTabs(): { chats: ChatState[], active: ChatState } {
|
|
44
43
|
const widget = useWidget()
|
|
45
|
-
const [tabs, setTabs] = useState<{ chats: ChatState[], active:
|
|
46
|
-
chats: widget.chatTabs.getAll(),
|
|
47
|
-
active: widget.chatTabs.
|
|
44
|
+
const [tabs, setTabs] = useState<{ chats: ChatState[], active: ChatState }>({
|
|
45
|
+
chats: widget.chatTabs.getAll(),
|
|
46
|
+
active: widget.chatTabs.getActiveChat(),
|
|
48
47
|
})
|
|
49
48
|
useEffect(() => widget.chatTabs.onChange((chats, active) => setTabs({ chats, active })), [])
|
|
50
49
|
return tabs
|
|
@@ -60,7 +59,7 @@ export function useChatTabs(): { chats: ChatState[], active: string } {
|
|
|
60
59
|
export function useChat(chatId: string): ChatState {
|
|
61
60
|
const widget = useWidget()
|
|
62
61
|
const chat = widget.chatTabs.get(chatId)
|
|
63
|
-
if (!chat) throw new Error(`No chat with id ${chatId} was found. Maybe there are no chats opened
|
|
62
|
+
if (!chat) throw new Error(`No chat with id ${chatId} was found. Maybe there are no chats opened.`)
|
|
64
63
|
return chat
|
|
65
64
|
}
|
|
66
65
|
|
|
@@ -72,8 +71,7 @@ export function useChat(chatId: string): ChatState {
|
|
|
72
71
|
* @returns the currently active chat.
|
|
73
72
|
*/
|
|
74
73
|
export function useCurrentChat(): ChatState {
|
|
75
|
-
|
|
76
|
-
return useChat(active)
|
|
74
|
+
return useChatTabs().active
|
|
77
75
|
}
|
|
78
76
|
|
|
79
77
|
/**
|
|
@@ -119,7 +117,7 @@ export function useChatMessages(chatId: string): ChatEntry[] {
|
|
|
119
117
|
*/
|
|
120
118
|
export function useCurrentChatMessages(): ChatEntry[] {
|
|
121
119
|
const { active } = useChatTabs()
|
|
122
|
-
return useChatMessages(active)
|
|
120
|
+
return useChatMessages(active.id)
|
|
123
121
|
}
|
|
124
122
|
|
|
125
123
|
/**
|
|
@@ -133,13 +131,3 @@ export function useChatEntry(entry: ChatEntry) {
|
|
|
133
131
|
useEffect(() => entry.onChange(setContent), [])
|
|
134
132
|
return content
|
|
135
133
|
}
|
|
136
|
-
|
|
137
|
-
/**
|
|
138
|
-
* This will create a new chat if none exists.
|
|
139
|
-
* @param interceptors the interceptors to add to the new chat.
|
|
140
|
-
*/
|
|
141
|
-
export function useFirstChat(interceptors: MessageInterceptor[]) {
|
|
142
|
-
const widget = useWidget()
|
|
143
|
-
const tabs = widget.chatTabs
|
|
144
|
-
if (!tabs.getAll().length) createNewChat(widget, interceptors)
|
|
145
|
-
}
|
package/src/features.ts
CHANGED
|
@@ -1,50 +1,53 @@
|
|
|
1
|
-
export interface
|
|
1
|
+
export interface ChatFeatures {
|
|
2
2
|
/**
|
|
3
3
|
* Enables stack selection.
|
|
4
|
-
* @default true
|
|
5
4
|
*/
|
|
6
|
-
stack
|
|
5
|
+
stack: boolean,
|
|
7
6
|
/**
|
|
8
7
|
* Enables workspace selection.
|
|
9
|
-
* @default true
|
|
10
8
|
*/
|
|
11
|
-
workspace
|
|
9
|
+
workspace: boolean,
|
|
12
10
|
/**
|
|
13
11
|
* Enables knowledge source selection.
|
|
14
|
-
* @default true
|
|
15
12
|
*/
|
|
16
|
-
knowledgeSource
|
|
13
|
+
knowledgeSource: boolean,
|
|
17
14
|
/**
|
|
18
15
|
* Enables agent selection.
|
|
19
|
-
* @default true
|
|
20
16
|
*/
|
|
21
|
-
agent
|
|
17
|
+
agent: boolean,
|
|
22
18
|
/**
|
|
23
19
|
* Enables quick commands.
|
|
24
|
-
* @default true
|
|
25
20
|
*/
|
|
26
|
-
quickCommands
|
|
21
|
+
quickCommands: boolean,
|
|
27
22
|
/**
|
|
28
23
|
* Enables the editor.
|
|
29
|
-
* @default true
|
|
30
24
|
*/
|
|
31
|
-
editor
|
|
25
|
+
editor: boolean,
|
|
32
26
|
}
|
|
33
27
|
|
|
34
|
-
export interface
|
|
28
|
+
export interface GlobalFeatures {
|
|
35
29
|
/**
|
|
36
30
|
* Enables the chat history.
|
|
37
|
-
* @default true
|
|
38
31
|
*/
|
|
39
|
-
chatHistory
|
|
32
|
+
chatHistory: boolean,
|
|
40
33
|
}
|
|
41
34
|
|
|
42
|
-
export
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
35
|
+
export type AIWidgetFeatures = ChatFeatures & GlobalFeatures
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* Receives a partial feature object and returns a full feature object, setting to true any missing property.
|
|
39
|
+
* @param features the partial features object.
|
|
40
|
+
* @returns a full features object.
|
|
41
|
+
*/
|
|
42
|
+
export function getFeaturesWithDefaults(features?: Partial<AIWidgetFeatures>): AIWidgetFeatures {
|
|
43
|
+
return {
|
|
44
|
+
agent: true,
|
|
45
|
+
editor: true,
|
|
46
|
+
knowledgeSource: true,
|
|
47
|
+
quickCommands: true,
|
|
48
|
+
stack: true,
|
|
49
|
+
workspace: true,
|
|
50
|
+
chatHistory: true,
|
|
51
|
+
...features,
|
|
52
|
+
}
|
|
50
53
|
}
|
package/src/index.ts
CHANGED
|
@@ -1,8 +1,14 @@
|
|
|
1
|
+
/* Attention: in order for the package "page" to work without linking the lib, we must export types separately, using the "type" keyword */
|
|
2
|
+
|
|
3
|
+
export { QuickStartButton } from './components/QuickStartButton'
|
|
1
4
|
export { AIWidgetProvider } from './context/AIWidgetProvider'
|
|
2
5
|
export * from './context/hooks'
|
|
6
|
+
export { getFeaturesWithDefaults } from './features'
|
|
7
|
+
export type { AIWidgetFeatures, ChatFeatures } from './features'
|
|
3
8
|
export { StackspotAIWidget } from './StackspotAIWidget'
|
|
4
9
|
export { ChatEntry } from './state/ChatEntry'
|
|
5
10
|
export { ChatState } from './state/ChatState'
|
|
6
11
|
export { ChatTabsController } from './state/ChatTabsController'
|
|
7
12
|
export { ObservableState } from './state/ObservableState'
|
|
13
|
+
export type { Labeled, LabeledWithImage } from './state/types'
|
|
8
14
|
export { WidgetState } from './state/WidgetState'
|
package/src/layout.css
CHANGED
package/src/state/ChatState.ts
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import { dropRight, last, pull } from 'lodash'
|
|
2
2
|
import { ulid } from 'ulid'
|
|
3
3
|
import { AbortedError } from '../AbortedError'
|
|
4
|
+
import { ChatFeatures, getFeaturesWithDefaults } from '../features'
|
|
4
5
|
import { ChatEntry } from './ChatEntry'
|
|
5
6
|
import { ObservableState } from './ObservableState'
|
|
6
7
|
import { Labeled, LabeledWithImage } from './types'
|
|
7
8
|
|
|
8
|
-
export interface
|
|
9
|
+
export interface ChatPropertiesWithOptionalFeatures {
|
|
9
10
|
/**
|
|
10
11
|
* The name of the chat.
|
|
11
12
|
*/
|
|
@@ -46,6 +47,19 @@ export interface ChatProperties {
|
|
|
46
47
|
* The current selection in the editor.
|
|
47
48
|
*/
|
|
48
49
|
codeSelection?: string,
|
|
50
|
+
/**
|
|
51
|
+
* The features enabled for this chat.
|
|
52
|
+
*
|
|
53
|
+
* If a feature is marked as false, it's disabled, otherwise it's enabled.
|
|
54
|
+
*/
|
|
55
|
+
features?: Partial<ChatFeatures>,
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
export interface ChatProperties extends ChatPropertiesWithOptionalFeatures {
|
|
59
|
+
/**
|
|
60
|
+
* The features enabled for this chat.
|
|
61
|
+
*/
|
|
62
|
+
features: ChatFeatures,
|
|
49
63
|
}
|
|
50
64
|
|
|
51
65
|
type ChatMessagesListener = (chat: ChatEntry[]) => void
|
|
@@ -62,7 +76,7 @@ interface Options {
|
|
|
62
76
|
/**
|
|
63
77
|
* The initial value for the state of this chat.
|
|
64
78
|
*/
|
|
65
|
-
initial:
|
|
79
|
+
initial: ChatPropertiesWithOptionalFeatures,
|
|
66
80
|
/**
|
|
67
81
|
* The interceptors to use for the messages pushed to this chat.
|
|
68
82
|
*
|
|
@@ -86,6 +100,12 @@ interface Options {
|
|
|
86
100
|
* The content of this chat, i.e. its messages.
|
|
87
101
|
*/
|
|
88
102
|
entries?: ChatEntry[],
|
|
103
|
+
/**
|
|
104
|
+
* Whether or not the label for this chat is real (persisted in the backend) or just a mock.
|
|
105
|
+
*
|
|
106
|
+
* This should be true if the label is just a mock.
|
|
107
|
+
*/
|
|
108
|
+
untitled?: boolean,
|
|
89
109
|
}
|
|
90
110
|
|
|
91
111
|
/**
|
|
@@ -104,12 +124,14 @@ export class ChatState extends ObservableState<ChatProperties> {
|
|
|
104
124
|
* Abort signals currently active.
|
|
105
125
|
*/
|
|
106
126
|
private abortions: AbortController[] = []
|
|
127
|
+
untitled: boolean
|
|
107
128
|
|
|
108
|
-
constructor({ id, initial, entries = [], interceptors = [] }: Options) {
|
|
109
|
-
super(initial)
|
|
129
|
+
constructor({ id, initial, entries = [], interceptors = [], untitled = false }: Options) {
|
|
130
|
+
super({ ...initial, features: getFeaturesWithDefaults(initial.features) })
|
|
110
131
|
this.id = id
|
|
111
132
|
this.interceptors = interceptors
|
|
112
133
|
this.entries = entries
|
|
134
|
+
this.untitled = untitled
|
|
113
135
|
}
|
|
114
136
|
|
|
115
137
|
private runMessagesListeners() {
|