X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=client%2Fsrc%2Fapp%2Fshared%2Fvideo%2Fvideo.model.ts;h=b92c96450b1b4a60d99c8ca2bb97932e6f6c3ed7;hb=5c6d985faeef1d6793d3f44ca6374f1a9b722806;hp=ec0afcccb5360b1a036101525b25853236a18e7b;hpb=191764f30b0a812bf3a9dbdc7daf1d5afe25e12a;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 ec0afcccb..b92c96450 100644 --- a/client/src/app/shared/video/video.model.ts +++ b/client/src/app/shared/video/video.model.ts @@ -2,16 +2,18 @@ import { User } from '../' 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 { getAbsoluteAPIUrl } from '../misc/utils' -import { ServerConfig } from '../../../../../shared/models' +import { durationToString, getAbsoluteAPIUrl } from '../misc/utils' +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 + byVideoChannel: string + byAccount: string + accountAvatarUrl: string videoChannelAvatarUrl: string + createdAt: Date updatedAt: Date publishedAt: Date @@ -64,20 +66,12 @@ export class Video implements VideoServerModel { avatar: Avatar } - static buildClientUrl (videoUUID: string) { - return '/videos/watch/' + videoUUID + userHistory?: { + currentTime: number } - private static createDurationString (duration: number) { - const hours = Math.floor(duration / 3600) - 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() + static buildClientUrl (videoUUID: string) { + return '/videos/watch/' + videoUUID } constructor (hash: VideoServerModel, translations = {}) { @@ -93,7 +87,7 @@ export class Video implements VideoServerModel { 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 @@ -111,7 +105,8 @@ export class Video implements VideoServerModel { this.account = hash.account this.channel = hash.channel - this.by = Actor.CREATE_BY_STRING(hash.account.name, hash.account.host) + 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) @@ -125,6 +120,8 @@ export class Video implements VideoServerModel { this.blacklisted = hash.blacklisted this.blacklistedReason = hash.blacklistedReason + + this.userHistory = hash.userHistory } isVideoNSFWForUser (user: User, serverConfig: ServerConfig) {