/*--------------------------------------------------------------------------------------------- * 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('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 { super.setInput(input, options, CancellationToken.None); this.resultsView.input = input; return TPromise.wrap(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(); } }