@codingame/monaco-vscode-view-common-service-override 4.5.0-improve-code-splitting.1

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 (114) hide show
  1. package/assets/fake.html +10 -0
  2. package/assets/index-no-csp.html +1230 -0
  3. package/assets/index.html +1231 -0
  4. package/assets/service-worker.js +457 -0
  5. package/index.d.ts +1 -0
  6. package/index.js +1 -0
  7. package/override/vs/workbench/browser/parts/editor/textEditor.js +5 -0
  8. package/override/vs/workbench/browser/parts/editor/textEditor.weak.js +11 -0
  9. package/package.json +32 -0
  10. package/tools/editorAssets.js +4 -0
  11. package/tools/url.js +10 -0
  12. package/viewCommon.d.ts +5 -0
  13. package/viewCommon.js +105 -0
  14. package/vscode/src/vs/base/browser/deviceAccess.js +61 -0
  15. package/vscode/src/vs/base/browser/ui/centered/centeredViewLayout.js +180 -0
  16. package/vscode/src/vs/base/browser/ui/grid/grid.js +494 -0
  17. package/vscode/src/vs/base/browser/ui/grid/gridview.css.js +6 -0
  18. package/vscode/src/vs/base/browser/ui/grid/gridview.js +1113 -0
  19. package/vscode/src/vs/platform/languagePacks/common/localizedStrings.js +12 -0
  20. package/vscode/src/vs/platform/webview/common/mimeTypes.js +24 -0
  21. package/vscode/src/vs/platform/webview/common/webviewPortMapping.js +64 -0
  22. package/vscode/src/vs/workbench/api/browser/viewsExtensionPoint.js +907 -0
  23. package/vscode/src/vs/workbench/browser/actions/listCommands.js +764 -0
  24. package/vscode/src/vs/workbench/browser/actions/navigationActions.js +301 -0
  25. package/vscode/src/vs/workbench/browser/media/style.css.js +6 -0
  26. package/vscode/src/vs/workbench/browser/parts/activitybar/activitybarPart.js +671 -0
  27. package/vscode/src/vs/workbench/browser/parts/activitybar/media/activityaction.css.js +6 -0
  28. package/vscode/src/vs/workbench/browser/parts/activitybar/media/activitybarpart.css.js +6 -0
  29. package/vscode/src/vs/workbench/browser/parts/auxiliarybar/auxiliaryBarPart.js +229 -0
  30. package/vscode/src/vs/workbench/browser/parts/auxiliarybar/media/auxiliaryBarPart.css.js +6 -0
  31. package/vscode/src/vs/workbench/browser/parts/compositeBar.js +606 -0
  32. package/vscode/src/vs/workbench/browser/parts/compositePart.js +346 -0
  33. package/vscode/src/vs/workbench/browser/parts/editor/auxiliaryEditorPart.js +246 -0
  34. package/vscode/src/vs/workbench/browser/parts/editor/editor.contribution.js +1403 -0
  35. package/vscode/src/vs/workbench/browser/parts/editor/editorConfiguration.js +188 -0
  36. package/vscode/src/vs/workbench/browser/parts/editor/editorDropTarget.js +523 -0
  37. package/vscode/src/vs/workbench/browser/parts/editor/editorPart.js +1030 -0
  38. package/vscode/src/vs/workbench/browser/parts/editor/editorParts.js +391 -0
  39. package/vscode/src/vs/workbench/browser/parts/editor/media/editordroptarget.css.js +6 -0
  40. package/vscode/src/vs/workbench/browser/parts/media/compositepart.css.js +6 -0
  41. package/vscode/src/vs/workbench/browser/parts/media/paneCompositePart.css.js +6 -0
  42. package/vscode/src/vs/workbench/browser/parts/paneCompositeBar.js +643 -0
  43. package/vscode/src/vs/workbench/browser/parts/paneCompositePart.js +472 -0
  44. package/vscode/src/vs/workbench/browser/parts/paneCompositePartService.js +68 -0
  45. package/vscode/src/vs/workbench/browser/parts/panel/panelPart.js +160 -0
  46. package/vscode/src/vs/workbench/browser/parts/sidebar/media/sidebarpart.css.js +6 -0
  47. package/vscode/src/vs/workbench/browser/parts/sidebar/sidebarActions.js +39 -0
  48. package/vscode/src/vs/workbench/browser/parts/sidebar/sidebarPart.js +238 -0
  49. package/vscode/src/vs/workbench/browser/style.js +54 -0
  50. package/vscode/src/vs/workbench/browser/window.js +381 -0
  51. package/vscode/src/vs/workbench/contrib/callHierarchy/browser/callHierarchy.contribution.js +300 -0
  52. package/vscode/src/vs/workbench/contrib/callHierarchy/browser/callHierarchyPeek.js +367 -0
  53. package/vscode/src/vs/workbench/contrib/callHierarchy/browser/callHierarchyTree.js +135 -0
  54. package/vscode/src/vs/workbench/contrib/callHierarchy/browser/media/callHierarchy.css.js +6 -0
  55. package/vscode/src/vs/workbench/contrib/customEditor/browser/customEditor.contribution.js +18 -0
  56. package/vscode/src/vs/workbench/contrib/customEditor/browser/customEditorInputFactory.js +146 -0
  57. package/vscode/src/vs/workbench/contrib/customEditor/browser/customEditors.js +215 -0
  58. package/vscode/src/vs/workbench/contrib/customEditor/browser/media/customEditor.css.js +6 -0
  59. package/vscode/src/vs/workbench/contrib/customEditor/common/contributedCustomEditors.js +78 -0
  60. package/vscode/src/vs/workbench/contrib/customEditor/common/customEditor.js +56 -0
  61. package/vscode/src/vs/workbench/contrib/customEditor/common/customEditorModelManager.js +63 -0
  62. package/vscode/src/vs/workbench/contrib/customEditor/common/extensionPoint.js +183 -0
  63. package/vscode/src/vs/workbench/contrib/externalUriOpener/common/externalUriOpener.contribution.js +8 -0
  64. package/vscode/src/vs/workbench/contrib/languageStatus/browser/languageStatus.contribution.js +408 -0
  65. package/vscode/src/vs/workbench/contrib/languageStatus/browser/media/languageStatus.css.js +6 -0
  66. package/vscode/src/vs/workbench/contrib/limitIndicator/browser/limitIndicator.contribution.js +147 -0
  67. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/commands/commands.js +635 -0
  68. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/commands/devCommands.js +230 -0
  69. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/mergeEditor.contribution.js +75 -0
  70. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/mergeEditorSerializer.js +42 -0
  71. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/colors.js +81 -0
  72. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/conflictActions.js +350 -0
  73. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editorGutter.js +100 -0
  74. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editors/baseCodeEditorView.js +148 -0
  75. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editors/codeEditorView.js +106 -0
  76. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editors/inputCodeEditorView.js +403 -0
  77. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView.js +199 -0
  78. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/fixedZoneWidget.js +41 -0
  79. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/lineAlignment.js +128 -0
  80. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/media/mergeEditor.css.js +6 -0
  81. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/mergeEditor.js +619 -0
  82. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/scrollSynchronizer.js +161 -0
  83. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/viewModel.js +266 -0
  84. package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/viewZones.js +173 -0
  85. package/vscode/src/vs/workbench/contrib/preferences/browser/keyboardLayoutPicker.js +195 -0
  86. package/vscode/src/vs/workbench/contrib/sash/browser/sash.contribution.js +38 -0
  87. package/vscode/src/vs/workbench/contrib/sash/browser/sash.js +41 -0
  88. package/vscode/src/vs/workbench/contrib/typeHierarchy/browser/media/typeHierarchy.css.js +6 -0
  89. package/vscode/src/vs/workbench/contrib/typeHierarchy/browser/typeHierarchy.contribution.js +283 -0
  90. package/vscode/src/vs/workbench/contrib/typeHierarchy/browser/typeHierarchyPeek.js +362 -0
  91. package/vscode/src/vs/workbench/contrib/typeHierarchy/browser/typeHierarchyTree.js +133 -0
  92. package/vscode/src/vs/workbench/contrib/webview/browser/overlayWebview.js +314 -0
  93. package/vscode/src/vs/workbench/contrib/webview/browser/resourceLoading.js +96 -0
  94. package/vscode/src/vs/workbench/contrib/webview/browser/themeing.js +98 -0
  95. package/vscode/src/vs/workbench/contrib/webview/browser/webviewElement.js +656 -0
  96. package/vscode/src/vs/workbench/contrib/webview/browser/webviewFindWidget.js +65 -0
  97. package/vscode/src/vs/workbench/contrib/webview/browser/webviewService.js +59 -0
  98. package/vscode/src/vs/workbench/contrib/webviewPanel/browser/webviewCommands.js +143 -0
  99. package/vscode/src/vs/workbench/contrib/webviewPanel/browser/webviewEditorInputSerializer.js +121 -0
  100. package/vscode/src/vs/workbench/contrib/webviewPanel/browser/webviewPanel.contribution.js +67 -0
  101. package/vscode/src/vs/workbench/contrib/webviewView/browser/webviewViewPane.js +234 -0
  102. package/vscode/src/vs/workbench/contrib/webviewView/browser/webviewViewService.js +45 -0
  103. package/vscode/src/vs/workbench/services/activity/browser/activityService.js +145 -0
  104. package/vscode/src/vs/workbench/services/auxiliaryWindow/browser/auxiliaryWindowService.js +341 -0
  105. package/vscode/src/vs/workbench/services/driver/browser/driver.js +186 -0
  106. package/vscode/src/vs/workbench/services/editor/browser/editorPaneService.js +13 -0
  107. package/vscode/src/vs/workbench/services/editor/browser/editorResolverService.js +676 -0
  108. package/vscode/src/vs/workbench/services/history/browser/historyService.js +1516 -0
  109. package/vscode/src/vs/workbench/services/progress/browser/media/progressService.css.js +6 -0
  110. package/vscode/src/vs/workbench/services/progress/browser/progressService.js +527 -0
  111. package/vscode/src/vs/workbench/services/untitled/common/untitledTextEditorHandler.js +102 -0
  112. package/vscode/src/vs/workbench/services/untitled/common/untitledTextEditorService.js +133 -0
  113. package/vscode/src/vs/workbench/services/views/browser/viewDescriptorService.js +711 -0
  114. package/vscode/src/vs/workbench/services/views/common/viewContainerModel.js +603 -0
