X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=client%2Fsrc%2Fapp%2F%2Bmy-account%2Fmy-account.component.ts;h=05dcf522d4c13bdf6b8ba1be1fe161c6f0cf7492;hb=3b20bdd6dc7402b0723e038c57f0606131e20e54;hp=bad60a8fb750e6b9bd4598accb4ae6d9faad1b11;hpb=75f1d36218e2f2011845fcbf2e417c4524230668;p=github%2FChocobozzz%2FPeerTube.git diff --git a/client/src/app/+my-account/my-account.component.ts b/client/src/app/+my-account/my-account.component.ts index bad60a8fb..05dcf522d 100644 --- a/client/src/app/+my-account/my-account.component.ts +++ b/client/src/app/+my-account/my-account.component.ts @@ -1,58 +1,107 @@ -import { Component, OnDestroy, OnInit } from '@angular/core' +import { Component, OnInit } from '@angular/core' import { ServerService } from '@app/core' -import { NavigationStart, Router } from '@angular/router' -import { filter } from 'rxjs/operators' import { I18n } from '@ngx-translate/i18n-polyfill' -import { Subscription } from 'rxjs' +import { TopMenuDropdownParam } from '@app/shared/menu/top-menu-dropdown.component' +import { ServerConfig } from '@shared/models' @Component({ selector: 'my-my-account', templateUrl: './my-account.component.html', styleUrls: [ './my-account.component.scss' ] }) -export class MyAccountComponent implements OnInit, OnDestroy { +export class MyAccountComponent implements OnInit { + menuEntries: TopMenuDropdownParam[] = [] - libraryLabel = '' - - private routeSub: Subscription + private serverConfig: ServerConfig constructor ( private serverService: ServerService, - private router: Router, private i18n: I18n - ) {} + ) { } - ngOnInit () { - this.updateLibraryLabel(this.router.url) + ngOnInit (): void { + this.serverConfig = this.serverService.getTmpConfig() + this.serverService.getConfig() + .subscribe(config => this.serverConfig = config) - this.routeSub = this.router.events - .pipe(filter(event => event instanceof NavigationStart)) - .subscribe((event: NavigationStart) => this.updateLibraryLabel(event.url)) - } + const libraryEntries: TopMenuDropdownParam = { + label: this.i18n('My library'), + children: [ + { + label: this.i18n('My channels'), + routerLink: '/my-account/video-channels', + iconName: 'folder' + }, + { + label: this.i18n('My videos'), + routerLink: '/my-account/videos', + iconName: 'videos' + }, + { + label: this.i18n('My playlists'), + routerLink: '/my-account/video-playlists', + iconName: 'playlists' + }, + { + label: this.i18n('My subscriptions'), + routerLink: '/my-account/subscriptions', + iconName: 'subscriptions' + }, + { + label: this.i18n('My history'), + routerLink: '/my-account/history/videos', + iconName: 'history' + } + ] + } + + if (this.isVideoImportEnabled()) { + libraryEntries.children.push({ + label: 'My imports', + routerLink: '/my-account/video-imports', + iconName: 'cloud-download' + }) + } - ngOnDestroy () { - if (this.routeSub) this.routeSub.unsubscribe() + const miscEntries: TopMenuDropdownParam = { + label: this.i18n('Misc'), + children: [ + { + label: this.i18n('Muted accounts'), + routerLink: '/my-account/blocklist/accounts', + iconName: 'user' + }, + { + label: this.i18n('Muted instances'), + routerLink: '/my-account/blocklist/servers', + iconName: 'server' + }, + { + label: this.i18n('Ownership changes'), + routerLink: '/my-account/ownership', + iconName: 'im-with-her' + } + ] + } + + this.menuEntries = [ + { + label: this.i18n('My settings'), + routerLink: '/my-account/settings' + }, + { + label: this.i18n('My notifications'), + routerLink: '/my-account/notifications' + }, + libraryEntries, + miscEntries + ] } isVideoImportEnabled () { - const importConfig = this.serverService.getConfig().import.videos + const importConfig = this.serverConfig.import.videos return importConfig.http.enabled || importConfig.torrent.enabled } - private updateLibraryLabel (url: string) { - const [ path ] = url.split('?') - - if (path.startsWith('/my-account/video-channels')) { - this.libraryLabel = this.i18n('Channels') - } else if (path.startsWith('/my-account/videos')) { - this.libraryLabel = this.i18n('Videos') - } else if (path.startsWith('/my-account/subscriptions')) { - this.libraryLabel = this.i18n('Subscriptions') - } else if (path.startsWith('/my-account/video-imports')) { - this.libraryLabel = this.i18n('Video imports') - } else { - this.libraryLabel = '' - } - } }