]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - client/src/app/app.module.ts
use focus-visible polyfill to improve keyboard navigation
[github/Chocobozzz/PeerTube.git] / client / src / app / app.module.ts
CommitLineData
989e526a 1import { LOCALE_ID, NgModule, TRANSLATIONS, TRANSLATIONS_FORMAT } from '@angular/core'
df98563e 2import { BrowserModule } from '@angular/platform-browser'
63ac2857 3import { ServerService } from '@app/core'
ecb4e35f 4import { ResetPasswordModule } from '@app/reset-password'
ab32b0fc 5
ecb4e35f 6import { MetaLoader, MetaModule, MetaStaticLoader, PageTitlePositioning } from '@ngx-meta/core'
230de99e 7import { ClipboardModule } from 'ngx-clipboard'
ee1fc23a 8import { HotkeyModule, IHotkeyOptions } from 'angular2-hotkeys'
e78980eb 9import 'focus-visible'
ecb4e35f 10
df98563e
C
11import { AppRoutingModule } from './app-routing.module'
12import { AppComponent } from './app.component'
df98563e 13import { CoreModule } from './core'
ecb4e35f 14import { HeaderComponent } from './header'
df98563e 15import { LoginModule } from './login'
ecb4e35f 16import { MenuComponent } from './menu'
df98563e 17import { SharedModule } from './shared'
ecb4e35f 18import { SignupModule } from './signup'
df98563e 19import { VideosModule } from './videos'
b7f1747d 20import { buildFileLocale, getCompleteLocale, isDefaultLocale } from '../../../shared/models/i18n'
74b7c6d4 21import { getDevLocale, isOnDevLocale } from '@app/shared/i18n/i18n-utils'
8afc19a6 22import { LanguageChooserComponent } from '@app/menu/language-chooser.component'
57c36b27 23import { SearchModule } from '@app/search'
693b1aba 24
63ac2857 25export function metaFactory (serverService: ServerService): MetaLoader {
758b996d
C
26 return new MetaStaticLoader({
27 pageTitlePositioning: PageTitlePositioning.PrependPageTitle,
28 pageTitleSeparator: ' - ',
63ac2857 29 get applicationName () { return serverService.getConfig().instance.name },
758b996d 30 defaults: {
63ac2857
C
31 get title () { return serverService.getConfig().instance.name },
32 get description () { return serverService.getConfig().instance.shortDescription }
758b996d 33 }
df98563e 34 })
758b996d 35}
b58c69a1 36
ab32b0fc
C
37@NgModule({
38 bootstrap: [ AppComponent ],
39 declarations: [
b33f657c
C
40 AppComponent,
41
42 MenuComponent,
8afc19a6 43 LanguageChooserComponent,
f3aaa9a9 44 HeaderComponent
ab32b0fc 45 ],
693b1aba 46 imports: [
ab32b0fc 47 BrowserModule,
230de99e
C
48 // FIXME: https://github.com/maxisam/ngx-clipboard/issues/133
49 ClipboardModule,
ee1fc23a
RK
50 HotkeyModule.forRoot({
51 cheatSheetCloseEsc: true
52 } as IHotkeyOptions),
23bcf666 53
693b1aba
C
54 CoreModule,
55 SharedModule,
56
693b1aba
C
57 CoreModule,
58 LoginModule,
ecb4e35f 59 ResetPasswordModule,
a184c71b 60 SignupModule,
57c36b27 61 SearchModule,
693b1aba 62 SharedModule,
55b33946
C
63 VideosModule,
64
65 MetaModule.forRoot({
66 provide: MetaLoader,
63ac2857
C
67 useFactory: (metaFactory),
68 deps: [ ServerService ]
a51bad1a
C
69 }),
70
a9614776 71 AppRoutingModule // Put it after all the module because it has the 404 route
ab32b0fc 72 ],
989e526a
C
73 providers: [
74 {
75 provide: TRANSLATIONS,
76 useFactory: (locale) => {
74b7c6d4
C
77 // On dev mode, test localization
78 if (isOnDevLocale()) {
c0ffdd09 79 locale = buildFileLocale(getDevLocale())
74b7c6d4 80 return require(`raw-loader!../locale/target/angular_${locale}.xml`)
e309822b
C
81 }
82
989e526a 83 // Default locale, nothing to translate
74b7c6d4
C
84 const completeLocale = getCompleteLocale(locale)
85 if (isDefaultLocale(completeLocale)) return ''
989e526a 86
74b7c6d4 87 const fileLocale = buildFileLocale(locale)
f07d6385 88 return require(`raw-loader!../locale/target/angular_${fileLocale}.xml`)
989e526a
C
89 },
90 deps: [ LOCALE_ID ]
91 },
92 { provide: TRANSLATIONS_FORMAT, useValue: 'xlf' }
93 ]
ab32b0fc 94})
63c4db6d 95export class AppModule {}