@@ -0,0 +1,161 @@
1
+ import { Disposable } from 'vscode/vscode/vs/base/common/lifecycle';
2
+ import 'vscode/vscode/vs/base/common/observableInternal/derived';
3
+ import { autorunWithStore } from 'vscode/vscode/vs/base/common/observableInternal/autorun';
4
+ import 'vscode/vscode/vs/base/common/observableInternal/utils';
5
+ import 'vscode/vscode/vs/base/common/cancellation';
6
+ import { DocumentLineRangeMap } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/browser/model/mapping';
7
+ import { ReentrancyBarrier } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/browser/utils';
8
+
9
+ class ScrollSynchronizer extends Disposable {
10
+ get model() { return this.viewModel.get()?.model; }
11
+ get shouldAlignResult() { return this.layout.get().kind === 'columns'; }
12
+ get shouldAlignBase() { return this.layout.get().kind === 'mixed' && !this.layout.get().showBaseAtTop; }
13
+ constructor(viewModel, input1View, input2View, baseView, inputResultView, layout) {
14
+ super();
15
+ this.viewModel = viewModel;
16
+ this.input1View = input1View;
17
+ this.input2View = input2View;
18
+ this.baseView = baseView;
19
+ this.inputResultView = inputResultView;
20
+ this.layout = layout;
21
+ this.reentrancyBarrier = ( new ReentrancyBarrier());
22
+ const handleInput1OnScroll = this.updateScrolling = () => {
23
+ if (!this.model) {
24
+ return;
25
+ }
26
+ this.input2View.editor.setScrollTop(this.input1View.editor.getScrollTop(), 1 );
27
+ if (this.shouldAlignResult) {
28
+ this.inputResultView.editor.setScrollTop(this.input1View.editor.getScrollTop(), 1 );
29
+ }
30
+ else {
31
+ const mappingInput1Result = this.model.input1ResultMapping.get();
32
+ this.synchronizeScrolling(this.input1View.editor, this.inputResultView.editor, mappingInput1Result);
33
+ }
34
+ const baseView = this.baseView.get();
35
+ if (baseView) {
36
+ if (this.shouldAlignBase) {
37
+ this.baseView.get()?.editor.setScrollTop(this.input1View.editor.getScrollTop(), 1 );
38
+ }
39
+ else {
40
+ const mapping = ( new DocumentLineRangeMap(this.model.baseInput1Diffs.get(), -1)).reverse();
41
+ this.synchronizeScrolling(this.input1View.editor, baseView.editor, mapping);
42
+ }
43
+ }
44
+ };
45
+ this._store.add(this.input1View.editor.onDidScrollChange(this.reentrancyBarrier.makeExclusive((c) => {
46
+ if (c.scrollTopChanged) {
47
+ handleInput1OnScroll();
48
+ }
49
+ if (c.scrollLeftChanged) {
50
+ this.baseView.get()?.editor.setScrollLeft(c.scrollLeft, 1 );
51
+ this.input2View.editor.setScrollLeft(c.scrollLeft, 1 );
52
+ this.inputResultView.editor.setScrollLeft(c.scrollLeft, 1 );
53
+ }
54
+ })));
55
+ this._store.add(this.input2View.editor.onDidScrollChange(this.reentrancyBarrier.makeExclusive((c) => {
56
+ if (!this.model) {
57
+ return;
58
+ }
59
+ if (c.scrollTopChanged) {
60
+ this.input1View.editor.setScrollTop(c.scrollTop, 1 );
61
+ if (this.shouldAlignResult) {
62
+ this.inputResultView.editor.setScrollTop(this.input2View.editor.getScrollTop(), 1 );
63
+ }
64
+ else {
65
+ const mappingInput2Result = this.model.input2ResultMapping.get();
66
+ this.synchronizeScrolling(this.input2View.editor, this.inputResultView.editor, mappingInput2Result);
67
+ }
68
+ const baseView = this.baseView.get();
69
+ if (baseView && this.model) {
70
+ if (this.shouldAlignBase) {
71
+ this.baseView.get()?.editor.setScrollTop(c.scrollTop, 1 );
72
+ }
73
+ else {
74
+ const mapping = ( new DocumentLineRangeMap(this.model.baseInput2Diffs.get(), -1)).reverse();
75
+ this.synchronizeScrolling(this.input2View.editor, baseView.editor, mapping);
76
+ }
77
+ }
78
+ }
79
+ if (c.scrollLeftChanged) {
80
+ this.baseView.get()?.editor.setScrollLeft(c.scrollLeft, 1 );
81
+ this.input1View.editor.setScrollLeft(c.scrollLeft, 1 );
82
+ this.inputResultView.editor.setScrollLeft(c.scrollLeft, 1 );
83
+ }
84
+ })));
85
+ this._store.add(this.inputResultView.editor.onDidScrollChange(this.reentrancyBarrier.makeExclusive((c) => {
86
+ if (c.scrollTopChanged) {
87
+ if (this.shouldAlignResult) {
88
+ this.input1View.editor.setScrollTop(c.scrollTop, 1 );
89
+ this.input2View.editor.setScrollTop(c.scrollTop, 1 );
90
+ }
91
+ else {
92
+ const mapping1 = this.model?.resultInput1Mapping.get();
93
+ this.synchronizeScrolling(this.inputResultView.editor, this.input1View.editor, mapping1);
94
+ const mapping2 = this.model?.resultInput2Mapping.get();
95
+ this.synchronizeScrolling(this.inputResultView.editor, this.input2View.editor, mapping2);
96
+ }
97
+ const baseMapping = this.model?.resultBaseMapping.get();
98
+ const baseView = this.baseView.get();
99
+ if (baseView && this.model) {
100
+ this.synchronizeScrolling(this.inputResultView.editor, baseView.editor, baseMapping);
101
+ }
102
+ }
103
+ if (c.scrollLeftChanged) {
104
+ this.baseView.get()?.editor?.setScrollLeft(c.scrollLeft, 1 );
105
+ this.input1View.editor.setScrollLeft(c.scrollLeft, 1 );
106
+ this.input2View.editor.setScrollLeft(c.scrollLeft, 1 );
107
+ }
108
+ })));
109
+ this._store.add(autorunWithStore((reader, store) => {
110
+ const baseView = this.baseView.read(reader);
111
+ if (baseView) {
112
+ store.add(baseView.editor.onDidScrollChange(this.reentrancyBarrier.makeExclusive((c) => {
113
+ if (c.scrollTopChanged) {
114
+ if (!this.model) {
115
+ return;
116
+ }
117
+ if (this.shouldAlignBase) {
118
+ this.input1View.editor.setScrollTop(c.scrollTop, 1 );
119
+ this.input2View.editor.setScrollTop(c.scrollTop, 1 );
120
+ }
121
+ else {
122
+ const baseInput1Mapping = ( new DocumentLineRangeMap(this.model.baseInput1Diffs.get(), -1));
123
+ this.synchronizeScrolling(baseView.editor, this.input1View.editor, baseInput1Mapping);
124
+ const baseInput2Mapping = ( new DocumentLineRangeMap(this.model.baseInput2Diffs.get(), -1));
125
+ this.synchronizeScrolling(baseView.editor, this.input2View.editor, baseInput2Mapping);
126
+ }
127
+ const baseMapping = this.model?.baseResultMapping.get();
128
+ this.synchronizeScrolling(baseView.editor, this.inputResultView.editor, baseMapping);
129
+ }
130
+ if (c.scrollLeftChanged) {
131
+ this.inputResultView.editor.setScrollLeft(c.scrollLeft, 1 );
132
+ this.input1View.editor.setScrollLeft(c.scrollLeft, 1 );
133
+ this.input2View.editor.setScrollLeft(c.scrollLeft, 1 );
134
+ }
135
+ })));
136
+ }
137
+ }));
138
+ }
139
+ synchronizeScrolling(scrollingEditor, targetEditor, mapping) {
140
+ if (!mapping) {
141
+ return;
142
+ }
143
+ const visibleRanges = scrollingEditor.getVisibleRanges();
144
+ if (visibleRanges.length === 0) {
145
+ return;
146
+ }
147
+ const topLineNumber = visibleRanges[0].startLineNumber - 1;
148
+ const result = mapping.project(topLineNumber);
149
+ const sourceRange = result.inputRange;
150
+ const targetRange = result.outputRange;
151
+ const resultStartTopPx = targetEditor.getTopForLineNumber(targetRange.startLineNumber);
152
+ const resultEndPx = targetEditor.getTopForLineNumber(targetRange.endLineNumberExclusive);
153
+ const sourceStartTopPx = scrollingEditor.getTopForLineNumber(sourceRange.startLineNumber);
154
+ const sourceEndPx = scrollingEditor.getTopForLineNumber(sourceRange.endLineNumberExclusive);
155
+ const factor = Math.min((scrollingEditor.getScrollTop() - sourceStartTopPx) / (sourceEndPx - sourceStartTopPx), 1);
156
+ const resultScrollPosition = resultStartTopPx + (resultEndPx - resultStartTopPx) * factor;
157
+ targetEditor.setScrollTop(resultScrollPosition, 1 );
158
+ }
159
+ }
160
+
161
+ export { ScrollSynchronizer };
@@ -0,0 +1,266 @@
1
+ import { __decorate, __param } from 'vscode/external/tslib/tslib.es6.js';
2
+ import { findLast } from 'vscode/vscode/vs/base/common/arraysFind';
3
+ import { Disposable } from 'vscode/vscode/vs/base/common/lifecycle';
4
+ import { observableValue, transaction } from 'vscode/vscode/vs/base/common/observableInternal/base';
5
+ import { derived } from 'vscode/vscode/vs/base/common/observableInternal/derived';
6
+ import 'vscode/vscode/vs/base/common/observableInternal/autorun';
7
+ import { derivedObservableWithWritableCache } from 'vscode/vscode/vs/base/common/observableInternal/utils';
8
+ import 'vscode/vscode/vs/base/common/cancellation';
9
+ import { Range } from 'vscode/vscode/vs/editor/common/core/range';
10
+ import { localizeWithPath } from 'vscode/vscode/vs/nls';
11
+ import { IConfigurationService } from 'vscode/vscode/vs/platform/configuration/common/configuration.service';
12
+ import { INotificationService } from 'vscode/vscode/vs/platform/notification/common/notification.service';
13
+ import { LineRange } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/browser/model/lineRange';
14
+ import { observableConfigValue } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/browser/utils';
15
+
16
+ let MergeEditorViewModel = class MergeEditorViewModel extends Disposable {
17
+ constructor(model, inputCodeEditorView1, inputCodeEditorView2, resultCodeEditorView, baseCodeEditorView, showNonConflictingChanges, configurationService, notificationService) {
18
+ super();
19
+ this.model = model;
20
+ this.inputCodeEditorView1 = inputCodeEditorView1;
21
+ this.inputCodeEditorView2 = inputCodeEditorView2;
22
+ this.resultCodeEditorView = resultCodeEditorView;
23
+ this.baseCodeEditorView = baseCodeEditorView;
24
+ this.showNonConflictingChanges = showNonConflictingChanges;
25
+ this.configurationService = configurationService;
26
+ this.notificationService = notificationService;
27
+ this.manuallySetActiveModifiedBaseRange = observableValue(this, { range: undefined, counter: 0 });
28
+ this.attachedHistory = this._register(( new AttachedHistory(this.model.resultTextModel)));
29
+ this.shouldUseAppendInsteadOfAccept = observableConfigValue('mergeEditor.shouldUseAppendInsteadOfAccept', false, this.configurationService);
30
+ this.counter = 0;
31
+ this.lastFocusedEditor = derivedObservableWithWritableCache(this, (reader, lastValue) => {
32
+ const editors = [
33
+ this.inputCodeEditorView1,
34
+ this.inputCodeEditorView2,
35
+ this.resultCodeEditorView,
36
+ this.baseCodeEditorView.read(reader),
37
+ ];
38
+ const view = editors.find((e) => e && e.isFocused.read(reader));
39
+ return view ? { view, counter: this.counter++ } : lastValue || { view: undefined, counter: this.counter++ };
40
+ });
41
+ this.baseShowDiffAgainst = derived(this, reader => {
42
+ const lastFocusedEditor = this.lastFocusedEditor.read(reader);
43
+ if (lastFocusedEditor.view === this.inputCodeEditorView1) {
44
+ return 1;
45
+ }
46
+ else if (lastFocusedEditor.view === this.inputCodeEditorView2) {
47
+ return 2;
48
+ }
49
+ return undefined;
50
+ });
51
+ this.selectionInBase = derived(this, reader => {
52
+ const sourceEditor = this.lastFocusedEditor.read(reader).view;
53
+ if (!sourceEditor) {
54
+ return undefined;
55
+ }
56
+ const selections = sourceEditor.selection.read(reader) || [];
57
+ const rangesInBase = ( selections.map((selection) => {
58
+ if (sourceEditor === this.inputCodeEditorView1) {
59
+ return this.model.translateInputRangeToBase(1, selection);
60
+ }
61
+ else if (sourceEditor === this.inputCodeEditorView2) {
62
+ return this.model.translateInputRangeToBase(2, selection);
63
+ }
64
+ else if (sourceEditor === this.resultCodeEditorView) {
65
+ return this.model.translateResultRangeToBase(selection);
66
+ }
67
+ else if (sourceEditor === this.baseCodeEditorView.read(reader)) {
68
+ return selection;
69
+ }
70
+ else {
71
+ return selection;
72
+ }
73
+ }));
74
+ return {
75
+ rangesInBase,
76
+ sourceEditor
77
+ };
78
+ });
79
+ this.activeModifiedBaseRange = derived(this, (reader) => {
80
+ const focusedEditor = this.lastFocusedEditor.read(reader);
81
+ const manualRange = this.manuallySetActiveModifiedBaseRange.read(reader);
82
+ if (manualRange.counter > focusedEditor.counter) {
83
+ return manualRange.range;
84
+ }
85
+ if (!focusedEditor.view) {
86
+ return;
87
+ }
88
+ const cursorLineNumber = focusedEditor.view.cursorLineNumber.read(reader);
89
+ if (!cursorLineNumber) {
90
+ return undefined;
91
+ }
92
+ const modifiedBaseRanges = this.model.modifiedBaseRanges.read(reader);
93
+ return modifiedBaseRanges.find((r) => {
94
+ const range = this.getRangeOfModifiedBaseRange(focusedEditor.view, r, reader);
95
+ return range.isEmpty
96
+ ? range.startLineNumber === cursorLineNumber
97
+ : range.contains(cursorLineNumber);
98
+ });
99
+ });
100
+ this._register(resultCodeEditorView.editor.onDidChangeModelContent(e => {
101
+ if (this.model.isApplyingEditInResult || e.isRedoing || e.isUndoing) {
102
+ return;
103
+ }
104
+ const baseRangeStates = [];
105
+ for (const change of e.changes) {
106
+ const rangeInBase = this.model.translateResultRangeToBase(Range.lift(change.range));
107
+ const baseRanges = this.model.findModifiedBaseRangesInRange(( new LineRange(
108
+ rangeInBase.startLineNumber,
109
+ rangeInBase.endLineNumber - rangeInBase.startLineNumber
110
+ )));
111
+ if (baseRanges.length === 1) {
112
+ const isHandled = this.model.isHandled(baseRanges[0]).get();
113
+ if (!isHandled) {
114
+ baseRangeStates.push(baseRanges[0]);
115
+ }
116
+ }
117
+ }
118
+ if (baseRangeStates.length === 0) {
119
+ return;
120
+ }
121
+ const element = {
122
+ model: this.model,
123
+ redo() {
124
+ transaction(tx => {
125
+ for (const r of baseRangeStates) {
126
+ this.model.setHandled(r, true, tx);
127
+ }
128
+ });
129
+ },
130
+ undo() {
131
+ transaction(tx => {
132
+ for (const r of baseRangeStates) {
133
+ this.model.setHandled(r, false, tx);
134
+ }
135
+ });
136
+ },
137
+ };
138
+ this.attachedHistory.pushAttachedHistoryElement(element);
139
+ element.redo();
140
+ }));
141
+ }
142
+ getRangeOfModifiedBaseRange(editor, modifiedBaseRange, reader) {
143
+ if (editor === this.resultCodeEditorView) {
144
+ return this.model.getLineRangeInResult(modifiedBaseRange.baseRange, reader);
145
+ }
146
+ else if (editor === this.baseCodeEditorView.get()) {
147
+ return modifiedBaseRange.baseRange;
148
+ }
149
+ else {
150
+ const input = editor === this.inputCodeEditorView1 ? 1 : 2;
151
+ return modifiedBaseRange.getInputRange(input);
152
+ }
153
+ }
154
+ setActiveModifiedBaseRange(range, tx) {
155
+ this.manuallySetActiveModifiedBaseRange.set({ range, counter: this.counter++ }, tx);
156
+ }
157
+ setState(baseRange, state, tx, inputNumber) {
158
+ this.manuallySetActiveModifiedBaseRange.set({ range: baseRange, counter: this.counter++ }, tx);
159
+ this.model.setState(baseRange, state, inputNumber, tx);
160
+ }
161
+ goToConflict(getModifiedBaseRange) {
162
+ let editor = this.lastFocusedEditor.get().view;
163
+ if (!editor) {
164
+ editor = this.resultCodeEditorView;
165
+ }
166
+ const curLineNumber = editor.editor.getPosition()?.lineNumber;
167
+ if (curLineNumber === undefined) {
168
+ return;
169
+ }
170
+ const modifiedBaseRange = getModifiedBaseRange(editor, curLineNumber);
171
+ if (modifiedBaseRange) {
172
+ const range = this.getRangeOfModifiedBaseRange(editor, modifiedBaseRange, undefined);
173
+ editor.editor.focus();
174
+ let startLineNumber = range.startLineNumber;
175
+ let endLineNumberExclusive = range.endLineNumberExclusive;
176
+ if (range.startLineNumber > editor.editor.getModel().getLineCount()) {
177
+ transaction(tx => {
178
+ this.setActiveModifiedBaseRange(modifiedBaseRange, tx);
179
+ });
180
+ startLineNumber = endLineNumberExclusive = editor.editor.getModel().getLineCount();
181
+ }
182
+ editor.editor.setPosition({
183
+ lineNumber: startLineNumber,
184
+ column: editor.editor.getModel().getLineFirstNonWhitespaceColumn(startLineNumber),
185
+ });
186
+ editor.editor.revealLinesNearTop(startLineNumber, endLineNumberExclusive, 0 );
187
+ }
188
+ }
189
+ goToNextModifiedBaseRange(predicate) {
190
+ this.goToConflict((e, l) => this.model.modifiedBaseRanges
191
+ .get()
192
+ .find((r) => predicate(r) &&
193
+ this.getRangeOfModifiedBaseRange(e, r, undefined).startLineNumber > l) ||
194
+ this.model.modifiedBaseRanges
195
+ .get()
196
+ .find((r) => predicate(r)));
197
+ }
198
+ goToPreviousModifiedBaseRange(predicate) {
199
+ this.goToConflict((e, l) => findLast(this.model.modifiedBaseRanges.get(), (r) => predicate(r) &&
200
+ this.getRangeOfModifiedBaseRange(e, r, undefined).endLineNumberExclusive < l) ||
201
+ findLast(this.model.modifiedBaseRanges.get(), (r) => predicate(r)));
202
+ }
203
+ toggleActiveConflict(inputNumber) {
204
+ const activeModifiedBaseRange = this.activeModifiedBaseRange.get();
205
+ if (!activeModifiedBaseRange) {
206
+ this.notificationService.error(( localizeWithPath(
207
+ 'vs/workbench/contrib/mergeEditor/browser/view/viewModel',
208
+ 'noConflictMessage',
209
+ "There is currently no conflict focused that can be toggled."
210
+ )));
211
+ return;
212
+ }
213
+ transaction(tx => {
214
+ this.setState(activeModifiedBaseRange, this.model.getState(activeModifiedBaseRange).get().toggle(inputNumber), tx, inputNumber);
215
+ });
216
+ }
217
+ acceptAll(inputNumber) {
218
+ transaction(tx => {
219
+ for (const range of this.model.modifiedBaseRanges.get()) {
220
+ this.setState(range, this.model.getState(range).get().withInputValue(inputNumber, true), tx, inputNumber);
221
+ }
222
+ });
223
+ }
224
+ };
225
+ MergeEditorViewModel = ( __decorate([
226
+ ( __param(6, IConfigurationService)),
227
+ ( __param(7, INotificationService))
228
+ ], MergeEditorViewModel));
229
+ class AttachedHistory extends Disposable {
230
+ constructor(model) {
231
+ super();
232
+ this.model = model;
233
+ this.attachedHistory = [];
234
+ this.previousAltId = this.model.getAlternativeVersionId();
235
+ this._register(model.onDidChangeContent((e) => {
236
+ const currentAltId = model.getAlternativeVersionId();
237
+ if (e.isRedoing) {
238
+ for (const item of this.attachedHistory) {
239
+ if (this.previousAltId < item.altId && item.altId <= currentAltId) {
240
+ item.element.redo();
241
+ }
242
+ }
243
+ }
244
+ else if (e.isUndoing) {
245
+ for (let i = this.attachedHistory.length - 1; i >= 0; i--) {
246
+ const item = this.attachedHistory[i];
247
+ if (currentAltId < item.altId && item.altId <= this.previousAltId) {
248
+ item.element.undo();
249
+ }
250
+ }
251
+ }
252
+ else {
253
+ while (this.attachedHistory.length > 0
254
+ && this.attachedHistory[this.attachedHistory.length - 1].altId > this.previousAltId) {
255
+ this.attachedHistory.pop();
256
+ }
257
+ }
258
+ this.previousAltId = currentAltId;
259
+ }));
260
+ }
261
+ pushAttachedHistoryElement(element) {
262
+ this.attachedHistory.push({ altId: this.model.getAlternativeVersionId(), element });
263
+ }
264
+ }
265
+
266
+ export { MergeEditorViewModel };
@@ -0,0 +1,173 @@
1
+ import { $ } from 'vscode/vscode/vs/base/browser/dom';
2
+ import { CompareResult, lastOrDefault } from 'vscode/vscode/vs/base/common/arrays';
3
+ import { LineRange } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/browser/model/lineRange';
4
+ import { join } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/browser/utils';
5
+ import { ConflictActionsFactory, ActionsSource } from './conflictActions.js';
6
+ import { getAlignments } from './lineAlignment.js';
7
+
8
+ class ViewZoneComputer {
9
+ constructor(input1Editor, input2Editor, resultEditor) {
10
+ this.input1Editor = input1Editor;
11
+ this.input2Editor = input2Editor;
12
+ this.resultEditor = resultEditor;
13
+ this.conflictActionsFactoryInput1 = ( new ConflictActionsFactory(this.input1Editor));
14
+ this.conflictActionsFactoryInput2 = ( new ConflictActionsFactory(this.input2Editor));
15
+ this.conflictActionsFactoryResult = ( new ConflictActionsFactory(this.resultEditor));
16
+ }
17
+ computeViewZones(reader, viewModel, options) {
18
+ let input1LinesAdded = 0;
19
+ let input2LinesAdded = 0;
20
+ let baseLinesAdded = 0;
21
+ let resultLinesAdded = 0;
22
+ const input1ViewZones = [];
23
+ const input2ViewZones = [];
24
+ const baseViewZones = [];
25
+ const resultViewZones = [];
26
+ const model = viewModel.model;
27
+ const resultDiffs = model.baseResultDiffs.read(reader);
28
+ const baseRangeWithStoreAndTouchingDiffs = join(model.modifiedBaseRanges.read(reader), resultDiffs, (baseRange, diff) => baseRange.baseRange.touches(diff.inputRange)
29
+ ? CompareResult.neitherLessOrGreaterThan
30
+ : LineRange.compareByStart(baseRange.baseRange, diff.inputRange));
31
+ const shouldShowCodeLenses = options.codeLensesVisible;
32
+ const showNonConflictingChanges = options.showNonConflictingChanges;
33
+ let lastModifiedBaseRange = undefined;
34
+ let lastBaseResultDiff = undefined;
35
+ for (const m of baseRangeWithStoreAndTouchingDiffs) {
36
+ if (shouldShowCodeLenses && m.left && (m.left.isConflicting || showNonConflictingChanges || !model.isHandled(m.left).read(reader))) {
37
+ const actions = ( new ActionsSource(viewModel, m.left));
38
+ if (options.shouldAlignResult || !actions.inputIsEmpty.read(reader)) {
39
+ input1ViewZones.push(( new CommandViewZone(
40
+ this.conflictActionsFactoryInput1,
41
+ m.left.input1Range.startLineNumber - 1,
42
+ actions.itemsInput1
43
+ )));
44
+ input2ViewZones.push(( new CommandViewZone(
45
+ this.conflictActionsFactoryInput2,
46
+ m.left.input2Range.startLineNumber - 1,
47
+ actions.itemsInput2
48
+ )));
49
+ if (options.shouldAlignBase) {
50
+ baseViewZones.push(( new Placeholder(m.left.baseRange.startLineNumber - 1, 16)));
51
+ }
52
+ }
53
+ const afterLineNumber = m.left.baseRange.startLineNumber + (lastBaseResultDiff?.resultingDeltaFromOriginalToModified ?? 0) - 1;
54
+ resultViewZones.push(( new CommandViewZone(this.conflictActionsFactoryResult, afterLineNumber, actions.resultItems)));
55
+ }
56
+ const lastResultDiff = lastOrDefault(m.rights);
57
+ if (lastResultDiff) {
58
+ lastBaseResultDiff = lastResultDiff;
59
+ }
60
+ let alignedLines;
61
+ if (m.left) {
62
+ alignedLines = ( getAlignments(m.left).map(a => ({
63
+ input1Line: a[0],
64
+ baseLine: a[1],
65
+ input2Line: a[2],
66
+ resultLine: undefined,
67
+ })));
68
+ lastModifiedBaseRange = m.left;
69
+ alignedLines[alignedLines.length - 1].resultLine =
70
+ m.left.baseRange.endLineNumberExclusive
71
+ + (lastBaseResultDiff ? lastBaseResultDiff.resultingDeltaFromOriginalToModified : 0);
72
+ }
73
+ else {
74
+ alignedLines = [{
75
+ baseLine: lastResultDiff.inputRange.endLineNumberExclusive,
76
+ input1Line: lastResultDiff.inputRange.endLineNumberExclusive + (lastModifiedBaseRange ? (lastModifiedBaseRange.input1Range.endLineNumberExclusive - lastModifiedBaseRange.baseRange.endLineNumberExclusive) : 0),
77
+ input2Line: lastResultDiff.inputRange.endLineNumberExclusive + (lastModifiedBaseRange ? (lastModifiedBaseRange.input2Range.endLineNumberExclusive - lastModifiedBaseRange.baseRange.endLineNumberExclusive) : 0),
78
+ resultLine: lastResultDiff.outputRange.endLineNumberExclusive,
79
+ }];
80
+ }
81
+ for (const { input1Line, baseLine, input2Line, resultLine } of alignedLines) {
82
+ if (!options.shouldAlignBase && (input1Line === undefined || input2Line === undefined)) {
83
+ continue;
84
+ }
85
+ const input1Line_ = input1Line !== undefined ? input1Line + input1LinesAdded : -1;
86
+ const input2Line_ = input2Line !== undefined ? input2Line + input2LinesAdded : -1;
87
+ const baseLine_ = baseLine + baseLinesAdded;
88
+ const resultLine_ = resultLine !== undefined ? resultLine + resultLinesAdded : -1;
89
+ const max = Math.max(options.shouldAlignBase ? baseLine_ : 0, input1Line_, input2Line_, options.shouldAlignResult ? resultLine_ : 0);
90
+ if (input1Line !== undefined) {
91
+ const diffInput1 = max - input1Line_;
92
+ if (diffInput1 > 0) {
93
+ input1ViewZones.push(( new Spacer(input1Line - 1, diffInput1)));
94
+ input1LinesAdded += diffInput1;
95
+ }
96
+ }
97
+ if (input2Line !== undefined) {
98
+ const diffInput2 = max - input2Line_;
99
+ if (diffInput2 > 0) {
100
+ input2ViewZones.push(( new Spacer(input2Line - 1, diffInput2)));
101
+ input2LinesAdded += diffInput2;
102
+ }
103
+ }
104
+ if (options.shouldAlignBase) {
105
+ const diffBase = max - baseLine_;
106
+ if (diffBase > 0) {
107
+ baseViewZones.push(( new Spacer(baseLine - 1, diffBase)));
108
+ baseLinesAdded += diffBase;
109
+ }
110
+ }
111
+ if (options.shouldAlignResult && resultLine !== undefined) {
112
+ const diffResult = max - resultLine_;
113
+ if (diffResult > 0) {
114
+ resultViewZones.push(( new Spacer(resultLine - 1, diffResult)));
115
+ resultLinesAdded += diffResult;
116
+ }
117
+ }
118
+ }
119
+ }
120
+ return ( new MergeEditorViewZones(input1ViewZones, input2ViewZones, baseViewZones, resultViewZones));
121
+ }
122
+ }
123
+ class MergeEditorViewZones {
124
+ constructor(input1ViewZones, input2ViewZones, baseViewZones, resultViewZones) {
125
+ this.input1ViewZones = input1ViewZones;
126
+ this.input2ViewZones = input2ViewZones;
127
+ this.baseViewZones = baseViewZones;
128
+ this.resultViewZones = resultViewZones;
129
+ }
130
+ }
131
+ class MergeEditorViewZone {
132
+ }
133
+ class Spacer extends MergeEditorViewZone {
134
+ constructor(afterLineNumber, heightInLines) {
135
+ super();
136
+ this.afterLineNumber = afterLineNumber;
137
+ this.heightInLines = heightInLines;
138
+ }
139
+ create(viewZoneChangeAccessor, viewZoneIdsToCleanUp, disposableStore) {
140
+ viewZoneIdsToCleanUp.push(viewZoneChangeAccessor.addZone({
141
+ afterLineNumber: this.afterLineNumber,
142
+ heightInLines: this.heightInLines,
143
+ domNode: $('div.diagonal-fill'),
144
+ }));
145
+ }
146
+ }
147
+ class Placeholder extends MergeEditorViewZone {
148
+ constructor(afterLineNumber, heightPx) {
149
+ super();
150
+ this.afterLineNumber = afterLineNumber;
151
+ this.heightPx = heightPx;
152
+ }
153
+ create(viewZoneChangeAccessor, viewZoneIdsToCleanUp, disposableStore) {
154
+ viewZoneIdsToCleanUp.push(viewZoneChangeAccessor.addZone({
155
+ afterLineNumber: this.afterLineNumber,
156
+ heightInPx: this.heightPx,
157
+ domNode: $('div.conflict-actions-placeholder'),
158
+ }));
159
+ }
160
+ }
161
+ class CommandViewZone extends MergeEditorViewZone {
162
+ constructor(conflictActionsFactory, lineNumber, items) {
163
+ super();
164
+ this.conflictActionsFactory = conflictActionsFactory;
165
+ this.lineNumber = lineNumber;
166
+ this.items = items;
167
+ }
168
+ create(viewZoneChangeAccessor, viewZoneIdsToCleanUp, disposableStore) {
169
+ disposableStore.add(this.conflictActionsFactory.createWidget(viewZoneChangeAccessor, this.lineNumber, this.items, viewZoneIdsToCleanUp));
170
+ }
171
+ }
172
+
173
+ export { MergeEditorViewZone, MergeEditorViewZones, ViewZoneComputer };