]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - client/src/app/shared/shared-abuse-list/abuse-details.component.ts
Move to sass module
[github/Chocobozzz/PeerTube.git] / client / src / app / shared / shared-abuse-list / abuse-details.component.ts
CommitLineData
25a42e29 1import { Component, Input } from '@angular/core'
94148c90 2import { durationToString } from '@app/helpers'
d95d1559 3import { AbusePredefinedReasonsString } from '@shared/models'
94148c90 4import { ProcessedAbuse } from './processed-abuse.model'
801d9571
RK
5
6@Component({
d95d1559
C
7 selector: 'my-abuse-details',
8 templateUrl: './abuse-details.component.html',
94148c90 9 styleUrls: [ '../shared-moderation/moderation.scss', './abuse-details.component.scss' ]
801d9571 10})
d95d1559
C
11export class AbuseDetailsComponent {
12 @Input() abuse: ProcessedAbuse
94148c90 13 @Input() isAdminView: boolean
801d9571 14
d95d1559 15 private predefinedReasonsTranslations: { [key in AbusePredefinedReasonsString]: string }
1ebddadd 16
66357162 17 constructor () {
1ebddadd 18 this.predefinedReasonsTranslations = {
66357162
C
19 violentOrRepulsive: $localize`Violent or Repulsive`,
20 hatefulOrAbusive: $localize`Hateful or Abusive`,
21 spamOrMisleading: $localize`Spam or Misleading`,
22 privacy: $localize`Privacy`,
23 rights: $localize`Copyright`,
24 serverRules: $localize`Server rules`,
25 thumbnails: $localize`Thumbnails`,
26 captions: $localize`Captions`
1ebddadd
RK
27 }
28 }
29
30 get startAt () {
8ca56654 31 return durationToString(this.abuse.video.startAt)
1ebddadd
RK
32 }
33
34 get endAt () {
8ca56654 35 return durationToString(this.abuse.video.endAt)
1ebddadd
RK
36 }
37
38 getPredefinedReasons () {
d95d1559 39 if (!this.abuse.predefinedReasons) return []
8ca56654 40
d95d1559 41 return this.abuse.predefinedReasons.map(r => ({
1ebddadd
RK
42 id: r,
43 label: this.predefinedReasonsTranslations[r]
44 }))
45 }
801d9571 46}