mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-01-23 01:25:38 -05:00
73 lines
3.4 KiB
TypeScript
73 lines
3.4 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
import { QueryTextEditor } from 'sql/workbench/browser/modelComponents/queryTextEditor';
|
|
import * as stubs from 'sql/workbench/contrib/notebook/test/stubs';
|
|
import { INotebookModel, ICellModel } from 'sql/workbench/services/notebook/browser/models/modelInterfaces';
|
|
import { INotebookParams } from 'sql/workbench/services/notebook/browser/notebookService';
|
|
import * as dom from 'vs/base/browser/dom';
|
|
import { IInstantiationService } from 'vs/platform/instantiation/common/instantiation';
|
|
import { NullTelemetryService } from 'vs/platform/telemetry/common/telemetryUtils';
|
|
import { TestThemeService } from 'vs/platform/theme/test/common/testThemeService';
|
|
import { TestEditorGroupsService, TestEditorService, TestTextResourceConfigurationService } from 'vs/workbench/test/browser/workbenchTestServices';
|
|
import { TestStorageService } from 'vs/workbench/test/common/workbenchTestServices';
|
|
|
|
// Typically you will pass in either editor or the instantiationService parameter.
|
|
// Leave both undefined when you want the underlying object(s) to have an undefined editor.
|
|
export class NotebookEditorStub extends stubs.NotebookEditorStub {
|
|
cellEditors: CellEditorProviderStub[];
|
|
model: INotebookModel | undefined;
|
|
cells?: ICellModel[] = [];
|
|
|
|
public readonly id: string;
|
|
|
|
public readonly modelReady: Promise<INotebookModel>;
|
|
|
|
// Normally one needs to provide either the editor or the instantiationService as the constructor parameter
|
|
constructor({ cellGuid, instantiationService, editor, model, notebookParams }: { cellGuid?: string; instantiationService?: IInstantiationService; editor?: QueryTextEditor; model?: INotebookModel, notebookParams?: INotebookParams } = {}) {
|
|
super();
|
|
this.model = model;
|
|
this.notebookParams = notebookParams;
|
|
this.cellEditors = [new CellEditorProviderStub({ cellGuid: cellGuid, instantiationService: instantiationService, editor: editor })];
|
|
this.id = this.notebookParams?.notebookUri?.toString();
|
|
this.modelReady = Promise.resolve(this.model);
|
|
}
|
|
}
|
|
|
|
// Typically you will pass in either editor or the instantiationService parameter.
|
|
// Leave both undefined when you want the underlying object to have an undefined editor.
|
|
class CellEditorProviderStub extends stubs.CellEditorProviderStub {
|
|
private _editor: QueryTextEditor;
|
|
private _cellGuid: string;
|
|
constructor({ cellGuid, instantiationService, editor }: { cellGuid: string; instantiationService?: IInstantiationService; editor?: QueryTextEditor; }) {
|
|
super();
|
|
if (editor) {
|
|
this._editor = editor;
|
|
} else if (instantiationService) {
|
|
this._editor = new QueryTextEditor(
|
|
NullTelemetryService,
|
|
instantiationService,
|
|
new TestStorageService(),
|
|
new TestTextResourceConfigurationService(),
|
|
new TestThemeService(),
|
|
new TestEditorGroupsService(),
|
|
new TestEditorService()
|
|
);
|
|
}
|
|
if (this._editor) {
|
|
let div = dom.$('div', undefined, dom.$('span', { id: 'demospan' }));
|
|
let firstChild = div.firstChild as HTMLElement;
|
|
this._editor.create(firstChild);
|
|
}
|
|
this._cellGuid = cellGuid;
|
|
}
|
|
cellGuid(): string {
|
|
return this._cellGuid;
|
|
}
|
|
getEditor(): QueryTextEditor {
|
|
return this._editor;
|
|
}
|
|
}
|