@gitlab/duo-ui 8.7.11 → 8.9.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 +14 -0
- package/dist/components/chat/components/duo_chat_context/constants.js +2 -3
- package/dist/components/chat/components/duo_chat_context/duo_chat_context_item_selections/duo_chat_context_item_selections.js +2 -2
- package/dist/components/chat/components/duo_chat_context/mock_context_data.js +18 -2
- package/dist/components/chat/components/duo_chat_header/duo_chat_header.js +6 -1
- package/dist/components/chat/duo_chat.js +11 -1
- package/package.json +2 -2
- package/src/components/chat/components/duo_chat_context/constants.js +1 -3
- package/src/components/chat/components/duo_chat_context/duo_chat_context_item_selections/duo_chat_context_item_selections.vue +2 -0
- package/src/components/chat/components/duo_chat_context/mock_context_data.js +19 -0
- package/src/components/chat/components/duo_chat_header/duo_chat_header.vue +18 -2
- package/src/components/chat/duo_chat.vue +12 -0
package/CHANGELOG.md
CHANGED
|
@@ -1,3 +1,17 @@
|
|
|
1
|
+
# [8.9.0](https://gitlab.com/gitlab-org/duo-ui/compare/v8.8.0...v8.9.0) (2025-03-31)
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
### Features
|
|
5
|
+
|
|
6
|
+
* render current thread's title in Duo Chat ([fdbc38d](https://gitlab.com/gitlab-org/duo-ui/commit/fdbc38d143c5e563732cb92d60dabb685e89ea96))
|
|
7
|
+
|
|
8
|
+
# [8.8.0](https://gitlab.com/gitlab-org/duo-ui/compare/v8.7.11...v8.8.0) (2025-03-31)
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
### Features
|
|
12
|
+
|
|
13
|
+
* support terminal context category ([2aefdc6](https://gitlab.com/gitlab-org/duo-ui/commit/2aefdc60b95cbff87c8a6e284e01ef3f4e95da8c))
|
|
14
|
+
|
|
1
15
|
## [8.7.11](https://gitlab.com/gitlab-org/duo-ui/compare/v8.7.10...v8.7.11) (2025-03-28)
|
|
2
16
|
|
|
3
17
|
|
|
@@ -3,10 +3,9 @@ const CONTEXT_ITEM_CATEGORY_MERGE_REQUEST = 'merge_request';
|
|
|
3
3
|
const CONTEXT_ITEM_CATEGORY_FILE = 'file';
|
|
4
4
|
const CONTEXT_ITEM_CATEGORY_LOCAL_GIT = 'local_git';
|
|
5
5
|
const CONTEXT_ITEM_CATEGORY_DEPENDENCY = 'dependency';
|
|
6
|
-
const
|
|
7
|
-
const CONTEXT_ITEM_LOCAL_GIT_DIFF = 'diff';
|
|
6
|
+
const CONTEXT_ITEM_CATEGORY_TERMINAL_SELECTION = 'terminal';
|
|
8
7
|
const LANGUAGE_IDENTIFIER_PREFIX = 'language-';
|
|
9
8
|
const LANGUAGE_IDENTIFIER_DIFF = 'language-diff';
|
|
10
9
|
const LANGUAGE_IDENTIFIER_PLAINTEXT = 'language-plaintext';
|
|
11
10
|
|
|
12
|
-
export { CONTEXT_ITEM_CATEGORY_DEPENDENCY, CONTEXT_ITEM_CATEGORY_FILE, CONTEXT_ITEM_CATEGORY_ISSUE, CONTEXT_ITEM_CATEGORY_LOCAL_GIT, CONTEXT_ITEM_CATEGORY_MERGE_REQUEST,
|
|
11
|
+
export { CONTEXT_ITEM_CATEGORY_DEPENDENCY, CONTEXT_ITEM_CATEGORY_FILE, CONTEXT_ITEM_CATEGORY_ISSUE, CONTEXT_ITEM_CATEGORY_LOCAL_GIT, CONTEXT_ITEM_CATEGORY_MERGE_REQUEST, CONTEXT_ITEM_CATEGORY_TERMINAL_SELECTION, LANGUAGE_IDENTIFIER_DIFF, LANGUAGE_IDENTIFIER_PLAINTEXT, LANGUAGE_IDENTIFIER_PREFIX };
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import uniqueId from 'lodash/uniqueId';
|
|
2
2
|
import { GlTruncate, GlIcon, GlToken } from '@gitlab/ui';
|
|
3
3
|
import DuoChatContextItemPopover from '../duo_chat_context_item_popover/duo_chat_context_item_popover';
|
|
4
|
-
import { CONTEXT_ITEM_CATEGORY_LOCAL_GIT, CONTEXT_ITEM_CATEGORY_FILE, CONTEXT_ITEM_CATEGORY_DEPENDENCY } from '../constants';
|
|
4
|
+
import { CONTEXT_ITEM_CATEGORY_LOCAL_GIT, CONTEXT_ITEM_CATEGORY_FILE, CONTEXT_ITEM_CATEGORY_DEPENDENCY, CONTEXT_ITEM_CATEGORY_TERMINAL_SELECTION } from '../constants';
|
|
5
5
|
import DuoChatContextItemDetailsModal from '../duo_chat_context_item_details_modal/duo_chat_context_item_details_modal';
|
|
6
6
|
import { contextItemsValidator } from '../utils';
|
|
7
7
|
import __vue_normalize__ from 'vue-runtime-helpers/dist/normalize-component.js';
|
|
@@ -105,7 +105,7 @@ var script = {
|
|
|
105
105
|
this.previewContextItemId = contextItem.id;
|
|
106
106
|
},
|
|
107
107
|
canOpen(contextItem) {
|
|
108
|
-
return [CONTEXT_ITEM_CATEGORY_LOCAL_GIT, CONTEXT_ITEM_CATEGORY_FILE, CONTEXT_ITEM_CATEGORY_DEPENDENCY].includes(contextItem.category);
|
|
108
|
+
return [CONTEXT_ITEM_CATEGORY_LOCAL_GIT, CONTEXT_ITEM_CATEGORY_FILE, CONTEXT_ITEM_CATEGORY_DEPENDENCY, CONTEXT_ITEM_CATEGORY_TERMINAL_SELECTION].includes(contextItem.category);
|
|
109
109
|
},
|
|
110
110
|
onClosePreview() {
|
|
111
111
|
this.previewContextItemId = null;
|
|
@@ -300,8 +300,24 @@ const mockDependencies = [MOCK_CONTEXT_ITEM_DEPENDENCY, MOCK_CONTEXT_ITEM_DEPEND
|
|
|
300
300
|
project: 'example/legacy'
|
|
301
301
|
}
|
|
302
302
|
}];
|
|
303
|
+
const mockTerminalOutput = '$ npx cowsay "moo"\n _____\n< moo >\n -----\n \\ ^__^\n \\ (oo)\\_______\n (__)\\ )\\/\\\n ||----w |\n || ||';
|
|
304
|
+
const mockTerminalOutputLines = mockTerminalOutput.split('\n');
|
|
305
|
+
const MOCK_CONTEXT_ITEM_TERMINAL = {
|
|
306
|
+
id: 'cb94e08e-f2f6-408a-8f43-036079d19e47',
|
|
307
|
+
category: 'terminal',
|
|
308
|
+
content: mockTerminalOutput,
|
|
309
|
+
metadata: {
|
|
310
|
+
title: mockTerminalOutput.split('\n').at(0),
|
|
311
|
+
enabled: true,
|
|
312
|
+
subType: 'snippet',
|
|
313
|
+
icon: 'terminal',
|
|
314
|
+
subTypeLabel: 'Selected terminal output',
|
|
315
|
+
secondaryText: `${mockTerminalOutputLines.length} lines of terminal output`
|
|
316
|
+
}
|
|
317
|
+
};
|
|
318
|
+
const mockTerminalSelections = [MOCK_CONTEXT_ITEM_TERMINAL];
|
|
303
319
|
const getMockContextItems = () => {
|
|
304
|
-
const allItems = [...mockFiles, ...mockGitItems, ...mockIssues, ...mockMergeRequests, ...mockDependencies];
|
|
320
|
+
const allItems = [...mockFiles, ...mockGitItems, ...mockIssues, ...mockMergeRequests, ...mockDependencies, ...mockTerminalSelections];
|
|
305
321
|
|
|
306
322
|
// put disabled items in the back
|
|
307
323
|
const disabledItems = allItems.filter(item => !item.metadata.enabled);
|
|
@@ -309,4 +325,4 @@ const getMockContextItems = () => {
|
|
|
309
325
|
return [...enabledItems, ...disabledItems];
|
|
310
326
|
};
|
|
311
327
|
|
|
312
|
-
export { MOCK_CATEGORIES, MOCK_CONTEXT_FILE_CONTENT, MOCK_CONTEXT_FILE_DIFF_CONTENT, MOCK_CONTEXT_ITEM_DEPENDENCY, MOCK_CONTEXT_ITEM_DEPENDENCY_DISABLED, MOCK_CONTEXT_ITEM_FILE, MOCK_CONTEXT_ITEM_FILE_DISABLED, MOCK_CONTEXT_ITEM_GIT_COMMIT, MOCK_CONTEXT_ITEM_GIT_DIFF, MOCK_CONTEXT_ITEM_ISSUE, MOCK_CONTEXT_ITEM_ISSUE_DISABLED, MOCK_CONTEXT_ITEM_MERGE_REQUEST, MOCK_CONTEXT_ITEM_MERGE_REQUEST_DISABLED, getMockCategory, getMockContextItems };
|
|
328
|
+
export { MOCK_CATEGORIES, MOCK_CONTEXT_FILE_CONTENT, MOCK_CONTEXT_FILE_DIFF_CONTENT, MOCK_CONTEXT_ITEM_DEPENDENCY, MOCK_CONTEXT_ITEM_DEPENDENCY_DISABLED, MOCK_CONTEXT_ITEM_FILE, MOCK_CONTEXT_ITEM_FILE_DISABLED, MOCK_CONTEXT_ITEM_GIT_COMMIT, MOCK_CONTEXT_ITEM_GIT_DIFF, MOCK_CONTEXT_ITEM_ISSUE, MOCK_CONTEXT_ITEM_ISSUE_DISABLED, MOCK_CONTEXT_ITEM_MERGE_REQUEST, MOCK_CONTEXT_ITEM_MERGE_REQUEST_DISABLED, MOCK_CONTEXT_ITEM_TERMINAL, getMockCategory, getMockContextItems };
|
|
@@ -28,6 +28,11 @@ var script = {
|
|
|
28
28
|
required: false,
|
|
29
29
|
default: i18n.CHAT_TITLE
|
|
30
30
|
},
|
|
31
|
+
subtitle: {
|
|
32
|
+
type: String,
|
|
33
|
+
required: false,
|
|
34
|
+
default: ''
|
|
35
|
+
},
|
|
31
36
|
error: {
|
|
32
37
|
type: String,
|
|
33
38
|
required: false,
|
|
@@ -70,7 +75,7 @@ var script = {
|
|
|
70
75
|
const __vue_script__ = script;
|
|
71
76
|
|
|
72
77
|
/* template */
|
|
73
|
-
var __vue_render__ = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('header',{staticClass:"gl-border-b gl-bg-default gl-p-0 gl-shrink-0",attrs:{"data-testid":"chat-header"}},[_c('div',{staticClass:"drawer-title gl-flex gl-items-center gl-justify-start gl-p-5"},[(_vm.isMultithreaded && _vm.currentView === _vm.VIEW_TYPES.CHAT)?_c('gl-button',{directives:[{name:"gl-tooltip",rawName:"v-gl-tooltip"}],staticClass:"gl-mr-3",attrs:{"title":_vm.$options.i18n.CHAT_HISTORY_TOOLTIP,"data-testid":"chat-back-button","category":"primary","size":"medium","icon":"history","aria-label":_vm.$options.i18n.CHAT_BACK_LABEL},on:{"click":function($event){return _vm.$emit('go-back')}}}):_vm._e(),_vm._v(" "),(_vm.isMultithreaded && (_vm.activeThreadId || _vm.currentView === _vm.VIEW_TYPES.LIST))?_c('gl-button',{directives:[{name:"gl-tooltip",rawName:"v-gl-tooltip"}],staticClass:"gl-mr-3",attrs:{"title":_vm.$options.i18n.CHAT_NEW_TOOLTIP,"data-testid":"chat-new-button","category":"primary","size":"medium","icon":"duo-chat-new","aria-label":_vm.$options.i18n.CHAT_NEW_LABEL},on:{"click":function($event){return _vm.$emit('new-chat')}}}):_vm._e(),_vm._v(" "),_c('h3',{staticClass:"gl-my-0 gl-text-size-h2"},[_vm._v(_vm._s(_vm.title))]),_vm._v(" "),(_vm.badgeType)?_c('gl-experiment-badge',{attrs:{"type":_vm.badgeType,"container-id":"chat-component"}}):_vm._e(),_vm._v(" "),_c('gl-button',{staticClass:"gl-ml-auto",attrs:{"category":"tertiary","variant":"default","icon":"close","size":"small","data-testid":"chat-close-button","aria-label":_vm.$options.i18n.CHAT_CLOSE_LABEL},on:{"click":function($event){return _vm.$emit('close')}}})],1),_vm._v(" "),_vm._t("subheader"),_vm._v(" "),(_vm.error)?_c('gl-alert',{key:"error",staticClass:"!gl-pl-9",attrs:{"dismissible":false,"variant":"danger","role":"alert","data-testid":"chat-error"}},[_c('span',{directives:[{name:"safe-html",rawName:"v-safe-html",value:(_vm.error),expression:"error"}]})]):_vm._e()],2)};
|
|
78
|
+
var __vue_render__ = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('header',{staticClass:"gl-border-b gl-bg-default gl-p-0 gl-shrink-0",attrs:{"data-testid":"chat-header"}},[_c('div',{staticClass:"drawer-title gl-flex gl-items-center gl-justify-start gl-p-5"},[(_vm.isMultithreaded && _vm.currentView === _vm.VIEW_TYPES.CHAT)?_c('gl-button',{directives:[{name:"gl-tooltip",rawName:"v-gl-tooltip"}],staticClass:"gl-mr-3",attrs:{"title":_vm.$options.i18n.CHAT_HISTORY_TOOLTIP,"data-testid":"chat-back-button","category":"primary","size":"medium","icon":"history","aria-label":_vm.$options.i18n.CHAT_BACK_LABEL},on:{"click":function($event){return _vm.$emit('go-back')}}}):_vm._e(),_vm._v(" "),(_vm.isMultithreaded && (_vm.activeThreadId || _vm.currentView === _vm.VIEW_TYPES.LIST))?_c('gl-button',{directives:[{name:"gl-tooltip",rawName:"v-gl-tooltip"}],staticClass:"gl-mr-3",attrs:{"title":_vm.$options.i18n.CHAT_NEW_TOOLTIP,"data-testid":"chat-new-button","category":"primary","size":"medium","icon":"duo-chat-new","aria-label":_vm.$options.i18n.CHAT_NEW_LABEL},on:{"click":function($event){return _vm.$emit('new-chat')}}}):_vm._e(),_vm._v(" "),_c('div',{staticClass:"gl-flex-1 gl-overflow-hidden"},[_c('div',{staticClass:"gl-flex gl-items-center"},[_c('h3',{staticClass:"gl-my-0 gl-text-size-h2"},[_vm._v(_vm._s(_vm.title))]),_vm._v(" "),(_vm.badgeType)?_c('gl-experiment-badge',{attrs:{"type":_vm.badgeType,"container-id":"chat-component"}}):_vm._e()],1),_vm._v(" "),(_vm.subtitle)?_c('h4',{staticClass:"gl-text-base gl-whitespace-nowrap gl-overflow-hidden gl-text-ellipsis gl-font-normal text-muted gl-mb-0",attrs:{"data-testid":"chat-subtitle"}},[_vm._v("\n "+_vm._s(_vm.subtitle)+"\n ")]):_vm._e()]),_vm._v(" "),_c('gl-button',{staticClass:"gl-ml-auto",attrs:{"category":"tertiary","variant":"default","icon":"close","size":"small","data-testid":"chat-close-button","aria-label":_vm.$options.i18n.CHAT_CLOSE_LABEL},on:{"click":function($event){return _vm.$emit('close')}}})],1),_vm._v(" "),_vm._t("subheader"),_vm._v(" "),(_vm.error)?_c('gl-alert',{key:"error",staticClass:"!gl-pl-9",attrs:{"dismissible":false,"variant":"danger","role":"alert","data-testid":"chat-error"}},[_c('span',{directives:[{name:"safe-html",rawName:"v-safe-html",value:(_vm.error),expression:"error"}]})]):_vm._e()],2)};
|
|
74
79
|
var __vue_staticRenderFns__ = [];
|
|
75
80
|
|
|
76
81
|
/* style */
|
|
@@ -334,6 +334,16 @@ var script = {
|
|
|
334
334
|
},
|
|
335
335
|
hasContextItemSelectionMenu() {
|
|
336
336
|
return Boolean(this.contextItemMenuRef);
|
|
337
|
+
},
|
|
338
|
+
activeThread() {
|
|
339
|
+
return this.activeThreadId ? this.threadList.find(thread => thread.id === this.activeThreadId) : null;
|
|
340
|
+
},
|
|
341
|
+
activeThreadTitle() {
|
|
342
|
+
var _this$activeThread;
|
|
343
|
+
return (_this$activeThread = this.activeThread) === null || _this$activeThread === void 0 ? void 0 : _this$activeThread.title;
|
|
344
|
+
},
|
|
345
|
+
activeThreadTitleForView() {
|
|
346
|
+
return this.currentView === VIEW_TYPES.CHAT && this.activeThreadTitle || '';
|
|
337
347
|
}
|
|
338
348
|
},
|
|
339
349
|
watch: {
|
|
@@ -595,7 +605,7 @@ var __vue_render__ = function () {var _vm=this;var _h=_vm.$createElement;var _c=
|
|
|
595
605
|
},attrs:{"width":_vm.shouldRenderResizable ? _vm.dimensions.width : null,"height":_vm.shouldRenderResizable ? _vm.dimensions.height : null,"max-width":_vm.shouldRenderResizable ? _vm.dimensions.maxWidth : null,"max-height":_vm.shouldRenderResizable ? _vm.dimensions.maxHeight : null,"min-width":_vm.shouldRenderResizable ? _vm.dimensions.minWidth : null,"left":_vm.shouldRenderResizable ? _vm.dimensions.left : null,"top":_vm.shouldRenderResizable ? _vm.dimensions.top : null,"fit-parent":true,"min-height":_vm.shouldRenderResizable ? _vm.dimensions.minHeight : null,"active":_vm.shouldRenderResizable ? ['l', 't', 'lt'] : null},on:{"resize:end":_vm.updateSize}},[(!_vm.isHidden)?_c('aside',{staticClass:"markdown-code-block duo-chat gl-bottom-0 gl-max-h-full gl-flex gl-flex-col",class:{
|
|
596
606
|
'resizable-content': _vm.shouldRenderResizable,
|
|
597
607
|
'duo-chat-drawer': !_vm.shouldRenderResizable,
|
|
598
|
-
},attrs:{"id":"chat-component","role":"complementary","data-testid":"chat-component"}},[(_vm.showHeader)?_c('duo-chat-header',{ref:"header",attrs:{"active-thread-id":_vm.activeThreadId,"title":_vm.isMultithreaded && _vm.currentView === 'list' ? _vm.$options.i18n.CHAT_HISTORY_TITLE : _vm.title,"error":_vm.error,"is-multithreaded":_vm.isMultithreaded,"current-view":_vm.currentView,"should-render-resizable":_vm.shouldRenderResizable,"badge-type":_vm.isMultithreaded ? null : _vm.badgeType},on:{"go-back":_vm.onGoBack,"new-chat":_vm.onNewChat,"close":_vm.hideChat},scopedSlots:_vm._u([{key:"subheader",fn:function(){return [_vm._t("subheader")]},proxy:true}],null,true)}):_vm._e(),_vm._v(" "),_c('div',{staticClass:"gl-overflow-y-auto gl-flex gl-flex-col gl-flex-1 gl-flex-grow gl-bg-inherit gl-overscroll-contain",attrs:{"data-testid":"chat-history"},on:{"scroll":_vm.handleScrollingThrottled}},[(_vm.shouldShowThreadList)?_c('duo-chat-threads',{attrs:{"threads":_vm.threadList,"preferred-locale":_vm.preferredLocale},on:{"new-chat":_vm.onNewChat,"select-thread":_vm.onSelectThread,"delete-thread":_vm.onDeleteThread,"close":_vm.hideChat}}):_c('transition-group',{staticClass:"duo-chat-history gl-p-5 gl-mt-auto",attrs:{"mode":"out-in","tag":"section","name":"message"}},[_vm._l((_vm.conversations),function(conversation,index){return _c('duo-chat-conversation',{key:("conversation-" + index),attrs:{"enable-code-insertion":_vm.enableCodeInsertion,"messages":conversation,"canceled-request-ids":_vm.canceledRequestIds,"show-delimiter":index > 0},on:{"track-feedback":_vm.onTrackFeedback,"insert-code-snippet":_vm.onInsertCodeSnippet,"copy-code-snippet":_vm.onCopyCodeSnippet,"get-context-item-content":_vm.onGetContextItemContent}})}),_vm._v(" "),(!_vm.hasMessages && !_vm.isLoading)?[_c('div',{key:"empty-state-message",staticClass:"duo-chat-message gl-rounded-bl-none gl-border-1 gl-border-solid gl-border-gray-50 gl-bg-gray-10 gl-p-4 gl-leading-20 gl-text-gray-900 gl-break-anywhere",attrs:{"data-testid":"gl-duo-chat-empty-state"}},[(_vm.emptyStateTitle)?_c('p',{staticClass:"gl-m-0",attrs:{"data-testid":"gl-duo-chat-empty-state-title"}},[_vm._v("\n "+_vm._s(_vm.emptyStateTitle)+"\n ")]):_vm._e(),_vm._v(" "),_c('duo-chat-predefined-prompts',{key:"predefined-prompts",attrs:{"prompts":_vm.predefinedPrompts},on:{"click":_vm.sendPredefinedPrompt}})],1)]:_vm._e(),_vm._v(" "),(_vm.isLoading)?_c('duo-chat-loader',{key:"loader",attrs:{"tool-name":_vm.toolName}}):_vm._e(),_vm._v(" "),_c('div',{key:"anchor",ref:"anchor",staticClass:"scroll-anchor"})],2)],1),_vm._v(" "),(_vm.isChatAvailable && !_vm.shouldShowThreadList)?_c('footer',{staticClass:"duo-chat-drawer-footer gl-border-0 gl-bg-default gl-pb-3 gl-shrink-0 gl-relative gl-z-2",class:{ 'duo-chat-drawer-body-scrim-on-footer': !_vm.scrolledToBottom },attrs:{"data-testid":"chat-footer"}},[_c('gl-form',{attrs:{"data-testid":"chat-prompt-form"},on:{"submit":function($event){$event.stopPropagation();$event.preventDefault();return _vm.sendChatPrompt.apply(null, arguments)}}},[_c('div',{staticClass:"gl-relative gl-max-w-full"},[_vm._t("context-items-menu",null,{"isOpen":_vm.contextItemsMenuIsOpen,"onClose":_vm.closeContextItemsMenuOpen,"setRef":_vm.setContextItemsMenuRef,"focusPrompt":_vm.focusChatInput})],2),_vm._v(" "),_c('gl-form-input-group',{scopedSlots:_vm._u([{key:"append",fn:function(){return [(_vm.displaySubmitButton)?_c('gl-button',{staticClass:"!gl-absolute gl-bottom-2 gl-right-2 !gl-rounded-full",attrs:{"icon":"paper-airplane","category":"primary","variant":"confirm","type":"submit","data-testid":"chat-prompt-submit-button","aria-label":_vm.$options.i18n.CHAT_SUBMIT_LABEL}}):_c('gl-button',{staticClass:"!gl-absolute gl-bottom-2 gl-right-2 !gl-rounded-full",attrs:{"icon":"stop","category":"primary","variant":"default","data-testid":"chat-prompt-cancel-button","aria-label":_vm.$options.i18n.CHAT_CANCEL_LABEL},on:{"click":_vm.cancelPrompt}})]},proxy:true}],null,false,608602988)},[_c('div',{staticClass:"duo-chat-input gl-min-h-8 gl-max-w-full gl-grow gl-align-top",attrs:{"data-value":_vm.prompt}},[(_vm.shouldShowSlashCommands)?_c('gl-card',{ref:"commands",staticClass:"slash-commands !gl-absolute gl-w-full -gl-translate-y-full gl-list-none gl-pl-0 gl-shadow-md",attrs:{"body-class":"!gl-p-2"}},_vm._l((_vm.filteredSlashCommands),function(command,index){return _c('gl-dropdown-item',{key:command.name,class:{ 'active-command': index === _vm.activeCommandIndex },on:{"click":function($event){return _vm.selectSlashCommand(index)}},nativeOn:{"mouseenter":function($event){_vm.activeCommandIndex = index;}}},[_c('span',{staticClass:"gl-flex gl-justify-between"},[_c('span',{staticClass:"gl-block"},[_vm._v(_vm._s(command.name))]),_vm._v(" "),_c('small',{staticClass:"gl-pl-3 gl-text-right gl-italic gl-text-subtle"},[_vm._v(_vm._s(command.description))])])])}),1):_vm._e(),_vm._v(" "),_c('gl-form-textarea',{ref:"prompt",staticClass:"gl-absolute !gl-h-full gl-rounded-br-none gl-rounded-tr-none !gl-bg-transparent !gl-py-4 !gl-shadow-none",class:{ 'gl-truncate': !_vm.prompt },attrs:{"data-testid":"chat-prompt-input","placeholder":_vm.inputPlaceholder,"autofocus":""},on:{"compositionend":_vm.compositionEnd},nativeOn:{"keydown":function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,"enter",13,$event.key,"Enter")){ return null; }if($event.ctrlKey||$event.shiftKey||$event.altKey||$event.metaKey){ return null; }$event.preventDefault();},"keyup":function($event){return _vm.onInputKeyup.apply(null, arguments)}},model:{value:(_vm.prompt),callback:function ($$v) {_vm.prompt=$$v;},expression:"prompt"}})],1)])],1),_vm._v(" "),_c('p',{staticClass:"gl-mb-0 gl-mt-3 gl-px-4 gl-text-sm gl-text-secondary"},[_vm._v("\n "+_vm._s(_vm.$options.i18n.CHAT_DISCLAMER)+"\n ")])],1):_vm._e()],1):_vm._e()])};
|
|
608
|
+
},attrs:{"id":"chat-component","role":"complementary","data-testid":"chat-component"}},[(_vm.showHeader)?_c('duo-chat-header',{ref:"header",attrs:{"active-thread-id":_vm.activeThreadId,"title":_vm.isMultithreaded && _vm.currentView === 'list' ? _vm.$options.i18n.CHAT_HISTORY_TITLE : _vm.title,"subtitle":_vm.activeThreadTitleForView,"error":_vm.error,"is-multithreaded":_vm.isMultithreaded,"current-view":_vm.currentView,"should-render-resizable":_vm.shouldRenderResizable,"badge-type":_vm.isMultithreaded ? null : _vm.badgeType},on:{"go-back":_vm.onGoBack,"new-chat":_vm.onNewChat,"close":_vm.hideChat},scopedSlots:_vm._u([{key:"subheader",fn:function(){return [_vm._t("subheader")]},proxy:true}],null,true)}):_vm._e(),_vm._v(" "),_c('div',{staticClass:"gl-overflow-y-auto gl-flex gl-flex-col gl-flex-1 gl-flex-grow gl-bg-inherit gl-overscroll-contain",attrs:{"data-testid":"chat-history"},on:{"scroll":_vm.handleScrollingThrottled}},[(_vm.shouldShowThreadList)?_c('duo-chat-threads',{attrs:{"threads":_vm.threadList,"preferred-locale":_vm.preferredLocale},on:{"new-chat":_vm.onNewChat,"select-thread":_vm.onSelectThread,"delete-thread":_vm.onDeleteThread,"close":_vm.hideChat}}):_c('transition-group',{staticClass:"duo-chat-history gl-p-5 gl-mt-auto",attrs:{"mode":"out-in","tag":"section","name":"message"}},[_vm._l((_vm.conversations),function(conversation,index){return _c('duo-chat-conversation',{key:("conversation-" + index),attrs:{"enable-code-insertion":_vm.enableCodeInsertion,"messages":conversation,"canceled-request-ids":_vm.canceledRequestIds,"show-delimiter":index > 0},on:{"track-feedback":_vm.onTrackFeedback,"insert-code-snippet":_vm.onInsertCodeSnippet,"copy-code-snippet":_vm.onCopyCodeSnippet,"get-context-item-content":_vm.onGetContextItemContent}})}),_vm._v(" "),(!_vm.hasMessages && !_vm.isLoading)?[_c('div',{key:"empty-state-message",staticClass:"duo-chat-message gl-rounded-bl-none gl-border-1 gl-border-solid gl-border-gray-50 gl-bg-gray-10 gl-p-4 gl-leading-20 gl-text-gray-900 gl-break-anywhere",attrs:{"data-testid":"gl-duo-chat-empty-state"}},[(_vm.emptyStateTitle)?_c('p',{staticClass:"gl-m-0",attrs:{"data-testid":"gl-duo-chat-empty-state-title"}},[_vm._v("\n "+_vm._s(_vm.emptyStateTitle)+"\n ")]):_vm._e(),_vm._v(" "),_c('duo-chat-predefined-prompts',{key:"predefined-prompts",attrs:{"prompts":_vm.predefinedPrompts},on:{"click":_vm.sendPredefinedPrompt}})],1)]:_vm._e(),_vm._v(" "),(_vm.isLoading)?_c('duo-chat-loader',{key:"loader",attrs:{"tool-name":_vm.toolName}}):_vm._e(),_vm._v(" "),_c('div',{key:"anchor",ref:"anchor",staticClass:"scroll-anchor"})],2)],1),_vm._v(" "),(_vm.isChatAvailable && !_vm.shouldShowThreadList)?_c('footer',{staticClass:"duo-chat-drawer-footer gl-border-0 gl-bg-default gl-pb-3 gl-shrink-0 gl-relative gl-z-2",class:{ 'duo-chat-drawer-body-scrim-on-footer': !_vm.scrolledToBottom },attrs:{"data-testid":"chat-footer"}},[_c('gl-form',{attrs:{"data-testid":"chat-prompt-form"},on:{"submit":function($event){$event.stopPropagation();$event.preventDefault();return _vm.sendChatPrompt.apply(null, arguments)}}},[_c('div',{staticClass:"gl-relative gl-max-w-full"},[_vm._t("context-items-menu",null,{"isOpen":_vm.contextItemsMenuIsOpen,"onClose":_vm.closeContextItemsMenuOpen,"setRef":_vm.setContextItemsMenuRef,"focusPrompt":_vm.focusChatInput})],2),_vm._v(" "),_c('gl-form-input-group',{scopedSlots:_vm._u([{key:"append",fn:function(){return [(_vm.displaySubmitButton)?_c('gl-button',{staticClass:"!gl-absolute gl-bottom-2 gl-right-2 !gl-rounded-full",attrs:{"icon":"paper-airplane","category":"primary","variant":"confirm","type":"submit","data-testid":"chat-prompt-submit-button","aria-label":_vm.$options.i18n.CHAT_SUBMIT_LABEL}}):_c('gl-button',{staticClass:"!gl-absolute gl-bottom-2 gl-right-2 !gl-rounded-full",attrs:{"icon":"stop","category":"primary","variant":"default","data-testid":"chat-prompt-cancel-button","aria-label":_vm.$options.i18n.CHAT_CANCEL_LABEL},on:{"click":_vm.cancelPrompt}})]},proxy:true}],null,false,608602988)},[_c('div',{staticClass:"duo-chat-input gl-min-h-8 gl-max-w-full gl-grow gl-align-top",attrs:{"data-value":_vm.prompt}},[(_vm.shouldShowSlashCommands)?_c('gl-card',{ref:"commands",staticClass:"slash-commands !gl-absolute gl-w-full -gl-translate-y-full gl-list-none gl-pl-0 gl-shadow-md",attrs:{"body-class":"!gl-p-2"}},_vm._l((_vm.filteredSlashCommands),function(command,index){return _c('gl-dropdown-item',{key:command.name,class:{ 'active-command': index === _vm.activeCommandIndex },on:{"click":function($event){return _vm.selectSlashCommand(index)}},nativeOn:{"mouseenter":function($event){_vm.activeCommandIndex = index;}}},[_c('span',{staticClass:"gl-flex gl-justify-between"},[_c('span',{staticClass:"gl-block"},[_vm._v(_vm._s(command.name))]),_vm._v(" "),_c('small',{staticClass:"gl-pl-3 gl-text-right gl-italic gl-text-subtle"},[_vm._v(_vm._s(command.description))])])])}),1):_vm._e(),_vm._v(" "),_c('gl-form-textarea',{ref:"prompt",staticClass:"gl-absolute !gl-h-full gl-rounded-br-none gl-rounded-tr-none !gl-bg-transparent !gl-py-4 !gl-shadow-none",class:{ 'gl-truncate': !_vm.prompt },attrs:{"data-testid":"chat-prompt-input","placeholder":_vm.inputPlaceholder,"autofocus":""},on:{"compositionend":_vm.compositionEnd},nativeOn:{"keydown":function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,"enter",13,$event.key,"Enter")){ return null; }if($event.ctrlKey||$event.shiftKey||$event.altKey||$event.metaKey){ return null; }$event.preventDefault();},"keyup":function($event){return _vm.onInputKeyup.apply(null, arguments)}},model:{value:(_vm.prompt),callback:function ($$v) {_vm.prompt=$$v;},expression:"prompt"}})],1)])],1),_vm._v(" "),_c('p',{staticClass:"gl-mb-0 gl-mt-3 gl-px-4 gl-text-sm gl-text-secondary"},[_vm._v("\n "+_vm._s(_vm.$options.i18n.CHAT_DISCLAMER)+"\n ")])],1):_vm._e()],1):_vm._e()])};
|
|
599
609
|
var __vue_staticRenderFns__ = [];
|
|
600
610
|
|
|
601
611
|
/* style */
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@gitlab/duo-ui",
|
|
3
|
-
"version": "8.
|
|
3
|
+
"version": "8.9.0",
|
|
4
4
|
"description": "Duo UI Components",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -139,7 +139,7 @@
|
|
|
139
139
|
"esbuild": "^0.18.0",
|
|
140
140
|
"eslint": "8.57.1",
|
|
141
141
|
"eslint-import-resolver-jest": "3.0.2",
|
|
142
|
-
"eslint-plugin-storybook": "0.
|
|
142
|
+
"eslint-plugin-storybook": "0.12.0",
|
|
143
143
|
"gitlab-api-async-iterator": "^1.3.1",
|
|
144
144
|
"glob": "10.3.3",
|
|
145
145
|
"globby": "^11.1.0",
|
|
@@ -3,9 +3,7 @@ export const CONTEXT_ITEM_CATEGORY_MERGE_REQUEST = 'merge_request';
|
|
|
3
3
|
export const CONTEXT_ITEM_CATEGORY_FILE = 'file';
|
|
4
4
|
export const CONTEXT_ITEM_CATEGORY_LOCAL_GIT = 'local_git';
|
|
5
5
|
export const CONTEXT_ITEM_CATEGORY_DEPENDENCY = 'dependency';
|
|
6
|
-
|
|
7
|
-
export const CONTEXT_ITEM_LOCAL_GIT_COMMIT = 'commit';
|
|
8
|
-
export const CONTEXT_ITEM_LOCAL_GIT_DIFF = 'diff';
|
|
6
|
+
export const CONTEXT_ITEM_CATEGORY_TERMINAL_SELECTION = 'terminal';
|
|
9
7
|
|
|
10
8
|
export const LANGUAGE_IDENTIFIER_PREFIX = 'language-';
|
|
11
9
|
export const LANGUAGE_IDENTIFIER_DIFF = 'language-diff';
|
|
@@ -7,6 +7,7 @@ import {
|
|
|
7
7
|
CONTEXT_ITEM_CATEGORY_DEPENDENCY,
|
|
8
8
|
CONTEXT_ITEM_CATEGORY_FILE,
|
|
9
9
|
CONTEXT_ITEM_CATEGORY_LOCAL_GIT,
|
|
10
|
+
CONTEXT_ITEM_CATEGORY_TERMINAL_SELECTION,
|
|
10
11
|
} from '../constants';
|
|
11
12
|
import DuoChatContextItemDetailsModal from '../duo_chat_context_item_details_modal/duo_chat_context_item_details_modal.vue';
|
|
12
13
|
import { contextItemsValidator } from '../utils';
|
|
@@ -117,6 +118,7 @@ export default {
|
|
|
117
118
|
CONTEXT_ITEM_CATEGORY_LOCAL_GIT,
|
|
118
119
|
CONTEXT_ITEM_CATEGORY_FILE,
|
|
119
120
|
CONTEXT_ITEM_CATEGORY_DEPENDENCY,
|
|
121
|
+
CONTEXT_ITEM_CATEGORY_TERMINAL_SELECTION,
|
|
120
122
|
].includes(contextItem.category);
|
|
121
123
|
},
|
|
122
124
|
onClosePreview() {
|
|
@@ -352,6 +352,24 @@ const mockDependencies = [
|
|
|
352
352
|
},
|
|
353
353
|
];
|
|
354
354
|
|
|
355
|
+
const mockTerminalOutput =
|
|
356
|
+
'$ npx cowsay "moo"\n _____\n< moo >\n -----\n \\ ^__^\n \\ (oo)\\_______\n (__)\\ )\\/\\\n ||----w |\n || ||';
|
|
357
|
+
const mockTerminalOutputLines = mockTerminalOutput.split('\n');
|
|
358
|
+
export const MOCK_CONTEXT_ITEM_TERMINAL = {
|
|
359
|
+
id: 'cb94e08e-f2f6-408a-8f43-036079d19e47',
|
|
360
|
+
category: 'terminal',
|
|
361
|
+
content: mockTerminalOutput,
|
|
362
|
+
metadata: {
|
|
363
|
+
title: mockTerminalOutput.split('\n').at(0),
|
|
364
|
+
enabled: true,
|
|
365
|
+
subType: 'snippet',
|
|
366
|
+
icon: 'terminal',
|
|
367
|
+
subTypeLabel: 'Selected terminal output',
|
|
368
|
+
secondaryText: `${mockTerminalOutputLines.length} lines of terminal output`,
|
|
369
|
+
},
|
|
370
|
+
};
|
|
371
|
+
const mockTerminalSelections = [MOCK_CONTEXT_ITEM_TERMINAL];
|
|
372
|
+
|
|
355
373
|
export const getMockContextItems = () => {
|
|
356
374
|
const allItems = [
|
|
357
375
|
...mockFiles,
|
|
@@ -359,6 +377,7 @@ export const getMockContextItems = () => {
|
|
|
359
377
|
...mockIssues,
|
|
360
378
|
...mockMergeRequests,
|
|
361
379
|
...mockDependencies,
|
|
380
|
+
...mockTerminalSelections,
|
|
362
381
|
];
|
|
363
382
|
|
|
364
383
|
// put disabled items in the back
|
|
@@ -36,6 +36,11 @@ export default {
|
|
|
36
36
|
required: false,
|
|
37
37
|
default: i18n.CHAT_TITLE,
|
|
38
38
|
},
|
|
39
|
+
subtitle: {
|
|
40
|
+
type: String,
|
|
41
|
+
required: false,
|
|
42
|
+
default: '',
|
|
43
|
+
},
|
|
39
44
|
error: {
|
|
40
45
|
type: String,
|
|
41
46
|
required: false,
|
|
@@ -103,8 +108,19 @@ export default {
|
|
|
103
108
|
@click="$emit('new-chat')"
|
|
104
109
|
/>
|
|
105
110
|
|
|
106
|
-
<
|
|
107
|
-
|
|
111
|
+
<div class="gl-flex-1 gl-overflow-hidden">
|
|
112
|
+
<div class="gl-flex gl-items-center">
|
|
113
|
+
<h3 class="gl-my-0 gl-text-size-h2">{{ title }}</h3>
|
|
114
|
+
<gl-experiment-badge v-if="badgeType" :type="badgeType" container-id="chat-component" />
|
|
115
|
+
</div>
|
|
116
|
+
<h4
|
|
117
|
+
v-if="subtitle"
|
|
118
|
+
class="gl-text-base gl-whitespace-nowrap gl-overflow-hidden gl-text-ellipsis gl-font-normal text-muted gl-mb-0"
|
|
119
|
+
data-testid="chat-subtitle"
|
|
120
|
+
>
|
|
121
|
+
{{ subtitle }}
|
|
122
|
+
</h4>
|
|
123
|
+
</div>
|
|
108
124
|
<gl-button
|
|
109
125
|
category="tertiary"
|
|
110
126
|
variant="default"
|
|
@@ -403,6 +403,17 @@ export default {
|
|
|
403
403
|
hasContextItemSelectionMenu() {
|
|
404
404
|
return Boolean(this.contextItemMenuRef);
|
|
405
405
|
},
|
|
406
|
+
activeThread() {
|
|
407
|
+
return this.activeThreadId
|
|
408
|
+
? this.threadList.find((thread) => thread.id === this.activeThreadId)
|
|
409
|
+
: null;
|
|
410
|
+
},
|
|
411
|
+
activeThreadTitle() {
|
|
412
|
+
return this.activeThread?.title;
|
|
413
|
+
},
|
|
414
|
+
activeThreadTitleForView() {
|
|
415
|
+
return (this.currentView === VIEW_TYPES.CHAT && this.activeThreadTitle) || '';
|
|
416
|
+
},
|
|
406
417
|
},
|
|
407
418
|
watch: {
|
|
408
419
|
multiThreadedView(newView) {
|
|
@@ -693,6 +704,7 @@ export default {
|
|
|
693
704
|
:title="
|
|
694
705
|
isMultithreaded && currentView === 'list' ? $options.i18n.CHAT_HISTORY_TITLE : title
|
|
695
706
|
"
|
|
707
|
+
:subtitle="activeThreadTitleForView"
|
|
696
708
|
:error="error"
|
|
697
709
|
:is-multithreaded="isMultithreaded"
|
|
698
710
|
:current-view="currentView"
|