]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - client/src/app/shared/video/video-details.model.ts
Begin video watch design
[github/Chocobozzz/PeerTube.git] / client / src / app / shared / video / video-details.model.ts
CommitLineData
b1fa3eba 1import { Account } from '../../../../../shared/models/accounts'
202f6b6c 2import { Video } from '../../shared/video/video.model'
954605a8 3import { AuthUser } from '../../core'
404b54e1
C
4import {
5 VideoDetails as VideoDetailsServerModel,
6 VideoFile,
7 VideoChannel,
954605a8 8 VideoResolution,
fd45e8f4
C
9 UserRight,
10 VideoPrivacy
404b54e1
C
11} from '../../../../../shared'
12
13export class VideoDetails extends Video implements VideoDetailsServerModel {
b1fa3eba 14 accountName: string
404b54e1
C
15 by: string
16 createdAt: Date
17 updatedAt: Date
18 categoryLabel: string
19 category: number
20 licenceLabel: string
21 licence: number
22 languageLabel: string
23 language: number
24 description: string
25 duration: number
26 durationLabel: string
27 id: number
28 uuid: string
29 isLocal: boolean
30 name: string
60862425 31 serverHost: string
404b54e1
C
32 tags: string[]
33 thumbnailPath: string
34 thumbnailUrl: string
35 previewPath: string
36 previewUrl: string
37 embedPath: string
38 embedUrl: string
39 views: number
40 likes: number
41 dislikes: number
42 nsfw: boolean
2de96f4d 43 descriptionPath: string
404b54e1
C
44 files: VideoFile[]
45 channel: VideoChannel
fd45e8f4
C
46 privacy: VideoPrivacy
47 privacyLabel: string
b1fa3eba 48 account: Account
404b54e1
C
49
50 constructor (hash: VideoDetailsServerModel) {
51 super(hash)
52
fd45e8f4
C
53 this.privacy = hash.privacy
54 this.privacyLabel = hash.privacyLabel
2de96f4d 55 this.descriptionPath = hash.descriptionPath
404b54e1
C
56 this.files = hash.files
57 this.channel = hash.channel
b1fa3eba 58 this.account = hash.account
404b54e1
C
59 }
60
61 getAppropriateMagnetUri (actualDownloadSpeed = 0) {
62 if (this.files === undefined || this.files.length === 0) return ''
63 if (this.files.length === 1) return this.files[0].magnetUri
64
65 // Find first video that is good for our download speed (remember they are sorted)
66 let betterResolutionFile = this.files.find(f => actualDownloadSpeed > (f.size / this.duration))
67
68 // If the download speed is too bad, return the lowest resolution we have
69 if (betterResolutionFile === undefined) {
70 betterResolutionFile = this.files.find(f => f.resolution === VideoResolution.H_240P)
71 }
72
73 return betterResolutionFile.magnetUri
74 }
75
954605a8 76 isRemovableBy (user: AuthUser) {
b1fa3eba 77 return user && this.isLocal === true && (this.accountName === user.username || user.hasRight(UserRight.REMOVE_ANY_VIDEO))
404b54e1
C
78 }
79
954605a8
C
80 isBlackistableBy (user: AuthUser) {
81 return user && user.hasRight(UserRight.MANAGE_VIDEO_BLACKLIST) === true && this.isLocal === false
404b54e1
C
82 }
83
954605a8 84 isUpdatableBy (user: AuthUser) {
b1fa3eba 85 return user && this.isLocal === true && user.username === this.accountName
404b54e1
C
86 }
87}