@codingame/monaco-vscode-views-service-override 2.1.4 → 2.2.0-next.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.
- package/index.d.ts +11 -9
- package/index.js +8 -6
- package/package.json +11 -11
- package/tools/views.d.ts +102 -0
- package/tools/views.js +253 -0
- package/views.d.ts +4 -99
- package/views.js +52 -280
- package/external/rollup-plugin-styles/dist/runtime/inject-css.js +0 -3
- package/vscode/src/vs/base/browser/ui/centered/centeredViewLayout.js +0 -180
- package/vscode/src/vs/base/browser/ui/grid/grid.js +0 -494
- package/vscode/src/vs/base/browser/ui/grid/gridview.css.js +0 -6
- package/vscode/src/vs/base/browser/ui/grid/gridview.js +0 -1112
- package/vscode/src/vs/base/common/codicons.d.ts +0 -579
- package/vscode/src/vs/platform/webview/common/mimeTypes.js +0 -24
- package/vscode/src/vs/platform/webview/common/webviewPortMapping.js +0 -64
- package/vscode/src/vs/workbench/api/browser/viewsExtensionPoint.js +0 -790
- package/vscode/src/vs/workbench/browser/actions/listCommands.js +0 -764
- package/vscode/src/vs/workbench/browser/layout.d.ts +0 -26
- package/vscode/src/vs/workbench/browser/parts/activitybar/activitybarPart.js +0 -612
- package/vscode/src/vs/workbench/browser/parts/activitybar/media/activityaction.css.js +0 -6
- package/vscode/src/vs/workbench/browser/parts/activitybar/media/activitybarpart.css.js +0 -6
- package/vscode/src/vs/workbench/browser/parts/auxiliarybar/auxiliaryBarPart.js +0 -150
- package/vscode/src/vs/workbench/browser/parts/auxiliarybar/media/auxiliaryBarPart.css.js +0 -6
- package/vscode/src/vs/workbench/browser/parts/compositeBar.js +0 -605
- package/vscode/src/vs/workbench/browser/parts/compositePart.js +0 -335
- package/vscode/src/vs/workbench/browser/parts/editor/auxiliaryEditorPart.js +0 -223
- package/vscode/src/vs/workbench/browser/parts/editor/editor.contribution.js +0 -1407
- package/vscode/src/vs/workbench/browser/parts/editor/editorConfiguration.js +0 -186
- package/vscode/src/vs/workbench/browser/parts/editor/editorDropTarget.js +0 -511
- package/vscode/src/vs/workbench/browser/parts/editor/editorPane.d.ts +0 -112
- package/vscode/src/vs/workbench/browser/parts/editor/editorPart.js +0 -1020
- package/vscode/src/vs/workbench/browser/parts/editor/editorParts.js +0 -391
- package/vscode/src/vs/workbench/browser/parts/editor/media/editordroptarget.css.js +0 -6
- package/vscode/src/vs/workbench/browser/parts/media/compositepart.css.js +0 -6
- package/vscode/src/vs/workbench/browser/parts/media/paneCompositePart.css.js +0 -6
- package/vscode/src/vs/workbench/browser/parts/paneCompositeBar.js +0 -645
- package/vscode/src/vs/workbench/browser/parts/paneCompositePart.js +0 -379
- package/vscode/src/vs/workbench/browser/parts/paneCompositePartService.js +0 -68
- package/vscode/src/vs/workbench/browser/parts/panel/panelPart.js +0 -146
- package/vscode/src/vs/workbench/browser/parts/sidebar/media/sidebarpart.css.js +0 -6
- package/vscode/src/vs/workbench/browser/parts/sidebar/sidebarPart.js +0 -222
- package/vscode/src/vs/workbench/contrib/callHierarchy/browser/callHierarchy.contribution.js +0 -299
- package/vscode/src/vs/workbench/contrib/callHierarchy/browser/callHierarchyPeek.js +0 -365
- package/vscode/src/vs/workbench/contrib/callHierarchy/browser/callHierarchyTree.js +0 -135
- package/vscode/src/vs/workbench/contrib/callHierarchy/browser/media/callHierarchy.css.js +0 -6
- package/vscode/src/vs/workbench/contrib/customEditor/browser/customEditor.contribution.js +0 -17
- package/vscode/src/vs/workbench/contrib/customEditor/browser/customEditorInputFactory.js +0 -145
- package/vscode/src/vs/workbench/contrib/customEditor/browser/customEditors.js +0 -214
- package/vscode/src/vs/workbench/contrib/customEditor/browser/media/customEditor.css.js +0 -6
- package/vscode/src/vs/workbench/contrib/customEditor/common/contributedCustomEditors.js +0 -78
- package/vscode/src/vs/workbench/contrib/customEditor/common/customEditorModelManager.js +0 -63
- package/vscode/src/vs/workbench/contrib/customEditor/common/extensionPoint.js +0 -119
- package/vscode/src/vs/workbench/contrib/externalUriOpener/common/externalUriOpener.contribution.js +0 -6
- package/vscode/src/vs/workbench/contrib/files/browser/editors/binaryFileEditor.js +0 -79
- package/vscode/src/vs/workbench/contrib/files/browser/editors/fileEditorHandler.js +0 -74
- package/vscode/src/vs/workbench/contrib/files/browser/editors/textFileEditor.js +0 -256
- package/vscode/src/vs/workbench/contrib/files/browser/editors/textFileEditorTracker.js +0 -99
- package/vscode/src/vs/workbench/contrib/files/browser/editors/textFileSaveErrorHandler.js +0 -444
- package/vscode/src/vs/workbench/contrib/files/browser/explorerService.js +0 -432
- package/vscode/src/vs/workbench/contrib/files/browser/fileActions.contribution.js +0 -786
- package/vscode/src/vs/workbench/contrib/files/browser/fileCommands.js +0 -488
- package/vscode/src/vs/workbench/contrib/files/browser/files.contribution.js +0 -522
- package/vscode/src/vs/workbench/contrib/files/browser/workspaceWatcher.js +0 -152
- package/vscode/src/vs/workbench/contrib/files/common/dirtyFilesIndicator.js +0 -63
- package/vscode/src/vs/workbench/contrib/languageStatus/browser/languageStatus.contribution.js +0 -409
- package/vscode/src/vs/workbench/contrib/languageStatus/browser/media/languageStatus.css.js +0 -6
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/commands/commands.js +0 -693
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/commands/devCommands.js +0 -240
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/mergeEditor.contribution.js +0 -77
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/mergeEditorSerializer.js +0 -42
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/colors.js +0 -71
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/conflictActions.js +0 -348
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editorGutter.js +0 -98
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editors/baseCodeEditorView.js +0 -146
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editors/codeEditorView.js +0 -105
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editors/inputCodeEditorView.js +0 -401
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView.js +0 -197
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/fixedZoneWidget.js +0 -41
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/lineAlignment.js +0 -128
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/media/mergeEditor.css.js +0 -6
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/mergeEditor.js +0 -612
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/scrollSynchronizer.js +0 -158
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/viewModel.js +0 -264
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/viewZones.js +0 -173
- package/vscode/src/vs/workbench/contrib/typeHierarchy/browser/media/typeHierarchy.css.js +0 -6
- package/vscode/src/vs/workbench/contrib/typeHierarchy/browser/typeHierarchy.contribution.js +0 -282
- package/vscode/src/vs/workbench/contrib/typeHierarchy/browser/typeHierarchyPeek.js +0 -360
- package/vscode/src/vs/workbench/contrib/typeHierarchy/browser/typeHierarchyTree.js +0 -133
- package/vscode/src/vs/workbench/contrib/webview/browser/overlayWebview.js +0 -290
- package/vscode/src/vs/workbench/contrib/webview/browser/resourceLoading.js +0 -96
- package/vscode/src/vs/workbench/contrib/webview/browser/themeing.js +0 -88
- package/vscode/src/vs/workbench/contrib/webview/browser/webview.contribution.js +0 -79
- package/vscode/src/vs/workbench/contrib/webview/browser/webviewElement.js +0 -648
- package/vscode/src/vs/workbench/contrib/webview/browser/webviewFindWidget.js +0 -65
- package/vscode/src/vs/workbench/contrib/webview/browser/webviewService.js +0 -59
- package/vscode/src/vs/workbench/contrib/webviewPanel/browser/webviewCommands.js +0 -142
- package/vscode/src/vs/workbench/contrib/webviewPanel/browser/webviewEditorInputSerializer.js +0 -121
- package/vscode/src/vs/workbench/contrib/webviewPanel/browser/webviewPanel.contribution.js +0 -68
- package/vscode/src/vs/workbench/contrib/webviewView/browser/webviewViewPane.js +0 -235
- package/vscode/src/vs/workbench/services/activity/browser/activityService.js +0 -145
- package/vscode/src/vs/workbench/services/editor/browser/editorResolverService.js +0 -670
- package/vscode/src/vs/workbench/services/history/browser/historyService.js +0 -1484
- package/vscode/src/vs/workbench/services/progress/browser/media/progressService.css.js +0 -6
- package/vscode/src/vs/workbench/services/progress/browser/progressService.js +0 -523
- package/vscode/src/vs/workbench/services/untitled/common/untitledTextEditorHandler.js +0 -101
- package/vscode/src/vs/workbench/services/views/browser/viewDescriptorService.js +0 -713
- package/vscode/src/vs/workbench/services/views/common/viewContainerModel.js +0 -598
package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView.js
DELETED
|
@@ -1,197 +0,0 @@
|
|
|
1
|
-
import { __decorate, __param } from '../../../../../../../../../external/tslib/tslib.es6.js';
|
|
2
|
-
import { reset } from 'vscode/vscode/vs/base/browser/dom';
|
|
3
|
-
import { ActionBar } from 'vscode/vscode/vs/base/browser/ui/actionbar/actionbar';
|
|
4
|
-
import { renderLabelWithIcons } from 'vscode/vscode/vs/base/browser/ui/iconLabel/iconLabels';
|
|
5
|
-
import { CompareResult } from 'vscode/vscode/vs/base/common/arrays';
|
|
6
|
-
import { BugIndicatingError } from 'vscode/vscode/vs/base/common/errors';
|
|
7
|
-
import { toDisposable } from 'vscode/vscode/vs/base/common/lifecycle';
|
|
8
|
-
import { MinimapPosition, OverviewRulerLane } from 'vscode/vscode/vs/editor/common/model';
|
|
9
|
-
import { localizeWithPath } from 'vscode/vscode/vs/nls';
|
|
10
|
-
import { MenuId } from 'vscode/vscode/vs/platform/actions/common/actions';
|
|
11
|
-
import { IConfigurationService } from 'vscode/vscode/vs/platform/configuration/common/configuration';
|
|
12
|
-
import { IContextKeyService } from 'vscode/vscode/vs/platform/contextkey/common/contextkey';
|
|
13
|
-
import { IInstantiationService } from 'vscode/vscode/vs/platform/instantiation/common/instantiation';
|
|
14
|
-
import { ILabelService } from 'vscode/vscode/vs/platform/label/common/label';
|
|
15
|
-
import { LineRange } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/browser/model/lineRange';
|
|
16
|
-
import { join, applyObservableDecorations } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/browser/utils';
|
|
17
|
-
import { handledConflictMinimapOverViewRulerColor, unhandledConflictMinimapOverViewRulerColor } from '../colors.js';
|
|
18
|
-
import { EditorGutter } from '../editorGutter.js';
|
|
19
|
-
import { ctxIsMergeResultEditor } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/common/mergeEditor';
|
|
20
|
-
import { CodeEditorView, createSelectionsAutorun, TitleMenu } from './codeEditorView.js';
|
|
21
|
-
import { derived } from 'vscode/vscode/vs/base/common/observableInternal/derived';
|
|
22
|
-
import { autorunWithStore, autorun } from 'vscode/vscode/vs/base/common/observableInternal/autorun';
|
|
23
|
-
|
|
24
|
-
let ResultCodeEditorView = class ResultCodeEditorView extends CodeEditorView {
|
|
25
|
-
constructor(viewModel, instantiationService, _labelService, configurationService) {
|
|
26
|
-
super(instantiationService, viewModel, configurationService);
|
|
27
|
-
this._labelService = _labelService;
|
|
28
|
-
this.decorations = derived(this, reader => {
|
|
29
|
-
const viewModel = this.viewModel.read(reader);
|
|
30
|
-
if (!viewModel) {
|
|
31
|
-
return [];
|
|
32
|
-
}
|
|
33
|
-
const model = viewModel.model;
|
|
34
|
-
const textModel = model.resultTextModel;
|
|
35
|
-
const result = ( new Array());
|
|
36
|
-
const baseRangeWithStoreAndTouchingDiffs = join(model.modifiedBaseRanges.read(reader), model.baseResultDiffs.read(reader), (baseRange, diff) => baseRange.baseRange.touches(diff.inputRange)
|
|
37
|
-
? CompareResult.neitherLessOrGreaterThan
|
|
38
|
-
: LineRange.compareByStart(baseRange.baseRange, diff.inputRange));
|
|
39
|
-
const activeModifiedBaseRange = viewModel.activeModifiedBaseRange.read(reader);
|
|
40
|
-
const showNonConflictingChanges = viewModel.showNonConflictingChanges.read(reader);
|
|
41
|
-
for (const m of baseRangeWithStoreAndTouchingDiffs) {
|
|
42
|
-
const modifiedBaseRange = m.left;
|
|
43
|
-
if (modifiedBaseRange) {
|
|
44
|
-
const blockClassNames = ['merge-editor-block'];
|
|
45
|
-
let blockPadding = [0, 0, 0, 0];
|
|
46
|
-
const isHandled = model.isHandled(modifiedBaseRange).read(reader);
|
|
47
|
-
if (isHandled) {
|
|
48
|
-
blockClassNames.push('handled');
|
|
49
|
-
}
|
|
50
|
-
if (modifiedBaseRange === activeModifiedBaseRange) {
|
|
51
|
-
blockClassNames.push('focused');
|
|
52
|
-
blockPadding = [0, 2, 0, 2];
|
|
53
|
-
}
|
|
54
|
-
if (modifiedBaseRange.isConflicting) {
|
|
55
|
-
blockClassNames.push('conflicting');
|
|
56
|
-
}
|
|
57
|
-
blockClassNames.push('result');
|
|
58
|
-
if (!modifiedBaseRange.isConflicting && !showNonConflictingChanges && isHandled) {
|
|
59
|
-
continue;
|
|
60
|
-
}
|
|
61
|
-
const range = model.getLineRangeInResult(modifiedBaseRange.baseRange, reader);
|
|
62
|
-
result.push({
|
|
63
|
-
range: range.toInclusiveRangeOrEmpty(),
|
|
64
|
-
options: {
|
|
65
|
-
showIfCollapsed: true,
|
|
66
|
-
blockClassName: blockClassNames.join(' '),
|
|
67
|
-
blockPadding,
|
|
68
|
-
blockIsAfterEnd: range.startLineNumber > textModel.getLineCount(),
|
|
69
|
-
description: 'Result Diff',
|
|
70
|
-
minimap: {
|
|
71
|
-
position: MinimapPosition.Gutter,
|
|
72
|
-
color: { id: isHandled ? handledConflictMinimapOverViewRulerColor : unhandledConflictMinimapOverViewRulerColor },
|
|
73
|
-
},
|
|
74
|
-
overviewRuler: modifiedBaseRange.isConflicting ? {
|
|
75
|
-
position: OverviewRulerLane.Center,
|
|
76
|
-
color: { id: isHandled ? handledConflictMinimapOverViewRulerColor : unhandledConflictMinimapOverViewRulerColor },
|
|
77
|
-
} : undefined
|
|
78
|
-
}
|
|
79
|
-
});
|
|
80
|
-
}
|
|
81
|
-
if (!modifiedBaseRange || modifiedBaseRange.isConflicting) {
|
|
82
|
-
for (const diff of m.rights) {
|
|
83
|
-
const range = diff.outputRange.toInclusiveRange();
|
|
84
|
-
if (range) {
|
|
85
|
-
result.push({
|
|
86
|
-
range,
|
|
87
|
-
options: {
|
|
88
|
-
className: `merge-editor-diff result`,
|
|
89
|
-
description: 'Merge Editor',
|
|
90
|
-
isWholeLine: true,
|
|
91
|
-
}
|
|
92
|
-
});
|
|
93
|
-
}
|
|
94
|
-
if (diff.rangeMappings) {
|
|
95
|
-
for (const d of diff.rangeMappings) {
|
|
96
|
-
result.push({
|
|
97
|
-
range: d.outputRange,
|
|
98
|
-
options: {
|
|
99
|
-
className: `merge-editor-diff-word result`,
|
|
100
|
-
description: 'Merge Editor'
|
|
101
|
-
}
|
|
102
|
-
});
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
return result;
|
|
109
|
-
});
|
|
110
|
-
this.editor.invokeWithinContext(accessor => {
|
|
111
|
-
const contextKeyService = accessor.get(IContextKeyService);
|
|
112
|
-
const isMergeResultEditor = ctxIsMergeResultEditor.bindTo(contextKeyService);
|
|
113
|
-
isMergeResultEditor.set(true);
|
|
114
|
-
this._register(toDisposable(() => isMergeResultEditor.reset()));
|
|
115
|
-
});
|
|
116
|
-
this.htmlElements.gutterDiv.style.width = '5px';
|
|
117
|
-
this.htmlElements.root.classList.add(`result`);
|
|
118
|
-
this._register(autorunWithStore((reader, store) => {
|
|
119
|
-
if (this.checkboxesVisible.read(reader)) {
|
|
120
|
-
store.add(( new EditorGutter(this.editor, this.htmlElements.gutterDiv, {
|
|
121
|
-
getIntersectingGutterItems: (range, reader) => [],
|
|
122
|
-
createView: (item, target) => { throw new BugIndicatingError(); },
|
|
123
|
-
})));
|
|
124
|
-
}
|
|
125
|
-
}));
|
|
126
|
-
this._register(autorun(reader => {
|
|
127
|
-
const vm = this.viewModel.read(reader);
|
|
128
|
-
if (!vm) {
|
|
129
|
-
return;
|
|
130
|
-
}
|
|
131
|
-
this.editor.setModel(vm.model.resultTextModel);
|
|
132
|
-
reset(this.htmlElements.title, ...renderLabelWithIcons(( localizeWithPath(
|
|
133
|
-
'vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView',
|
|
134
|
-
'result',
|
|
135
|
-
'Result'
|
|
136
|
-
))));
|
|
137
|
-
reset(this.htmlElements.description, ...renderLabelWithIcons(this._labelService.getUriLabel(vm.model.resultTextModel.uri, { relative: true })));
|
|
138
|
-
}));
|
|
139
|
-
const remainingConflictsActionBar = this._register(( new ActionBar(this.htmlElements.detail)));
|
|
140
|
-
this._register(autorun(reader => {
|
|
141
|
-
const vm = this.viewModel.read(reader);
|
|
142
|
-
if (!vm) {
|
|
143
|
-
return;
|
|
144
|
-
}
|
|
145
|
-
const model = vm.model;
|
|
146
|
-
if (!model) {
|
|
147
|
-
return;
|
|
148
|
-
}
|
|
149
|
-
const count = model.unhandledConflictsCount.read(reader);
|
|
150
|
-
const text = count === 1
|
|
151
|
-
? ( localizeWithPath(
|
|
152
|
-
'vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView',
|
|
153
|
-
'mergeEditor.remainingConflicts',
|
|
154
|
-
'{0} Conflict Remaining',
|
|
155
|
-
count
|
|
156
|
-
))
|
|
157
|
-
: ( localizeWithPath(
|
|
158
|
-
'vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView',
|
|
159
|
-
'mergeEditor.remainingConflict',
|
|
160
|
-
'{0} Conflicts Remaining ',
|
|
161
|
-
count
|
|
162
|
-
));
|
|
163
|
-
remainingConflictsActionBar.clear();
|
|
164
|
-
remainingConflictsActionBar.push({
|
|
165
|
-
class: undefined,
|
|
166
|
-
enabled: count > 0,
|
|
167
|
-
id: 'nextConflict',
|
|
168
|
-
label: text,
|
|
169
|
-
run() {
|
|
170
|
-
vm.model.telemetry.reportConflictCounterClicked();
|
|
171
|
-
vm.goToNextModifiedBaseRange(m => !model.isHandled(m).get());
|
|
172
|
-
},
|
|
173
|
-
tooltip: count > 0
|
|
174
|
-
? ( localizeWithPath(
|
|
175
|
-
'vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView',
|
|
176
|
-
'goToNextConflict',
|
|
177
|
-
'Go to next conflict'
|
|
178
|
-
))
|
|
179
|
-
: ( localizeWithPath(
|
|
180
|
-
'vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView',
|
|
181
|
-
'allConflictHandled',
|
|
182
|
-
'All conflicts handled, the merge can be completed now.'
|
|
183
|
-
)),
|
|
184
|
-
});
|
|
185
|
-
}));
|
|
186
|
-
this._register(applyObservableDecorations(this.editor, this.decorations));
|
|
187
|
-
this._register(createSelectionsAutorun(this, (baseRange, viewModel) => viewModel.model.translateBaseRangeToResult(baseRange)));
|
|
188
|
-
this._register(instantiationService.createInstance(TitleMenu, MenuId.MergeInputResultToolbar, this.htmlElements.toolbar));
|
|
189
|
-
}
|
|
190
|
-
};
|
|
191
|
-
ResultCodeEditorView = ( __decorate([
|
|
192
|
-
( __param(1, IInstantiationService)),
|
|
193
|
-
( __param(2, ILabelService)),
|
|
194
|
-
( __param(3, IConfigurationService))
|
|
195
|
-
], ResultCodeEditorView));
|
|
196
|
-
|
|
197
|
-
export { ResultCodeEditorView };
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import { h } from 'vscode/vscode/vs/base/browser/dom';
|
|
2
|
-
import { Disposable } from 'vscode/vscode/vs/base/common/lifecycle';
|
|
3
|
-
import { Event } from 'vscode/vscode/vs/base/common/event';
|
|
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 };
|
|
@@ -1,128 +0,0 @@
|
|
|
1
|
-
import { compareBy } from 'vscode/vscode/vs/base/common/arrays';
|
|
2
|
-
import { assertFn, checkAdjacentItems } from 'vscode/vscode/vs/base/common/assert';
|
|
3
|
-
import { isDefined } from 'vscode/vscode/vs/base/common/types';
|
|
4
|
-
import { Position } from 'vscode/vscode/vs/editor/common/core/position';
|
|
5
|
-
import { Range } from 'vscode/vscode/vs/editor/common/core/range';
|
|
6
|
-
import { LengthObj } from 'vscode/vscode/vs/editor/common/model/bracketPairsTextModelPart/bracketPairsTree/length';
|
|
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 };
|
|
@@ -1,6 +0,0 @@
|
|
|
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 };
|