mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-02-09 01:32:34 -05:00
* Initial VS Code 1.21 file copy with patches * A few more merges * Post npm install * Fix batch of build breaks * Fix more build breaks * Fix more build errors * Fix more build breaks * Runtime fixes 1 * Get connection dialog working with some todos * Fix a few packaging issues * Copy several node_modules to package build to fix loader issues * Fix breaks from master * A few more fixes * Make tests pass * First pass of license header updates * Second pass of license header updates * Fix restore dialog issues * Remove add additional themes menu items * fix select box issues where the list doesn't show up * formatting * Fix editor dispose issue * Copy over node modules to correct location on all platforms
141 lines
4.7 KiB
TypeScript
141 lines
4.7 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
'use strict';
|
|
|
|
import 'vs/css!./currentLineMarginHighlight';
|
|
import { DynamicViewOverlay } from 'vs/editor/browser/view/dynamicViewOverlay';
|
|
import { ViewContext } from 'vs/editor/common/view/viewContext';
|
|
import { RenderingContext } from 'vs/editor/common/view/renderingContext';
|
|
import * as viewEvents from 'vs/editor/common/view/viewEvents';
|
|
import { registerThemingParticipant } from 'vs/platform/theme/common/themeService';
|
|
import { editorLineHighlight, editorLineHighlightBorder } from 'vs/editor/common/view/editorColorRegistry';
|
|
|
|
export class CurrentLineMarginHighlightOverlay extends DynamicViewOverlay {
|
|
private _context: ViewContext;
|
|
private _lineHeight: number;
|
|
private _renderLineHighlight: 'none' | 'gutter' | 'line' | 'all';
|
|
private _selectionIsEmpty: boolean;
|
|
private _primaryCursorLineNumber: number;
|
|
private _contentLeft: number;
|
|
|
|
constructor(context: ViewContext) {
|
|
super();
|
|
this._context = context;
|
|
this._lineHeight = this._context.configuration.editor.lineHeight;
|
|
this._renderLineHighlight = this._context.configuration.editor.viewInfo.renderLineHighlight;
|
|
|
|
this._selectionIsEmpty = true;
|
|
this._primaryCursorLineNumber = 1;
|
|
this._contentLeft = this._context.configuration.editor.layoutInfo.contentLeft;
|
|
|
|
this._context.addEventHandler(this);
|
|
}
|
|
|
|
public dispose(): void {
|
|
this._context.removeEventHandler(this);
|
|
this._context = null;
|
|
super.dispose();
|
|
}
|
|
|
|
// --- begin event handlers
|
|
|
|
public onConfigurationChanged(e: viewEvents.ViewConfigurationChangedEvent): boolean {
|
|
if (e.lineHeight) {
|
|
this._lineHeight = this._context.configuration.editor.lineHeight;
|
|
}
|
|
if (e.viewInfo) {
|
|
this._renderLineHighlight = this._context.configuration.editor.viewInfo.renderLineHighlight;
|
|
}
|
|
if (e.layoutInfo) {
|
|
this._contentLeft = this._context.configuration.editor.layoutInfo.contentLeft;
|
|
}
|
|
return true;
|
|
}
|
|
public onCursorStateChanged(e: viewEvents.ViewCursorStateChangedEvent): boolean {
|
|
let hasChanged = false;
|
|
|
|
const primaryCursorLineNumber = e.selections[0].positionLineNumber;
|
|
if (this._primaryCursorLineNumber !== primaryCursorLineNumber) {
|
|
this._primaryCursorLineNumber = primaryCursorLineNumber;
|
|
hasChanged = true;
|
|
}
|
|
|
|
const selectionIsEmpty = e.selections[0].isEmpty();
|
|
if (this._selectionIsEmpty !== selectionIsEmpty) {
|
|
this._selectionIsEmpty = selectionIsEmpty;
|
|
hasChanged = true;
|
|
return true;
|
|
}
|
|
|
|
return hasChanged;
|
|
}
|
|
public onFlushed(e: viewEvents.ViewFlushedEvent): boolean {
|
|
return true;
|
|
}
|
|
public onLinesDeleted(e: viewEvents.ViewLinesDeletedEvent): boolean {
|
|
return true;
|
|
}
|
|
public onLinesInserted(e: viewEvents.ViewLinesInsertedEvent): boolean {
|
|
return true;
|
|
}
|
|
public onZonesChanged(e: viewEvents.ViewZonesChangedEvent): boolean {
|
|
return true;
|
|
}
|
|
// --- end event handlers
|
|
|
|
public prepareRender(ctx: RenderingContext): void {
|
|
}
|
|
|
|
public render(startLineNumber: number, lineNumber: number): string {
|
|
if (lineNumber === this._primaryCursorLineNumber) {
|
|
let className = 'current-line';
|
|
if (this._shouldShowCurrentLine()) {
|
|
const paintedInContent = this._willRenderContentCurrentLine();
|
|
className = 'current-line current-line-margin' + (paintedInContent ? ' current-line-margin-both' : '');
|
|
}
|
|
|
|
return (
|
|
'<div class="'
|
|
+ className
|
|
+ '" style="width:'
|
|
+ String(this._contentLeft)
|
|
+ 'px; height:'
|
|
+ String(this._lineHeight)
|
|
+ 'px;"></div>'
|
|
);
|
|
}
|
|
return '';
|
|
}
|
|
|
|
private _shouldShowCurrentLine(): boolean {
|
|
return (
|
|
(this._renderLineHighlight === 'gutter' || this._renderLineHighlight === 'all')
|
|
);
|
|
}
|
|
|
|
private _willRenderContentCurrentLine(): boolean {
|
|
return (
|
|
(this._renderLineHighlight === 'line' || this._renderLineHighlight === 'all')
|
|
&& this._selectionIsEmpty
|
|
);
|
|
}
|
|
}
|
|
|
|
registerThemingParticipant((theme, collector) => {
|
|
let lineHighlight = theme.getColor(editorLineHighlight);
|
|
if (lineHighlight) {
|
|
collector.addRule(`.monaco-editor .margin-view-overlays .current-line-margin { background-color: ${lineHighlight}; border: none; }`);
|
|
} else {
|
|
let lineHighlightBorder = theme.getColor(editorLineHighlightBorder);
|
|
if (lineHighlightBorder) {
|
|
collector.addRule(`.monaco-editor .margin-view-overlays .current-line-margin { border: 2px solid ${lineHighlightBorder}; }`);
|
|
}
|
|
if (theme.type === 'hc') {
|
|
collector.addRule(`.monaco-editor .margin-view-overlays .current-line-margin { border-width: 1px; }`);
|
|
}
|
|
}
|
|
});
|