X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=client%2Fsrc%2Fapp%2F%2Bmy-account%2Fmy-account.component.ts;h=eaf8a72e92d0fe2b19b8d14b495055a9d90f28ff;hb=0f7407d926cf7774f8f730dba08327569c11680c;hp=85b2795c5675caa2274c802673d49884bd25de85;hpb=c41c0e28ed444fdb427f9803d2f123ba6f535fb9;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 85b2795c5..eaf8a72e9 100644 --- a/client/src/app/+my-account/my-account.component.ts +++ b/client/src/app/+my-account/my-account.component.ts @@ -1,8 +1,6 @@ import { Component, OnInit } from '@angular/core' -import { ServerService } from '@app/core' -import { I18n } from '@ngx-translate/i18n-polyfill' -import { ServerConfig } from '@shared/models' -import { TopMenuDropdownParam } from './top-menu-dropdown.component' +import { AuthUser, ScreenService } from '@app/core' +import { TopMenuDropdownParam } from '../shared/shared-main/misc/top-menu-dropdown.component' @Component({ selector: 'my-my-account', @@ -11,97 +9,59 @@ import { TopMenuDropdownParam } from './top-menu-dropdown.component' }) export class MyAccountComponent implements OnInit { menuEntries: TopMenuDropdownParam[] = [] - - private serverConfig: ServerConfig + user: AuthUser constructor ( - private serverService: ServerService, - private i18n: I18n - ) { } - - ngOnInit (): void { - this.serverConfig = this.serverService.getTmpConfig() - this.serverService.getConfig() - .subscribe(config => this.serverConfig = config) + private screenService: ScreenService + ) { } - const libraryEntries: TopMenuDropdownParam = { - label: this.i18n('My library'), - children: [ - { - label: this.i18n('My channels'), - routerLink: '/my-account/video-channels', - iconName: 'channel' - }, - { - 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: 'inbox-full' - }, - { - label: this.i18n('My history'), - routerLink: '/my-account/history/videos', - iconName: 'history' - } - ] - } + get isBroadcastMessageDisplayed () { + return this.screenService.isBroadcastMessageDisplayed + } - if (this.isVideoImportEnabled()) { - libraryEntries.children.push({ - label: 'My imports', - routerLink: '/my-account/video-imports', - iconName: 'cloud-download' - }) - } + ngOnInit (): void { + this.buildMenu() + } - const miscEntries: TopMenuDropdownParam = { - label: this.i18n('Misc'), + private buildMenu () { + const moderationEntries: TopMenuDropdownParam = { + label: $localize`Moderation`, children: [ { - label: this.i18n('Muted accounts'), + label: $localize`Muted accounts`, routerLink: '/my-account/blocklist/accounts', - iconName: 'user' + iconName: 'user-x' }, { - label: this.i18n('Muted servers'), + label: $localize`Muted servers`, routerLink: '/my-account/blocklist/servers', - iconName: 'server' + iconName: 'peertube-x' }, { - label: this.i18n('Ownership changes'), - routerLink: '/my-account/ownership', - iconName: 'ownership-change' + label: $localize`Abuse reports`, + routerLink: '/my-account/abuses', + iconName: 'flag' } ] } this.menuEntries = [ { - label: this.i18n('My settings'), + label: $localize`Settings`, routerLink: '/my-account/settings' }, + { - label: this.i18n('My notifications'), + label: $localize`Notifications`, routerLink: '/my-account/notifications' }, - libraryEntries, - miscEntries - ] - } - isVideoImportEnabled () { - const importConfig = this.serverConfig.import.videos + { + label: $localize`Applications`, + routerLink: '/my-account/applications' + }, - return importConfig.http.enabled || importConfig.torrent.enabled + moderationEntries + ] } - }