@gitlab/duo-ui 8.7.11 → 8.8.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 +7 -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/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/CHANGELOG.md
CHANGED
|
@@ -1,3 +1,10 @@
|
|
|
1
|
+
# [8.8.0](https://gitlab.com/gitlab-org/duo-ui/compare/v8.7.11...v8.8.0) (2025-03-31)
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
### Features
|
|
5
|
+
|
|
6
|
+
* support terminal context category ([2aefdc6](https://gitlab.com/gitlab-org/duo-ui/commit/2aefdc60b95cbff87c8a6e284e01ef3f4e95da8c))
|
|
7
|
+
|
|
1
8
|
## [8.7.11](https://gitlab.com/gitlab-org/duo-ui/compare/v8.7.10...v8.7.11) (2025-03-28)
|
|
2
9
|
|
|
3
10
|
|
|
@@ -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 };
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@gitlab/duo-ui",
|
|
3
|
-
"version": "8.
|
|
3
|
+
"version": "8.8.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
|