import { AuthUser } from '@app/core'
import { User } from '@app/core/users/user.model'
-import { durationToString, getAbsoluteAPIUrl, getAbsoluteEmbedUrl } from '@app/helpers'
+import { durationToString, prepareIcu, getAbsoluteAPIUrl, getAbsoluteEmbedUrl } from '@app/helpers'
import { Actor } from '@app/shared/shared-main/account/actor.model'
import { buildVideoWatchPath } from '@shared/core-utils'
import { peertubeTranslate } from '@shared/core-utils/i18n'
VideoPrivacy,
VideoScheduleUpdate,
VideoState,
- VideoStreamingPlaylist
+ VideoStreamingPlaylist,
+ VideoStreamingPlaylistType
} from '@shared/models'
export class Video implements VideoServerModel {
+ private static readonly viewsICU = prepareIcu($localize`{views, plural, =0 {No view} =1 {1 view} other {{views} views}}`)
+ private static readonly viewersICU = prepareIcu($localize`{viewers, plural, =0 {No viewers} =1 {1 viewer} other {{viewers} viewers}}`)
+
byVideoChannel: string
byAccount: string
url: string
views: number
+ viewers: number
+
likes: number
dislikes: number
nsfw: boolean
displayName: string
url: string
host: string
- avatar?: ActorImage
+
+ // TODO: remove, deprecated in 4.2
+ avatar: ActorImage
+
+ avatars: ActorImage[]
}
channel: {
displayName: string
url: string
host: string
- avatar?: ActorImage
+
+ // TODO: remove, deprecated in 4.2
+ avatar: ActorImage
+
+ avatars: ActorImage[]
}
userHistory?: {
this.url = hash.url
this.views = hash.views
+ this.viewers = hash.viewers
this.likes = hash.likes
this.dislikes = hash.dislikes
return user && this.isLocal === true && (this.account.name === user.username || user.hasRight(UserRight.UPDATE_ANY_VIDEO))
}
+ isEditableBy (user: AuthUser, videoStudioEnabled: boolean) {
+ return videoStudioEnabled &&
+ this.state?.id === VideoState.PUBLISHED &&
+ this.isUpdatableBy(user)
+ }
+
+ canSeeStats (user: AuthUser) {
+ return user && this.isLocal === true && (this.account.name === user.username || user.hasRight(UserRight.SEE_ALL_VIDEOS))
+ }
+
+ canRemoveFiles (user: AuthUser) {
+ return this.isLocal &&
+ user && user.hasRight(UserRight.MANAGE_VIDEO_FILES) &&
+ this.state.id !== VideoState.TO_TRANSCODE &&
+ this.hasHLS() &&
+ this.hasWebTorrent()
+ }
+
+ canRunTranscoding (user: AuthUser) {
+ return this.isLocal &&
+ user && user.hasRight(UserRight.RUN_VIDEO_TRANSCODING) &&
+ this.state.id !== VideoState.TO_TRANSCODE
+ }
+
+ hasHLS () {
+ return this.streamingPlaylists?.some(p => p.type === VideoStreamingPlaylistType.HLS)
+ }
+
+ hasWebTorrent () {
+ return this.files && this.files.length !== 0
+ }
+
isLiveInfoAvailableBy (user: AuthUser) {
return this.isLive &&
user && this.isLocal === true && (this.account.name === user.username || user.hasRight(UserRight.GET_ANY_LIVE))
}
getExactNumberOfViews () {
- if (this.views < 1000) return ''
-
if (this.isLive) {
- return $localize`${this.views} viewers`
+ return Video.viewersICU({ viewers: this.viewers }, $localize`${this.viewers} viewer(s)`)
}
- return $localize`${this.views} views`
+ return Video.viewsICU({ views: this.views }, $localize`{${this.views} view(s)}`)
}
}