]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blob - client/src/app/app.module.ts
Merge branch 'master' into release/3.3.0
[github/Chocobozzz/PeerTube.git] / client / src / app / app.module.ts
1 import 'focus-visible'
2 import { tap } from 'rxjs/operators'
3 import { environment } from 'src/environments/environment'
4 import { APP_BASE_HREF, registerLocaleData } from '@angular/common'
5 import { APP_INITIALIZER, NgModule } from '@angular/core'
6 import { BrowserModule } from '@angular/platform-browser'
7 import { ServiceWorkerModule } from '@angular/service-worker'
8 import localeOc from '@app/helpers/locales/oc'
9 import { AppRoutingModule } from './app-routing.module'
10 import { AppComponent } from './app.component'
11 import { CoreModule, PluginService, ServerService } from './core'
12 import { EmptyComponent } from './empty.component'
13 import { HeaderComponent, SearchTypeaheadComponent, SuggestionComponent } from './header'
14 import { HighlightPipe } from './header/highlight.pipe'
15 import { LanguageChooserComponent, MenuComponent, NotificationComponent } from './menu'
16 import { ConfirmComponent } from './modal/confirm.component'
17 import { CustomModalComponent } from './modal/custom-modal.component'
18 import { InstanceConfigWarningModalComponent } from './modal/instance-config-warning-modal.component'
19 import { QuickSettingsModalComponent } from './modal/quick-settings-modal.component'
20 import { WelcomeModalComponent } from './modal/welcome-modal.component'
21 import { SharedActorImageModule } from './shared/shared-actor-image/shared-actor-image.module'
22 import { SharedFormModule } from './shared/shared-forms'
23 import { SharedGlobalIconModule } from './shared/shared-icons'
24 import { SharedInstanceModule } from './shared/shared-instance'
25 import { SharedMainModule } from './shared/shared-main'
26 import { SharedUserInterfaceSettingsModule } from './shared/shared-user-settings'
27
28 registerLocaleData(localeOc, 'oc')
29
30 export function loadConfigFactory (server: ServerService, pluginService: PluginService) {
31 return () => {
32 const result = server.loadHTMLConfig()
33
34 if (result) return result.pipe(tap(() => pluginService.initializePlugins()))
35
36 return pluginService.initializePlugins()
37 }
38 }
39
40 @NgModule({
41 bootstrap: [ AppComponent ],
42
43 declarations: [
44 AppComponent,
45 EmptyComponent,
46
47 MenuComponent,
48 LanguageChooserComponent,
49 QuickSettingsModalComponent,
50 NotificationComponent,
51 HeaderComponent,
52 SearchTypeaheadComponent,
53 SuggestionComponent,
54 HighlightPipe,
55
56 CustomModalComponent,
57 WelcomeModalComponent,
58 InstanceConfigWarningModalComponent,
59 ConfirmComponent
60 ],
61
62 imports: [
63 BrowserModule,
64 ServiceWorkerModule.register('ngsw-worker.js', { enabled: environment.production }),
65
66 CoreModule,
67 SharedMainModule,
68 SharedFormModule,
69 SharedUserInterfaceSettingsModule,
70 SharedGlobalIconModule,
71 SharedInstanceModule,
72 SharedActorImageModule,
73
74 AppRoutingModule // Put it after all the module because it has the 404 route
75 ],
76
77 providers: [
78 {
79 provide: APP_BASE_HREF,
80 useValue: '/'
81 },
82 {
83 provide: APP_INITIALIZER,
84 useFactory: loadConfigFactory,
85 deps: [ ServerService, PluginService ],
86 multi: true
87 }
88 ]
89 })
90 export class AppModule {}