import { NgModule, ApplicationRef } from '@angular/core'; import { BrowserModule } from '@angular/platform-browser'; import { FormsModule } from '@angular/forms'; import { HttpModule } from '@angular/http'; import { RouterModule } from '@angular/router'; import { removeNgStyles, createNewHosts, createInputTransfer } from '@angularclass/hmr'; /* * Platform and Environment providers/directives/pipes */ import { ENV_PROVIDERS } from './environment'; import { ProductService } from './Services/order.service'; import { ROUTES } from './app.routes'; // App is our top level component import { AppComponent } from './app.component'; import { AppState, InternalStateType } from './app.service'; import { HomeComponent } from './View/home'; import { TabComponent } from './Components/Tab'; import { NoContentComponent } from './View/no-content'; // Application wide providers const APP_PROVIDERS = [ AppState ]; type StoreType = { state: InternalStateType, restoreInputValues: () => void, disposeOldHosts: () => void }; /** * `AppModule` is the main entry point into Angular2's bootstraping process */ @NgModule({ bootstrap: [ AppComponent ], declarations: [ AppComponent, HomeComponent, NoContentComponent, TabComponent ], imports: [ // import Angular's modules BrowserModule, FormsModule, HttpModule, RouterModule.forRoot(ROUTES, { useHash: true }) ], providers: [ // expose our Services and Providers into Angular's dependency injection ENV_PROVIDERS, APP_PROVIDERS, ProductService ] }) export class AppModule {}