mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-02-06 09:35:41 -05:00
123 lines
5.1 KiB
TypeScript
123 lines
5.1 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 { Inject, NgModule, forwardRef, ApplicationRef, ComponentFactoryResolver } from '@angular/core';
|
|
import { CommonModule, APP_BASE_HREF } from '@angular/common';
|
|
import { BrowserModule } from '@angular/platform-browser';
|
|
import { RouterModule, Routes, UrlSerializer } from '@angular/router';
|
|
import { FormsModule } from '@angular/forms';
|
|
import { NgGridModule } from 'angular2-grid';
|
|
import { ChartsModule } from 'ng2-charts/ng2-charts';
|
|
|
|
import CustomUrlSerializer from 'sql/common/urlSerializer';
|
|
import { IBootstrapService, BOOTSTRAP_SERVICE_ID } from 'sql/services/bootstrap/bootstrapService';
|
|
import { Extensions, IInsightRegistry } from 'sql/platform/dashboard/common/insightRegistry';
|
|
|
|
import { Registry } from 'vs/platform/registry/common/platform';
|
|
|
|
/* Services */
|
|
import { BreadcrumbService } from 'sql/parts/dashboard/services/breadcrumb.service';
|
|
import { DashboardServiceInterface } from 'sql/parts/dashboard/services/dashboardServiceInterface.service';
|
|
|
|
/* Directives */
|
|
import { ComponentHostDirective } from 'sql/parts/dashboard/common/componentHost.directive';
|
|
|
|
/* Base Components */
|
|
import { DashboardComponent, DASHBOARD_SELECTOR } from 'sql/parts/dashboard/dashboard.component';
|
|
import { DashboardWidgetWrapper } from 'sql/parts/dashboard/common/dashboardWidgetWrapper.component';
|
|
import { DashboardWidgetTab } from 'sql/parts/dashboard/tabs/dashboardWidgetTab.component';
|
|
import { DashboardGridTab } from 'sql/parts/dashboard/tabs/dashboardGridTab.component';
|
|
import { DashboardWebviewTab } from 'sql/parts/dashboard/tabs/dashboardWebviewTab.component';
|
|
import { WidgetContent } from 'sql/parts/dashboard/contents/widgetContent.component';
|
|
import { WebviewContent } from 'sql/parts/dashboard/contents/webviewContent.component';
|
|
import { BreadcrumbComponent } from 'sql/base/browser/ui/breadcrumb/breadcrumb.component';
|
|
import { IBreadcrumbService } from 'sql/base/browser/ui/breadcrumb/interfaces';
|
|
let baseComponents = [DashboardComponent, DashboardWidgetWrapper, DashboardWebviewTab, DashboardWidgetTab, DashboardGridTab, WidgetContent, WebviewContent, ComponentHostDirective, BreadcrumbComponent];
|
|
|
|
/* Panel */
|
|
import { PanelModule } from 'sql/base/browser/ui/panel/panel.module';
|
|
|
|
/* Pages */
|
|
import { ServerDashboardPage } from 'sql/parts/dashboard/pages/serverDashboardPage.component';
|
|
import { DatabaseDashboardPage } from 'sql/parts/dashboard/pages/databaseDashboardPage.component';
|
|
let pageComponents = [ServerDashboardPage, DatabaseDashboardPage];
|
|
|
|
/* Widget Components */
|
|
import { PropertiesWidgetComponent } from 'sql/parts/dashboard/widgets/properties/propertiesWidget.component';
|
|
import { ExplorerWidget } from 'sql/parts/dashboard/widgets/explorer/explorerWidget.component';
|
|
import { TasksWidget } from 'sql/parts/dashboard/widgets/tasks/tasksWidget.component';
|
|
import { InsightsWidget } from 'sql/parts/dashboard/widgets/insights/insightsWidget.component';
|
|
import { WebviewWidget } from 'sql/parts/dashboard/widgets/webview/webviewWidget.component';
|
|
let widgetComponents = [
|
|
PropertiesWidgetComponent,
|
|
ExplorerWidget,
|
|
TasksWidget,
|
|
InsightsWidget,
|
|
WebviewWidget
|
|
];
|
|
|
|
/* Insights */
|
|
let insightComponents = Registry.as<IInsightRegistry>(Extensions.InsightContribution).getAllCtors();
|
|
|
|
// Setup routes for various child components
|
|
const appRoutes: Routes = [
|
|
{ path: 'database-dashboard', component: DatabaseDashboardPage },
|
|
{ path: 'server-dashboard', component: ServerDashboardPage },
|
|
{
|
|
path: '',
|
|
redirectTo: 'database-dashboard',
|
|
pathMatch: 'full'
|
|
},
|
|
{ path: '**', component: DatabaseDashboardPage }
|
|
];
|
|
|
|
// Connection Dashboard main angular module
|
|
@NgModule({
|
|
declarations: [
|
|
...baseComponents,
|
|
...pageComponents,
|
|
...widgetComponents,
|
|
...insightComponents
|
|
],
|
|
// also for widgets
|
|
entryComponents: [
|
|
DashboardComponent,
|
|
...widgetComponents,
|
|
...insightComponents
|
|
],
|
|
imports: [
|
|
CommonModule,
|
|
BrowserModule,
|
|
FormsModule,
|
|
NgGridModule,
|
|
ChartsModule,
|
|
RouterModule.forRoot(appRoutes),
|
|
PanelModule
|
|
],
|
|
providers: [
|
|
{ provide: APP_BASE_HREF, useValue: '/' },
|
|
{ provide: IBreadcrumbService, useClass: BreadcrumbService },
|
|
DashboardServiceInterface,
|
|
{ provide: UrlSerializer, useClass: CustomUrlSerializer }
|
|
]
|
|
})
|
|
export class DashboardModule {
|
|
|
|
constructor(
|
|
@Inject(forwardRef(() => ComponentFactoryResolver)) private _resolver: ComponentFactoryResolver,
|
|
@Inject(BOOTSTRAP_SERVICE_ID) private _bootstrapService: IBootstrapService,
|
|
@Inject(forwardRef(() => DashboardServiceInterface)) private _bootstrap: DashboardServiceInterface
|
|
) {
|
|
}
|
|
|
|
ngDoBootstrap(appRef: ApplicationRef) {
|
|
const factory = this._resolver.resolveComponentFactory(DashboardComponent);
|
|
const uniqueSelector: string = this._bootstrapService.getUniqueSelector(DASHBOARD_SELECTOR);
|
|
this._bootstrap.selector = uniqueSelector;
|
|
(<any>factory).factory.selector = uniqueSelector;
|
|
appRef.bootstrap(factory);
|
|
}
|
|
}
|