2017-06-16 07:32:15 -05:00
|
|
|
import { ApplicationRef, NgModule } from '@angular/core'
|
|
|
|
import { BrowserModule } from '@angular/platform-browser'
|
2017-06-11 05:28:22 -05:00
|
|
|
import {
|
|
|
|
removeNgStyles,
|
|
|
|
createNewHosts,
|
|
|
|
createInputTransfer
|
2017-06-16 07:32:15 -05:00
|
|
|
} from '@angularclass/hmr'
|
2016-09-06 15:40:57 -05:00
|
|
|
|
2017-07-06 10:43:58 -05:00
|
|
|
import { MetaModule, MetaLoader, MetaStaticLoader, PageTitlePositioning } from '@ngx-meta/core'
|
2017-06-16 07:32:15 -05:00
|
|
|
import 'bootstrap-loader'
|
2016-11-04 11:25:26 -05:00
|
|
|
|
2017-06-16 07:32:15 -05:00
|
|
|
import { ENV_PROVIDERS } from './environment'
|
|
|
|
import { AppRoutingModule } from './app-routing.module'
|
|
|
|
import { AppComponent } from './app.component'
|
|
|
|
import { AppState, InternalStateType } from './app.service'
|
2016-09-09 15:23:41 -05:00
|
|
|
|
2017-06-16 07:32:15 -05:00
|
|
|
import { AccountModule } from './account'
|
|
|
|
import { CoreModule } from './core'
|
|
|
|
import { LoginModule } from './login'
|
|
|
|
import { SignupModule } from './signup'
|
|
|
|
import { SharedModule } from './shared'
|
|
|
|
import { VideosModule } from './videos'
|
2017-12-08 03:41:49 -06:00
|
|
|
import { MenuComponent } from './menu'
|
2017-12-05 10:46:33 -06:00
|
|
|
import { HeaderComponent } from './header'
|
2016-11-20 10:18:15 -06:00
|
|
|
|
2017-06-16 07:32:15 -05:00
|
|
|
export function metaFactory (): MetaLoader {
|
2017-03-10 03:33:36 -06:00
|
|
|
return new MetaStaticLoader({
|
|
|
|
pageTitlePositioning: PageTitlePositioning.PrependPageTitle,
|
|
|
|
pageTitleSeparator: ' - ',
|
|
|
|
applicationName: 'PeerTube',
|
|
|
|
defaults: {
|
|
|
|
title: 'PeerTube',
|
|
|
|
description: 'PeerTube, a decentralized video streaming platform using P2P (BitTorrent) directly in the web browser'
|
|
|
|
}
|
2017-06-16 07:32:15 -05:00
|
|
|
})
|
2017-03-10 03:33:36 -06:00
|
|
|
}
|
2016-11-04 11:25:26 -05:00
|
|
|
|
2017-06-11 05:28:22 -05:00
|
|
|
type StoreType = {
|
|
|
|
state: InternalStateType,
|
|
|
|
restoreInputValues: () => void,
|
|
|
|
disposeOldHosts: () => void
|
2017-06-16 07:32:15 -05:00
|
|
|
}
|
2017-06-11 05:28:22 -05:00
|
|
|
|
2016-09-06 15:40:57 -05:00
|
|
|
// Application wide providers
|
|
|
|
const APP_PROVIDERS = [
|
2016-11-20 10:18:15 -06:00
|
|
|
AppState
|
2017-06-16 07:32:15 -05:00
|
|
|
]
|
2016-11-20 10:18:15 -06:00
|
|
|
|
2016-09-06 15:40:57 -05:00
|
|
|
@NgModule({
|
|
|
|
bootstrap: [ AppComponent ],
|
|
|
|
declarations: [
|
2017-12-01 02:20:19 -06:00
|
|
|
AppComponent,
|
|
|
|
|
|
|
|
MenuComponent,
|
2017-12-05 10:46:33 -06:00
|
|
|
HeaderComponent
|
2016-09-06 15:40:57 -05:00
|
|
|
],
|
2016-11-20 10:18:15 -06:00
|
|
|
imports: [
|
2016-09-06 15:40:57 -05:00
|
|
|
BrowserModule,
|
2016-09-09 15:23:41 -05:00
|
|
|
|
2016-11-20 10:18:15 -06:00
|
|
|
CoreModule,
|
|
|
|
SharedModule,
|
|
|
|
|
|
|
|
AppRoutingModule,
|
2016-11-04 11:25:26 -05:00
|
|
|
|
2016-11-20 10:18:15 -06:00
|
|
|
AccountModule,
|
|
|
|
CoreModule,
|
|
|
|
LoginModule,
|
2017-04-10 13:29:33 -05:00
|
|
|
SignupModule,
|
2016-11-20 10:18:15 -06:00
|
|
|
SharedModule,
|
2017-03-12 12:40:05 -05:00
|
|
|
VideosModule,
|
|
|
|
|
|
|
|
MetaModule.forRoot({
|
|
|
|
provide: MetaLoader,
|
|
|
|
useFactory: (metaFactory)
|
|
|
|
})
|
2016-09-06 15:40:57 -05:00
|
|
|
],
|
|
|
|
providers: [ // expose our Services and Providers into Angular's dependency injection
|
|
|
|
ENV_PROVIDERS,
|
|
|
|
APP_PROVIDERS
|
|
|
|
]
|
|
|
|
})
|
|
|
|
export class AppModule {
|
2017-06-16 07:32:15 -05:00
|
|
|
constructor (
|
2017-06-11 05:28:22 -05:00
|
|
|
public appRef: ApplicationRef,
|
|
|
|
public appState: AppState
|
|
|
|
) {}
|
|
|
|
|
2017-06-16 07:32:15 -05:00
|
|
|
public hmrOnInit (store: StoreType) {
|
2017-06-11 05:28:22 -05:00
|
|
|
if (!store || !store.state) {
|
2017-06-16 07:32:15 -05:00
|
|
|
return
|
2017-06-11 05:28:22 -05:00
|
|
|
}
|
2017-06-16 07:32:15 -05:00
|
|
|
console.log('HMR store', JSON.stringify(store, null, 2))
|
2017-06-11 05:28:22 -05:00
|
|
|
/**
|
|
|
|
* Set state
|
|
|
|
*/
|
2017-06-16 07:32:15 -05:00
|
|
|
this.appState._state = store.state
|
2017-06-11 05:28:22 -05:00
|
|
|
/**
|
|
|
|
* Set input values
|
|
|
|
*/
|
|
|
|
if ('restoreInputValues' in store) {
|
2017-06-16 07:32:15 -05:00
|
|
|
let restoreInputValues = store.restoreInputValues
|
|
|
|
setTimeout(restoreInputValues)
|
2017-06-11 05:28:22 -05:00
|
|
|
}
|
|
|
|
|
2017-06-16 07:32:15 -05:00
|
|
|
this.appRef.tick()
|
|
|
|
delete store.state
|
|
|
|
delete store.restoreInputValues
|
2016-09-06 15:40:57 -05:00
|
|
|
}
|
2017-06-11 05:28:22 -05:00
|
|
|
|
2017-06-16 07:32:15 -05:00
|
|
|
public hmrOnDestroy (store: StoreType) {
|
|
|
|
const cmpLocation = this.appRef.components.map((cmp) => cmp.location.nativeElement)
|
2017-06-11 05:28:22 -05:00
|
|
|
/**
|
|
|
|
* Save state
|
|
|
|
*/
|
2017-06-16 07:32:15 -05:00
|
|
|
const state = this.appState._state
|
|
|
|
store.state = state
|
2017-06-11 05:28:22 -05:00
|
|
|
/**
|
|
|
|
* Recreate root elements
|
|
|
|
*/
|
2017-06-16 07:32:15 -05:00
|
|
|
store.disposeOldHosts = createNewHosts(cmpLocation)
|
2017-06-11 05:28:22 -05:00
|
|
|
/**
|
|
|
|
* Save input values
|
|
|
|
*/
|
2017-06-16 07:32:15 -05:00
|
|
|
store.restoreInputValues = createInputTransfer()
|
2017-06-11 05:28:22 -05:00
|
|
|
/**
|
|
|
|
* Remove styles
|
|
|
|
*/
|
2017-06-16 07:32:15 -05:00
|
|
|
removeNgStyles()
|
2016-09-06 15:40:57 -05:00
|
|
|
}
|
2017-06-11 05:28:22 -05:00
|
|
|
|
2017-06-16 07:32:15 -05:00
|
|
|
public hmrAfterDestroy (store: StoreType) {
|
2017-06-11 05:28:22 -05:00
|
|
|
/**
|
|
|
|
* Display new elements
|
|
|
|
*/
|
2017-10-31 10:37:37 -05:00
|
|
|
store.disposeOldHosts()
|
2017-06-16 07:32:15 -05:00
|
|
|
delete store.disposeOldHosts
|
2016-09-06 15:40:57 -05:00
|
|
|
}
|
|
|
|
}
|