@codingame/monaco-vscode-views-service-override 1.85.0 → 1.85.2

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.
Files changed (44) hide show
  1. package/assets/index-no-csp.html +4 -0
  2. package/assets/index.html +5 -1
  3. package/index.d.ts +2 -2
  4. package/index.js +2 -2
  5. package/package.json +11 -9
  6. package/tools/editor.js +1 -1
  7. package/views.d.ts +9 -4
  8. package/views.js +32 -10
  9. package/vscode/src/vs/workbench/api/browser/viewsExtensionPoint.js +2 -2
  10. package/vscode/src/vs/workbench/contrib/customEditor/browser/customEditorInputFactory.js +1 -1
  11. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/commands/commands.js +692 -0
  12. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/commands/devCommands.js +240 -0
  13. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/mergeEditor.contribution.js +77 -0
  14. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/mergeEditorSerializer.js +42 -0
  15. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/colors.js +71 -0
  16. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/conflictActions.js +346 -0
  17. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editorGutter.js +96 -0
  18. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editors/baseCodeEditorView.js +145 -0
  19. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editors/codeEditorView.js +103 -0
  20. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editors/inputCodeEditorView.js +399 -0
  21. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView.js +196 -0
  22. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/fixedZoneWidget.js +41 -0
  23. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/lineAlignment.js +128 -0
  24. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/media/mergeEditor.css.js +6 -0
  25. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/mergeEditor.js +611 -0
  26. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/scrollSynchronizer.js +158 -0
  27. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/viewModel.js +262 -0
  28. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/viewZones.js +173 -0
  29. package/vscode/src/vs/workbench/contrib/webview/browser/webview.contribution.js +79 -0
  30. package/vscode/src/vs/workbench/contrib/webview/browser/webviewFindWidget.js +1 -1
  31. package/vscode/src/vs/workbench/services/history/browser/historyService.js +3 -0
  32. package/override/vs/workbench/contrib/notebook/common/notebookEditorInput.js +0 -3
  33. package/vscode/src/vs/base/browser/ui/tree/treeDefaults.js +0 -16
  34. package/vscode/src/vs/workbench/browser/parts/views/checkbox.js +0 -107
  35. package/vscode/src/vs/workbench/browser/parts/views/media/views.css.js +0 -6
  36. package/vscode/src/vs/workbench/browser/parts/views/treeView.js +0 -1604
  37. package/vscode/src/vs/workbench/contrib/codeEditor/browser/find/simpleFindWidget.css.js +0 -6
  38. package/vscode/src/vs/workbench/contrib/codeEditor/browser/find/simpleFindWidget.js +0 -390
  39. package/vscode/src/vs/workbench/contrib/languageDetection/browser/languageDetection.contribution.js +0 -157
  40. package/vscode/src/vs/workbench/contrib/notebook/common/notebookContextKeys.js +0 -5
  41. package/vscode/src/vs/workbench/contrib/remote/browser/media/tunnelView.css.js +0 -6
  42. package/vscode/src/vs/workbench/contrib/remote/browser/remoteExplorer.js +0 -217
  43. package/vscode/src/vs/workbench/contrib/remote/browser/remoteIcons.js +0 -91
  44. package/vscode/src/vs/workbench/contrib/remote/browser/tunnelView.js +0 -1837
