]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame_incremental - client/src/app/app.module.ts
Fix privacy descriptions
[github/Chocobozzz/PeerTube.git] / client / src / app / app.module.ts
... / ...
CommitLineData
1import 'focus-visible'
2import { tap } from 'rxjs/operators'
3import { environment } from 'src/environments/environment'
4import { APP_BASE_HREF, registerLocaleData } from '@angular/common'
5import { APP_INITIALIZER, NgModule } from '@angular/core'
6import { BrowserModule } from '@angular/platform-browser'
7import { ServiceWorkerModule } from '@angular/service-worker'
8import localeOc from '@app/helpers/locales/oc'
9import { AppRoutingModule } from './app-routing.module'
10import { AppComponent } from './app.component'
11import { CoreModule, PluginService, ServerService } from './core'
12import { EmptyComponent } from './empty.component'
13import { HeaderComponent, SearchTypeaheadComponent, SuggestionComponent } from './header'
14import { HighlightPipe } from './header/highlight.pipe'
15import { LanguageChooserComponent, MenuComponent, NotificationComponent } from './menu'
16import { ConfirmComponent } from './modal/confirm.component'
17import { CustomModalComponent } from './modal/custom-modal.component'
18import { InstanceConfigWarningModalComponent } from './modal/instance-config-warning-modal.component'
19import { QuickSettingsModalComponent } from './modal/quick-settings-modal.component'
20import { WelcomeModalComponent } from './modal/welcome-modal.component'
21import { SharedActorImageModule } from './shared/shared-actor-image/shared-actor-image.module'
22import { SharedFormModule } from './shared/shared-forms'
23import { SharedGlobalIconModule } from './shared/shared-icons'
24import { SharedInstanceModule } from './shared/shared-instance'
25import { SharedMainModule } from './shared/shared-main'
26import { SharedUserInterfaceSettingsModule } from './shared/shared-user-settings'
27
28registerLocaleData(localeOc, 'oc')
29
30export 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})
90export class AppModule {}