@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 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 CONTEXT_ITEM_LOCAL_GIT_COMMIT = 'commit';
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, CONTEXT_ITEM_LOCAL_GIT_COMMIT, CONTEXT_ITEM_LOCAL_GIT_DIFF, LANGUAGE_IDENTIFIER_DIFF, LANGUAGE_IDENTIFIER_PLAINTEXT, LANGUAGE_IDENTIFIER_PREFIX };
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.7.11",
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.11.6",
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