mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-01-26 01:25:38 -05:00
* fix grid links * formatting * remove commented code * adding query plan * asd * add query plan * fix title
163 lines
5.6 KiB
TypeScript
163 lines
5.6 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 { TPromise } from 'vs/base/common/winjs.base';
|
|
import { EditorOptions } from 'vs/workbench/common/editor';
|
|
import { ITelemetryService } from 'vs/platform/telemetry/common/telemetry';
|
|
import { RawContextKey } from 'vs/platform/contextkey/common/contextkey';
|
|
import { BaseEditor } from 'vs/workbench/browser/parts/editor/baseEditor';
|
|
import { IConfigurationService } from 'vs/platform/configuration/common/configuration';
|
|
import { BareFontInfo } from 'vs/editor/common/config/fontInfo';
|
|
import { getZoomLevel } from 'vs/base/browser/browser';
|
|
import { IThemeService } from 'vs/platform/theme/common/themeService';
|
|
import * as DOM from 'vs/base/browser/dom';
|
|
import * as types from 'vs/base/common/types';
|
|
import { IInstantiationService } from 'vs/platform/instantiation/common/instantiation';
|
|
|
|
import { QueryResultsInput } from 'sql/parts/query/common/queryResultsInput';
|
|
import { IQueryModelService } from 'sql/parts/query/execution/queryModel';
|
|
import { QueryResultsView } from 'sql/parts/query/editor/queryResultsView';
|
|
import { CancellationToken } from 'vs/base/common/cancellation';
|
|
|
|
export const RESULTS_GRID_DEFAULTS = {
|
|
cellPadding: [6, 10, 5],
|
|
rowHeight: 29
|
|
};
|
|
|
|
export const TextCompareEditorVisible = new RawContextKey<boolean>('textCompareEditorVisible', false);
|
|
|
|
export class BareResultsGridInfo extends BareFontInfo {
|
|
|
|
public static createFromRawSettings(opts: {
|
|
fontFamily?: string;
|
|
fontWeight?: string;
|
|
fontSize?: number | string;
|
|
lineHeight?: number | string;
|
|
letterSpacing?: number | string;
|
|
cellPadding?: number | number[];
|
|
}, zoomLevel: number): BareResultsGridInfo {
|
|
let cellPadding = !types.isUndefinedOrNull(opts.cellPadding) ? opts.cellPadding : RESULTS_GRID_DEFAULTS.cellPadding;
|
|
|
|
return new BareResultsGridInfo(BareFontInfo.createFromRawSettings(opts, zoomLevel), { cellPadding });
|
|
}
|
|
|
|
readonly cellPadding: number | number[];
|
|
|
|
protected constructor(fontInfo: BareFontInfo, opts: {
|
|
cellPadding: number | number[];
|
|
}) {
|
|
super({
|
|
zoomLevel: fontInfo.zoomLevel,
|
|
fontFamily: fontInfo.fontFamily,
|
|
fontWeight: fontInfo.fontWeight,
|
|
fontSize: fontInfo.fontSize,
|
|
lineHeight: fontInfo.lineHeight,
|
|
letterSpacing: fontInfo.letterSpacing
|
|
});
|
|
this.cellPadding = opts.cellPadding;
|
|
}
|
|
}
|
|
|
|
function getBareResultsGridInfoStyles(info: BareResultsGridInfo): string {
|
|
let content = '';
|
|
if (info.fontFamily) {
|
|
content += `font-family: ${info.fontFamily};`;
|
|
}
|
|
if (info.fontWeight) {
|
|
content += `font-weight: ${info.fontWeight};`;
|
|
}
|
|
if (info.fontSize) {
|
|
content += `font-size: ${info.fontSize}px;`;
|
|
}
|
|
if (info.lineHeight) {
|
|
content += `line-height: ${info.lineHeight}px;`;
|
|
}
|
|
if (info.letterSpacing) {
|
|
content += `letter-spacing: ${info.letterSpacing}px;`;
|
|
}
|
|
return content;
|
|
}
|
|
|
|
/**
|
|
* Editor associated with viewing and editing the data of a query results grid.
|
|
*/
|
|
export class QueryResultsEditor extends BaseEditor {
|
|
|
|
public static ID: string = 'workbench.editor.queryResultsEditor';
|
|
public static AngularSelectorString: string = 'slickgrid-container.slickgridContainer';
|
|
protected _rawOptions: BareResultsGridInfo;
|
|
protected _input: QueryResultsInput;
|
|
|
|
private resultsView: QueryResultsView;
|
|
|
|
constructor(
|
|
@ITelemetryService telemetryService: ITelemetryService,
|
|
@IThemeService themeService: IThemeService,
|
|
@IQueryModelService private _queryModelService: IQueryModelService,
|
|
@IConfigurationService private _configurationService: IConfigurationService,
|
|
@IInstantiationService private _instantiationService: IInstantiationService
|
|
) {
|
|
super(QueryResultsEditor.ID, telemetryService, themeService);
|
|
this._rawOptions = BareResultsGridInfo.createFromRawSettings(this._configurationService.getValue('resultsGrid'), getZoomLevel());
|
|
// this._configurationService.onDidChangeConfiguration(e => {
|
|
// if (e.affectsConfiguration('resultsGrid')) {
|
|
// this._rawOptions = BareResultsGridInfo.createFromRawSettings(this._configurationService.getValue('resultsGrid'), getZoomLevel());
|
|
// this.applySettings();
|
|
// }
|
|
// });
|
|
}
|
|
|
|
public get input(): QueryResultsInput {
|
|
return this._input;
|
|
}
|
|
|
|
private applySettings() {
|
|
if (this.input && this.input.container) {
|
|
if (!this.input.css) {
|
|
this.input.css = DOM.createStyleSheet(this.input.container);
|
|
}
|
|
let cssRuleText = '';
|
|
if (types.isNumber(this._rawOptions.cellPadding)) {
|
|
cssRuleText = this._rawOptions.cellPadding + 'px';
|
|
} else {
|
|
cssRuleText = this._rawOptions.cellPadding.join('px ') + 'px;';
|
|
}
|
|
let content = `.grid .slick-cell { padding: ${cssRuleText}; }`;
|
|
content += `.grid { ${getBareResultsGridInfoStyles(this._rawOptions)} }`;
|
|
this.input.css.innerHTML = content;
|
|
}
|
|
}
|
|
|
|
createEditor(parent: HTMLElement): void {
|
|
if (!this.resultsView) {
|
|
this.resultsView = new QueryResultsView(parent, this._instantiationService, this._queryModelService);
|
|
}
|
|
}
|
|
|
|
layout(dimension: DOM.Dimension): void {
|
|
this.resultsView.layout(dimension);
|
|
}
|
|
|
|
setInput(input: QueryResultsInput, options: EditorOptions): TPromise<void> {
|
|
super.setInput(input, options, CancellationToken.None);
|
|
this.resultsView.input = input;
|
|
return TPromise.wrap<void>(null);
|
|
}
|
|
|
|
public chart(dataId: { batchId: number, resultId: number }) {
|
|
this.resultsView.chartData(dataId);
|
|
}
|
|
|
|
public showQueryPlan(xml: string) {
|
|
this.resultsView.showPlan(xml);
|
|
}
|
|
|
|
public dispose(): void {
|
|
super.dispose();
|
|
}
|
|
}
|