@@ -0,0 +1,196 @@
1
+ import { __decorate, __param } from '../../../../../../../../../external/tslib/tslib.es6.js';
2
+ import { reset } from 'monaco-editor/esm/vs/base/browser/dom.js';
3
+ import { ActionBar } from 'monaco-editor/esm/vs/base/browser/ui/actionbar/actionbar.js';
4
+ import { renderLabelWithIcons } from 'monaco-editor/esm/vs/base/browser/ui/iconLabel/iconLabels.js';
5
+ import { CompareResult } from 'monaco-editor/esm/vs/base/common/arrays.js';
6
+ import { BugIndicatingError } from 'monaco-editor/esm/vs/base/common/errors.js';
7
+ import { toDisposable } from 'monaco-editor/esm/vs/base/common/lifecycle.js';
8
+ import { derived, autorunWithStore, autorun } from 'monaco-editor/esm/vs/base/common/observable.js';
9
+ import { MinimapPosition, OverviewRulerLane } from 'monaco-editor/esm/vs/editor/common/model.js';
10
+ import { localizeWithPath } from 'monaco-editor/esm/vs/nls.js';
11
+ import { MenuId } from 'monaco-editor/esm/vs/platform/actions/common/actions.js';
12
+ import { IConfigurationService } from 'monaco-editor/esm/vs/platform/configuration/common/configuration.js';
13
+ import { IContextKeyService } from 'monaco-editor/esm/vs/platform/contextkey/common/contextkey.js';
14
+ import { IInstantiationService } from 'monaco-editor/esm/vs/platform/instantiation/common/instantiation.js';
15
+ import { ILabelService } from 'monaco-editor/esm/vs/platform/label/common/label.js';
16
+ import { LineRange } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/browser/model/lineRange';
17
+ import { join, applyObservableDecorations } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/browser/utils';
18
+ import { handledConflictMinimapOverViewRulerColor, unhandledConflictMinimapOverViewRulerColor } from '../colors.js';
19
+ import { EditorGutter } from '../editorGutter.js';
20
+ import { ctxIsMergeResultEditor } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/common/mergeEditor';
21
+ import { CodeEditorView, createSelectionsAutorun, TitleMenu } from './codeEditorView.js';
22
+
23
+ let ResultCodeEditorView = class ResultCodeEditorView extends CodeEditorView {
24
+ constructor(viewModel, instantiationService, _labelService, configurationService) {
25
+ super(instantiationService, viewModel, configurationService);
26
+ this._labelService = _labelService;
27
+ this.decorations = derived(this, reader => {
28
+ const viewModel = this.viewModel.read(reader);
29
+ if (!viewModel) {
30
+ return [];
31
+ }
32
+ const model = viewModel.model;
33
+ const textModel = model.resultTextModel;
34
+ const result = ( new Array());
35
+ const baseRangeWithStoreAndTouchingDiffs = join(model.modifiedBaseRanges.read(reader), model.baseResultDiffs.read(reader), (baseRange, diff) => baseRange.baseRange.touches(diff.inputRange)
36
+ ? CompareResult.neitherLessOrGreaterThan
37
+ : LineRange.compareByStart(baseRange.baseRange, diff.inputRange));
38
+ const activeModifiedBaseRange = viewModel.activeModifiedBaseRange.read(reader);
39
+ const showNonConflictingChanges = viewModel.showNonConflictingChanges.read(reader);
40
+ for (const m of baseRangeWithStoreAndTouchingDiffs) {
41
+ const modifiedBaseRange = m.left;
42
+ if (modifiedBaseRange) {
43
+ const blockClassNames = ['merge-editor-block'];
44
+ let blockPadding = [0, 0, 0, 0];
45
+ const isHandled = model.isHandled(modifiedBaseRange).read(reader);
46
+ if (isHandled) {
47
+ blockClassNames.push('handled');
48
+ }
49
+ if (modifiedBaseRange === activeModifiedBaseRange) {
50
+ blockClassNames.push('focused');
51
+ blockPadding = [0, 2, 0, 2];
52
+ }
53
+ if (modifiedBaseRange.isConflicting) {
54
+ blockClassNames.push('conflicting');
55
+ }
56
+ blockClassNames.push('result');
57
+ if (!modifiedBaseRange.isConflicting && !showNonConflictingChanges && isHandled) {
58
+ continue;
59
+ }
60
+ const range = model.getLineRangeInResult(modifiedBaseRange.baseRange, reader);
61
+ result.push({
62
+ range: range.toInclusiveRangeOrEmpty(),
63
+ options: {
64
+ showIfCollapsed: true,
65
+ blockClassName: blockClassNames.join(' '),
66
+ blockPadding,
67
+ blockIsAfterEnd: range.startLineNumber > textModel.getLineCount(),
68
+ description: 'Result Diff',
69
+ minimap: {
70
+ position: MinimapPosition.Gutter,
71
+ color: { id: isHandled ? handledConflictMinimapOverViewRulerColor : unhandledConflictMinimapOverViewRulerColor },
72
+ },
73
+ overviewRuler: modifiedBaseRange.isConflicting ? {
74
+ position: OverviewRulerLane.Center,
75
+ color: { id: isHandled ? handledConflictMinimapOverViewRulerColor : unhandledConflictMinimapOverViewRulerColor },
76
+ } : undefined
77
+ }
78
+ });
79
+ }
80
+ if (!modifiedBaseRange || modifiedBaseRange.isConflicting) {
81
+ for (const diff of m.rights) {
82
+ const range = diff.outputRange.toInclusiveRange();
83
+ if (range) {
84
+ result.push({
85
+ range,
86
+ options: {
87
+ className: `merge-editor-diff result`,
88
+ description: 'Merge Editor',
89
+ isWholeLine: true,
90
+ }
91
+ });
92
+ }
93
+ if (diff.rangeMappings) {
94
+ for (const d of diff.rangeMappings) {
95
+ result.push({
96
+ range: d.outputRange,
97
+ options: {
98
+ className: `merge-editor-diff-word result`,
99
+ description: 'Merge Editor'
100
+ }
101
+ });
102
+ }
103
+ }
104
+ }
105
+ }
106
+ }
107
+ return result;
108
+ });
109
+ this.editor.invokeWithinContext(accessor => {
110
+ const contextKeyService = accessor.get(IContextKeyService);
111
+ const isMergeResultEditor = ctxIsMergeResultEditor.bindTo(contextKeyService);
112
+ isMergeResultEditor.set(true);
113
+ this._register(toDisposable(() => isMergeResultEditor.reset()));
114
+ });
115
+ this.htmlElements.gutterDiv.style.width = '5px';
116
+ this.htmlElements.root.classList.add(`result`);
117
+ this._register(autorunWithStore((reader, store) => {
118
+ if (this.checkboxesVisible.read(reader)) {
119
+ store.add(( new EditorGutter(this.editor, this.htmlElements.gutterDiv, {
120
+ getIntersectingGutterItems: (range, reader) => [],
121
+ createView: (item, target) => { throw new BugIndicatingError(); },
122
+ })));
123
+ }
124
+ }));
125
+ this._register(autorun(reader => {
126
+ const vm = this.viewModel.read(reader);
127
+ if (!vm) {
128
+ return;
129
+ }
130
+ this.editor.setModel(vm.model.resultTextModel);
131
+ reset(this.htmlElements.title, ...renderLabelWithIcons(( localizeWithPath(
132
+ 'vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView',
133
+ 'result',
134
+ 'Result'
135
+ ))));
136
+ reset(this.htmlElements.description, ...renderLabelWithIcons(this._labelService.getUriLabel(vm.model.resultTextModel.uri, { relative: true })));
137
+ }));
138
+ const remainingConflictsActionBar = this._register(( new ActionBar(this.htmlElements.detail)));
139
+ this._register(autorun(reader => {
140
+ const vm = this.viewModel.read(reader);
141
+ if (!vm) {
142
+ return;
143
+ }
144
+ const model = vm.model;
145
+ if (!model) {
146
+ return;
147
+ }
148
+ const count = model.unhandledConflictsCount.read(reader);
149
+ const text = count === 1
150
+ ? ( localizeWithPath(
151
+ 'vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView',
152
+ 'mergeEditor.remainingConflicts',
153
+ '{0} Conflict Remaining',
154
+ count
155
+ ))
156
+ : ( localizeWithPath(
157
+ 'vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView',
158
+ 'mergeEditor.remainingConflict',
159
+ '{0} Conflicts Remaining ',
160
+ count
161
+ ));
162
+ remainingConflictsActionBar.clear();
163
+ remainingConflictsActionBar.push({
164
+ class: undefined,
165
+ enabled: count > 0,
166
+ id: 'nextConflict',
167
+ label: text,
168
+ run() {
169
+ vm.model.telemetry.reportConflictCounterClicked();
170
+ vm.goToNextModifiedBaseRange(m => !model.isHandled(m).get());
171
+ },
172
+ tooltip: count > 0
173
+ ? ( localizeWithPath(
174
+ 'vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView',
175
+ 'goToNextConflict',
176
+ 'Go to next conflict'
177
+ ))
178
+ : ( localizeWithPath(
179
+ 'vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView',
180
+ 'allConflictHandled',
181
+ 'All conflicts handled, the merge can be completed now.'
182
+ )),
183
+ });
184
+ }));
185
+ this._register(applyObservableDecorations(this.editor, this.decorations));
186
+ this._register(createSelectionsAutorun(this, (baseRange, viewModel) => viewModel.model.translateBaseRangeToResult(baseRange)));
187
+ this._register(instantiationService.createInstance(TitleMenu, MenuId.MergeInputResultToolbar, this.htmlElements.toolbar));
188
+ }
189
+ };
190
+ ResultCodeEditorView = ( __decorate([
191
+ ( __param(1, IInstantiationService)),
192
+ ( __param(2, ILabelService)),
193
+ ( __param(3, IConfigurationService))
194
+ ], ResultCodeEditorView));
195
+
196
+ export { ResultCodeEditorView };
@@ -0,0 +1,41 @@
1
+ import { h } from 'monaco-editor/esm/vs/base/browser/dom.js';
2
+ import { Disposable } from 'monaco-editor/esm/vs/base/common/lifecycle.js';
3
+ import { Event } from 'monaco-editor/esm/vs/base/common/event.js';
4
+
5
+ class FixedZoneWidget extends Disposable {
6
+ static { this.counter = 0; }
7
+ constructor(editor, viewZoneAccessor, afterLineNumber, height, viewZoneIdsToCleanUp) {
8
+ super();
9
+ this.editor = editor;
10
+ this.overlayWidgetId = `fixedZoneWidget-${FixedZoneWidget.counter++}`;
11
+ this.widgetDomNode = h('div.fixed-zone-widget').root;
12
+ this.overlayWidget = {
13
+ getId: () => this.overlayWidgetId,
14
+ getDomNode: () => this.widgetDomNode,
15
+ getPosition: () => null
16
+ };
17
+ this.viewZoneId = viewZoneAccessor.addZone({
18
+ domNode: document.createElement('div'),
19
+ afterLineNumber: afterLineNumber,
20
+ heightInPx: height,
21
+ onComputedHeight: (height) => {
22
+ this.widgetDomNode.style.height = `${height}px`;
23
+ },
24
+ onDomNodeTop: (top) => {
25
+ this.widgetDomNode.style.top = `${top}px`;
26
+ }
27
+ });
28
+ viewZoneIdsToCleanUp.push(this.viewZoneId);
29
+ this._register(Event.runAndSubscribe(this.editor.onDidLayoutChange, () => {
30
+ this.widgetDomNode.style.left = this.editor.getLayoutInfo().contentLeft + 'px';
31
+ }));
32
+ this.editor.addOverlayWidget(this.overlayWidget);
33
+ this._register({
34
+ dispose: () => {
35
+ this.editor.removeOverlayWidget(this.overlayWidget);
36
+ },
37
+ });
38
+ }
39
+ }
40
+
41
+ export { FixedZoneWidget };
@@ -0,0 +1,128 @@
1
+ import { compareBy } from 'monaco-editor/esm/vs/base/common/arrays.js';
2
+ import { assertFn, checkAdjacentItems } from 'monaco-editor/esm/vs/base/common/assert.js';
3
+ import { isDefined } from 'monaco-editor/esm/vs/base/common/types.js';
4
+ import { Position } from 'monaco-editor/esm/vs/editor/common/core/position.js';
5
+ import { Range } from 'monaco-editor/esm/vs/editor/common/core/range.js';
6
+ import { LengthObj } from 'monaco-editor/esm/vs/editor/common/model/bracketPairsTextModelPart/bracketPairsTree/length.js';
7
+ import { RangeMapping } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/browser/model/mapping';
8
+ import { lengthOfRange, lengthBetweenPositions, addLength } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/browser/model/rangeUtils';
9
+
10
+ function getAlignments(m) {
11
+ const equalRanges1 = toEqualRangeMappings(m.input1Diffs.flatMap(d => d.rangeMappings), m.baseRange.toRange(), m.input1Range.toRange());
12
+ const equalRanges2 = toEqualRangeMappings(m.input2Diffs.flatMap(d => d.rangeMappings), m.baseRange.toRange(), m.input2Range.toRange());
13
+ const commonRanges = splitUpCommonEqualRangeMappings(equalRanges1, equalRanges2);
14
+ let result = [];
15
+ result.push([m.input1Range.startLineNumber - 1, m.baseRange.startLineNumber - 1, m.input2Range.startLineNumber - 1]);
16
+ function isFullSync(lineAlignment) {
17
+ return lineAlignment.every((i) => i !== undefined);
18
+ }
19
+ for (const m of commonRanges) {
20
+ const lineAlignment = [m.output1Pos?.lineNumber, m.inputPos.lineNumber, m.output2Pos?.lineNumber];
21
+ const alignmentIsFullSync = isFullSync(lineAlignment);
22
+ let shouldAdd = true;
23
+ if (alignmentIsFullSync) {
24
+ const isNewFullSyncAlignment = !( result.some(r => isFullSync(r) && ( r.some((v, idx) => v !== undefined && v === lineAlignment[idx]))));
25
+ if (isNewFullSyncAlignment) {
26
+ result = result.filter(r => !( r.some((v, idx) => v !== undefined && v === lineAlignment[idx])));
27
+ }
28
+ shouldAdd = isNewFullSyncAlignment;
29
+ }
30
+ else {
31
+ const isNew = !( result.some(r => ( r.some((v, idx) => v !== undefined && v === lineAlignment[idx]))));
32
+ shouldAdd = isNew;
33
+ }
34
+ if (shouldAdd) {
35
+ result.push(lineAlignment);
36
+ }
37
+ else {
38
+ if (m.length.isGreaterThan(( new LengthObj(1, 0)))) {
39
+ result.push([
40
+ m.output1Pos ? m.output1Pos.lineNumber + 1 : undefined,
41
+ m.inputPos.lineNumber + 1,
42
+ m.output2Pos ? m.output2Pos.lineNumber + 1 : undefined
43
+ ]);
44
+ }
45
+ }
46
+ }
47
+ const finalLineAlignment = [m.input1Range.endLineNumberExclusive, m.baseRange.endLineNumberExclusive, m.input2Range.endLineNumberExclusive];
48
+ result = result.filter(r => r.every((v, idx) => v !== finalLineAlignment[idx]));
49
+ result.push(finalLineAlignment);
50
+ assertFn(() => checkAdjacentItems(( result.map(r => r[0])).filter(isDefined), (a, b) => a < b)
51
+ && checkAdjacentItems(( result.map(r => r[1])).filter(isDefined), (a, b) => a <= b)
52
+ && checkAdjacentItems(( result.map(r => r[2])).filter(isDefined), (a, b) => a < b)
53
+ && result.every(alignment => alignment.filter(isDefined).length >= 2));
54
+ return result;
55
+ }
56
+ function toEqualRangeMappings(diffs, inputRange, outputRange) {
57
+ const result = [];
58
+ let equalRangeInputStart = inputRange.getStartPosition();
59
+ let equalRangeOutputStart = outputRange.getStartPosition();
60
+ for (const d of diffs) {
61
+ const equalRangeMapping = ( new RangeMapping(
62
+ Range.fromPositions(equalRangeInputStart, d.inputRange.getStartPosition()),
63
+ Range.fromPositions(equalRangeOutputStart, d.outputRange.getStartPosition())
64
+ ));
65
+ assertFn(() => lengthOfRange(equalRangeMapping.inputRange).equals(lengthOfRange(equalRangeMapping.outputRange)));
66
+ if (!equalRangeMapping.inputRange.isEmpty()) {
67
+ result.push(equalRangeMapping);
68
+ }
69
+ equalRangeInputStart = d.inputRange.getEndPosition();
70
+ equalRangeOutputStart = d.outputRange.getEndPosition();
71
+ }
72
+ const equalRangeMapping = ( new RangeMapping(
73
+ Range.fromPositions(equalRangeInputStart, inputRange.getEndPosition()),
74
+ Range.fromPositions(equalRangeOutputStart, outputRange.getEndPosition())
75
+ ));
76
+ assertFn(() => lengthOfRange(equalRangeMapping.inputRange).equals(lengthOfRange(equalRangeMapping.outputRange)));
77
+ if (!equalRangeMapping.inputRange.isEmpty()) {
78
+ result.push(equalRangeMapping);
79
+ }
80
+ return result;
81
+ }
82
+ function splitUpCommonEqualRangeMappings(equalRangeMappings1, equalRangeMappings2) {
83
+ const result = [];
84
+ const events = [];
85
+ for (const [input, rangeMappings] of [[0, equalRangeMappings1], [1, equalRangeMappings2]]) {
86
+ for (const rangeMapping of rangeMappings) {
87
+ events.push({
88
+ input: input,
89
+ start: true,
90
+ inputPos: rangeMapping.inputRange.getStartPosition(),
91
+ outputPos: rangeMapping.outputRange.getStartPosition()
92
+ });
93
+ events.push({
94
+ input: input,
95
+ start: false,
96
+ inputPos: rangeMapping.inputRange.getEndPosition(),
97
+ outputPos: rangeMapping.outputRange.getEndPosition()
98
+ });
99
+ }
100
+ }
101
+ events.sort(compareBy((m) => m.inputPos, Position.compare));
102
+ const starts = [undefined, undefined];
103
+ let lastInputPos;
104
+ for (const event of events) {
105
+ if (lastInputPos && ( starts.some(s => !!s))) {
106
+ const length = lengthBetweenPositions(lastInputPos, event.inputPos);
107
+ if (!length.isZero()) {
108
+ result.push({
109
+ inputPos: lastInputPos,
110
+ length,
111
+ output1Pos: starts[0],
112
+ output2Pos: starts[1]
113
+ });
114
+ if (starts[0]) {
115
+ starts[0] = addLength(starts[0], length);
116
+ }
117
+ if (starts[1]) {
118
+ starts[1] = addLength(starts[1], length);
119
+ }
120
+ }
121
+ }
122
+ starts[event.input] = event.start ? event.outputPos : undefined;
123
+ lastInputPos = event.inputPos;
124
+ }
125
+ return result;
126
+ }
127
+
128
+ export { getAlignments };
@@ -0,0 +1,6 @@
1
+ import n from '../../../../../../../../../external/rollup-plugin-styles/dist/runtime/inject-css.js';
2
+
3
+ var css = ".monaco-workbench .merge-editor .code-view>.header{align-content:center;display:flex;height:30px;overflow:hidden;padding:0 10px}.monaco-workbench .merge-editor .code-view>.header>span{align-self:center;overflow:hidden;padding-right:6px;text-overflow:ellipsis;white-space:nowrap}.monaco-workbench .merge-editor .code-view>.header>span.title{flex-shrink:0}.monaco-workbench .merge-editor .code-view>.header>span.description{align-items:center;color:var(--vscode-descriptionForeground);display:flex;flex-shrink:0;font-size:12px}.monaco-workbench .merge-editor .code-view.result>.header>.description{display:inline;flex-shrink:1}.monaco-workbench .merge-editor .code-view.result>.header>.detail,.monaco-workbench .merge-editor .code-view.result>.header>.toolbar{flex-shrink:0}.monaco-workbench .merge-editor .code-view>.header>span.description .codicon{color:var(--vscode-descriptionForeground);font-size:14px}.monaco-workbench .merge-editor .code-view>.header>span.detail{color:var(--vscode-descriptionForeground);font-size:12px;margin-left:auto}.monaco-workbench .merge-editor .code-view>.header>span.detail .codicon{font-size:13px}.monaco-workbench .merge-editor .code-view.input>.header>span.detail:before{content:\"•\";opacity:.5;padding-right:3px}.monaco-workbench .merge-editor .code-view.input>.header>span.detail{margin-left:0}.monaco-workbench .merge-editor .code-view.input>.header>span.toolbar{flex-shrink:0;margin-left:auto}.monaco-workbench .merge-editor .code-view>.container{display:flex;flex-direction:row}.monaco-workbench .merge-editor .code-view>.container>.gutter{flex-grow:0;flex-shrink:0;overflow:hidden;position:relative;width:24px}.monaco-workbench .merge-editor .merge-editor-diff{background-color:var(--vscode-mergeEditor-change-background)}.monaco-workbench .merge-editor .merge-editor-diff-word{background-color:var(--vscode-mergeEditor-change-word-background)}.monaco-workbench .merge-editor .merge-editor-block:not(.handled):not(.focused){border:1px solid var(--vscode-mergeEditor-conflict-unhandledUnfocused-border)}.monaco-workbench .merge-editor .merge-editor-block:not(.handled).focused{border:2px solid var(--vscode-mergeEditor-conflict-unhandledFocused-border)}.monaco-workbench .merge-editor .merge-editor-block.handled:not(.focused){border:1px solid var(--vscode-mergeEditor-conflict-handledUnfocused-border)}.monaco-workbench .merge-editor .merge-editor-block.handled.focused{border:1px solid var(--vscode-mergeEditor-conflict-handledFocused-border)}.merge-editor-block.use-simplified-decorations.input.i1,.monaco-workbench .merge-editor .merge-editor-simplified.input.i1{background-color:var(--vscode-mergeEditor-conflict-input1-background)}.merge-editor-block.use-simplified-decorations.input.i2,.monaco-workbench .merge-editor .merge-editor-simplified.input.i2{background-color:var(--vscode-mergeEditor-conflict-input2-background)}.gutter.monaco-editor>div{position:absolute}.merge-accept-gutter-marker{margin-left:4px;width:28px}.merge-accept-gutter-marker .background{height:100%;position:absolute;width:50%}.merge-accept-gutter-marker.multi-line.focused .background{border:2px solid var(--vscode-mergeEditor-conflict-unhandledFocused-border);border-right:0}.merge-accept-gutter-marker.multi-line .background{border:2px solid var(--vscode-mergeEditor-conflict-unhandledUnfocused-border);border-bottom-left-radius:3px;border-right:0;border-top-left-radius:3px}.merge-accept-gutter-marker.multi-line.handled.focused .background{border:2px solid var(--vscode-mergeEditor-conflict-handledFocused-border);border-right:0}.merge-accept-gutter-marker.multi-line.handled .background{border:2px solid var(--vscode-checkbox-border);border-right:0}.focused .accept-conflict-group.monaco-custom-toggle{border:1px solid var(--vscode-mergeEditor-conflict-unhandledFocused-border)}.accept-conflict-group.monaco-custom-toggle{border:1px solid var(--vscode-mergeEditor-conflict-unhandledUnfocused-border)}.handled.focused .accept-conflict-group.monaco-custom-toggle{border:1px solid var(--vscode-mergeEditor-conflict-handledFocused-border)}.handled .accept-conflict-group.monaco-custom-toggle{border:1px solid var(--vscode-checkbox-border)}.merge-accept-gutter-marker.multi-line .background{left:8px;width:10px}.merge-accept-gutter-marker .checkbox{position:absolute;width:100%}.accept-conflict-group.monaco-custom-toggle{background-color:var(--vscode-checkbox-border);background-size:16px!important;border-radius:3px;height:18px;margin-left:0;margin-right:0;opacity:1;padding:0;width:18px}.merge-accept-gutter-marker .checkbox-background{background:var(--vscode-editor-background);display:flex}.conflict-zone-root{align-content:center;align-items:center;background-color:var(--vscode-mergeEditor-change-background);border:1px solid var(--vscode-mergeEditor-conflict-unhandledUnfocused-border);display:flex;height:90%}.conflict-zone-root .dots{margin:0 10px}.conflict-zone-root pre{display:\"inline\";font-family:var(--monaco-monospace-font)}.conflict-zone-root .text{align-items:center;background:var(--vscode-mergeEditor-conflictingLines-background);display:flex;height:100%;margin-left:auto;overflow:hidden;padding:0 8px;white-space:nowrap}.focused.conflict-zone .conflict-zone-root{border:1px solid var(--vscode-mergeEditor-conflict-unhandledFocused-border)}.merge-editor-conflict-actions{color:var(--vscode-editorCodeLens-foreground);display:inline-block;margin:0 3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.merge-editor-conflict-actions>a,.merge-editor-conflict-actions>span{user-select:none;-webkit-user-select:none;white-space:nowrap}.merge-editor-conflict-actions>a{text-decoration:none}.merge-editor-conflict-actions>a:hover{cursor:pointer}.merge-editor-conflict-actions>a:hover,.merge-editor-conflict-actions>a:hover .codicon{color:var(--vscode-editorLink-activeForeground)!important}.merge-editor-conflict-actions .codicon{color:currentColor!important;color:var(--vscode-editorCodeLens-foreground);vertical-align:middle}.merge-editor-conflict-actions>a:hover .codicon:before{cursor:pointer}.fixed-zone-widget{width:100%}.merge-editor-diff-empty-word.base{border-left:3px solid var(--vscode-mergeEditor-changeBase-word-background);margin-left:3px}.merge-editor-diff-empty-word.input{border-left:3px solid var(--vscode-mergeEditor-change-word-background);margin-left:3px}.merge-editor-diff-word.base{background-color:var(--vscode-mergeEditor-changeBase-word-background)}.merge-editor-diff.base{background-color:var(--vscode-mergeEditor-changeBase-background)}";
4
+ n(css,{});
5
+
6
+ export { css, css as default };