X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=client%2Fsrc%2Fapp%2Fshared%2Fvideo%2Fvideo.model.ts;h=df825330173ed45e92c6fbb998d16ca4b5bf0283;hb=99492dbc0d87ef54d0dab7d8d44f8d0de5722bdd;hp=d37dc2c3ef969d431f962278b7e0d2045ca83109;hpb=7ce44a74a3b052190cfacd4bd5ee6b92cfc620ac;p=github%2FChocobozzz%2FPeerTube.git diff --git a/client/src/app/shared/video/video.model.ts b/client/src/app/shared/video/video.model.ts index d37dc2c3e..df8253301 100644 --- a/client/src/app/shared/video/video.model.ts +++ b/client/src/app/shared/video/video.model.ts @@ -1,15 +1,16 @@ import { User } from '../' -import { Video as VideoServerModel, VideoPrivacy } from '../../../../../shared' +import { Video as VideoServerModel, VideoPrivacy, VideoState } from '../../../../../shared' import { Avatar } from '../../../../../shared/models/avatars/avatar.model' -import { VideoConstant } from '../../../../../shared/models/videos/video.model' +import { VideoConstant } from '../../../../../shared/models/videos/video-constant.model' import { getAbsoluteAPIUrl } from '../misc/utils' -import { ServerConfig } from '../../../../../shared/models' +import { peertubeTranslate, ServerConfig } from '../../../../../shared/models' import { Actor } from '@app/shared/actor/actor.model' -import { peertubeTranslate } from '@app/shared/i18n/i18n-utils' +import { VideoScheduleUpdate } from '../../../../../shared/models/videos/video-schedule-update.model' export class Video implements VideoServerModel { by: string accountAvatarUrl: string + videoChannelAvatarUrl: string createdAt: Date updatedAt: Date publishedAt: Date @@ -36,6 +37,12 @@ export class Video implements VideoServerModel { dislikes: number nsfw: boolean + waitTranscoding?: boolean + state?: VideoConstant + scheduledUpdate?: VideoScheduleUpdate + blacklisted?: boolean + blacklistedReason?: string + account: { id: number uuid: string @@ -56,17 +63,20 @@ export class Video implements VideoServerModel { avatar: Avatar } + static buildClientUrl (videoUUID: string) { + return '/videos/watch/' + videoUUID + } + private static createDurationString (duration: number) { const hours = Math.floor(duration / 3600) - const minutes = Math.floor(duration % 3600 / 60) + const minutes = Math.floor((duration % 3600) / 60) const seconds = duration % 60 const minutesPadding = minutes >= 10 ? '' : '0' const secondsPadding = seconds >= 10 ? '' : '0' const displayedHours = hours > 0 ? hours.toString() + ':' : '' - return displayedHours + minutesPadding + - minutes.toString() + ':' + secondsPadding + seconds.toString() + return displayedHours + minutesPadding + minutes.toString() + ':' + secondsPadding + seconds.toString() } constructor (hash: VideoServerModel, translations = {}) { @@ -78,6 +88,8 @@ export class Video implements VideoServerModel { this.licence = hash.licence this.language = hash.language this.privacy = hash.privacy + this.waitTranscoding = hash.waitTranscoding + this.state = hash.state this.description = hash.description this.duration = hash.duration this.durationLabel = Video.createDurationString(hash.duration) @@ -96,14 +108,22 @@ export class Video implements VideoServerModel { this.dislikes = hash.dislikes this.nsfw = hash.nsfw this.account = hash.account + this.channel = hash.channel this.by = Actor.CREATE_BY_STRING(hash.account.name, hash.account.host) this.accountAvatarUrl = Actor.GET_ACTOR_AVATAR_URL(this.account) + this.videoChannelAvatarUrl = Actor.GET_ACTOR_AVATAR_URL(this.channel) this.category.label = peertubeTranslate(this.category.label, translations) this.licence.label = peertubeTranslate(this.licence.label, translations) this.language.label = peertubeTranslate(this.language.label, translations) this.privacy.label = peertubeTranslate(this.privacy.label, translations) + + this.scheduledUpdate = hash.scheduledUpdate + if (this.state) this.state.label = peertubeTranslate(this.state.label, translations) + + this.blacklisted = hash.blacklisted + this.blacklistedReason = hash.blacklistedReason } isVideoNSFWForUser (user: User, serverConfig: ServerConfig) {