X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=client%2Fsrc%2Fapp%2Fshared%2Fvideo%2Fvideo.model.ts;h=80794faa60d9f06a23b0129b961d1c39a21a77e4;hb=d1a63fc7ac58a1db00d8ca4f43aadba02eb9b084;hp=d86ef8f9265127364901321f39e605551b3c02ca;hpb=fada8d75550dc7365f7e18ee1569b9406251d660;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 d86ef8f92..80794faa6 100644 --- a/client/src/app/shared/video/video.model.ts +++ b/client/src/app/shared/video/video.model.ts @@ -1,18 +1,26 @@ -import { Video as VideoServerModel } from '../../../../../shared' import { User } from '../' -import { Account } from '../../../../../shared/models/accounts' +import { Video as VideoServerModel, VideoPrivacy, VideoState } from '../../../../../shared' +import { Avatar } from '../../../../../shared/models/avatars/avatar.model' +import { VideoConstant } from '../../../../../shared/models/videos/video-constant.model' +import { durationToString, getAbsoluteAPIUrl } from '../misc/utils' +import { peertubeTranslate, ServerConfig } from '../../../../../shared/models' +import { Actor } from '@app/shared/actor/actor.model' +import { VideoScheduleUpdate } from '../../../../../shared/models/videos/video-schedule-update.model' export class Video implements VideoServerModel { - accountName: string - by: string + byVideoChannel: string + byAccount: string + + accountAvatarUrl: string + videoChannelAvatarUrl: string + createdAt: Date updatedAt: Date - categoryLabel: string - category: number - licenceLabel: string - licence: number - languageLabel: string - language: number + publishedAt: Date + category: VideoConstant + licence: VideoConstant + language: VideoConstant + privacy: VideoConstant description: string duration: number durationLabel: string @@ -21,7 +29,6 @@ export class Video implements VideoServerModel { isLocal: boolean name: string serverHost: string - tags: string[] thumbnailPath: string thumbnailUrl: string previewPath: string @@ -32,45 +39,55 @@ export class Video implements VideoServerModel { likes: number dislikes: number nsfw: boolean - account: Account - private static createByString (account: string, serverHost: string) { - return account + '@' + serverHost + waitTranscoding?: boolean + state?: VideoConstant + scheduledUpdate?: VideoScheduleUpdate + blacklisted?: boolean + blacklistedReason?: string + + account: { + id: number + uuid: string + name: string + displayName: string + url: string + host: string + avatar: Avatar } - private static createDurationString (duration: number) { - const minutes = Math.floor(duration / 60) - const seconds = duration % 60 - const minutesPadding = minutes >= 10 ? '' : '0' - const secondsPadding = seconds >= 10 ? '' : '0' + channel: { + id: number + uuid: string + name: string + displayName: string + url: string + host: string + avatar: Avatar + } - return minutesPadding + minutes.toString() + ':' + secondsPadding + seconds.toString() + static buildClientUrl (videoUUID: string) { + return '/videos/watch/' + videoUUID } - constructor (hash: VideoServerModel) { - let absoluteAPIUrl = API_URL - if (!absoluteAPIUrl) { - // The API is on the same domain - absoluteAPIUrl = window.location.origin - } + constructor (hash: VideoServerModel, translations = {}) { + const absoluteAPIUrl = getAbsoluteAPIUrl() - this.accountName = hash.accountName this.createdAt = new Date(hash.createdAt.toString()) - this.categoryLabel = hash.categoryLabel + this.publishedAt = new Date(hash.publishedAt.toString()) this.category = hash.category - this.licenceLabel = hash.licenceLabel this.licence = hash.licence - this.languageLabel = hash.languageLabel 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) + this.durationLabel = durationToString(hash.duration) this.id = hash.id this.uuid = hash.uuid this.isLocal = hash.isLocal this.name = hash.name - this.serverHost = hash.serverHost - this.tags = hash.tags this.thumbnailPath = hash.thumbnailPath this.thumbnailUrl = absoluteAPIUrl + hash.thumbnailPath this.previewPath = hash.previewPath @@ -81,12 +98,34 @@ export class Video implements VideoServerModel { this.likes = hash.likes this.dislikes = hash.dislikes this.nsfw = hash.nsfw + this.account = hash.account + this.channel = hash.channel + + this.byAccount = Actor.CREATE_BY_STRING(hash.account.name, hash.account.host) + this.byVideoChannel = Actor.CREATE_BY_STRING(hash.channel.name, hash.channel.host) + this.accountAvatarUrl = Actor.GET_ACTOR_AVATAR_URL(this.account) + this.videoChannelAvatarUrl = Actor.GET_ACTOR_AVATAR_URL(this.channel) - this.by = Video.createByString(hash.accountName, hash.serverHost) + 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) { - // If the video is NSFW and the user is not logged in, or the user does not want to display NSFW videos... - return (this.nsfw && (!user || user.displayNSFW === false)) + isVideoNSFWForUser (user: User, serverConfig: ServerConfig) { + // Video is not NSFW, skip + if (this.nsfw === false) return false + + // Return user setting if logged in + if (user) return user.nsfwPolicy !== 'display' + + // Return default instance config + return serverConfig.instance.defaultNSFWPolicy !== 'display' } }