]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame_incremental - client/src/app/videos/+video-watch/comment/video-comment.service.ts
Strict templates enabled
[github/Chocobozzz/PeerTube.git] / client / src / app / videos / +video-watch / comment / video-comment.service.ts
... / ...
CommitLineData
1import { catchError, map } from 'rxjs/operators'
2import { HttpClient, HttpParams } from '@angular/common/http'
3import { Injectable } from '@angular/core'
4import { objectLineFeedToHtml } from '@app/shared/misc/utils'
5import { Observable } from 'rxjs'
6import { FeedFormat, ResultList } from '../../../../../../shared/models'
7import {
8 VideoComment as VideoCommentServerModel,
9 VideoCommentCreate,
10 VideoCommentThreadTree as VideoCommentThreadTreeServerModel
11} from '../../../../../../shared/models/videos/video-comment.model'
12import { environment } from '../../../../environments/environment'
13import { RestExtractor, RestService } from '../../../shared/rest'
14import { ComponentPaginationLight } from '../../../shared/rest/component-pagination.model'
15import { CommentSortField } from '../../../shared/video/sort-field.type'
16import { VideoComment } from './video-comment.model'
17import { VideoCommentThreadTree } from '@app/videos/+video-watch/comment/video-comment-thread-tree.model'
18
19@Injectable()
20export class VideoCommentService {
21 private static BASE_VIDEO_URL = environment.apiUrl + '/api/v1/videos/'
22 private static BASE_FEEDS_URL = environment.apiUrl + '/feeds/video-comments.'
23
24 constructor (
25 private authHttp: HttpClient,
26 private restExtractor: RestExtractor,
27 private restService: RestService
28 ) {}
29
30 addCommentThread (videoId: number | string, comment: VideoCommentCreate) {
31 const url = VideoCommentService.BASE_VIDEO_URL + videoId + '/comment-threads'
32 const normalizedComment = objectLineFeedToHtml(comment, 'text')
33
34 return this.authHttp.post<{ comment: VideoCommentServerModel }>(url, normalizedComment)
35 .pipe(
36 map(data => this.extractVideoComment(data.comment)),
37 catchError(err => this.restExtractor.handleError(err))
38 )
39 }
40
41 addCommentReply (videoId: number | string, inReplyToCommentId: number, comment: VideoCommentCreate) {
42 const url = VideoCommentService.BASE_VIDEO_URL + videoId + '/comments/' + inReplyToCommentId
43 const normalizedComment = objectLineFeedToHtml(comment, 'text')
44
45 return this.authHttp.post<{ comment: VideoCommentServerModel }>(url, normalizedComment)
46 .pipe(
47 map(data => this.extractVideoComment(data.comment)),
48 catchError(err => this.restExtractor.handleError(err))
49 )
50 }
51
52 getVideoCommentThreads (parameters: {
53 videoId: number | string,
54 componentPagination: ComponentPaginationLight,
55 sort: CommentSortField
56 }): Observable<ResultList<VideoComment>> {
57 const { videoId, componentPagination, sort } = parameters
58
59 const pagination = this.restService.componentPaginationToRestPagination(componentPagination)
60
61 let params = new HttpParams()
62 params = this.restService.addRestGetParams(params, pagination, sort)
63
64 const url = VideoCommentService.BASE_VIDEO_URL + videoId + '/comment-threads'
65 return this.authHttp.get<ResultList<VideoComment>>(url, { params })
66 .pipe(
67 map(result => this.extractVideoComments(result)),
68 catchError(err => this.restExtractor.handleError(err))
69 )
70 }
71
72 getVideoThreadComments (parameters: {
73 videoId: number | string,
74 threadId: number
75 }): Observable<VideoCommentThreadTree> {
76 const { videoId, threadId } = parameters
77 const url = `${VideoCommentService.BASE_VIDEO_URL + videoId}/comment-threads/${threadId}`
78
79 return this.authHttp
80 .get<VideoCommentThreadTreeServerModel>(url)
81 .pipe(
82 map(tree => this.extractVideoCommentTree(tree)),
83 catchError(err => this.restExtractor.handleError(err))
84 )
85 }
86
87 deleteVideoComment (videoId: number | string, commentId: number) {
88 const url = `${VideoCommentService.BASE_VIDEO_URL + videoId}/comments/${commentId}`
89
90 return this.authHttp
91 .delete(url)
92 .pipe(
93 map(this.restExtractor.extractDataBool),
94 catchError(err => this.restExtractor.handleError(err))
95 )
96 }
97
98 getVideoCommentsFeeds (videoUUID?: string) {
99 const feeds = [
100 {
101 format: FeedFormat.RSS,
102 label: 'rss 2.0',
103 url: VideoCommentService.BASE_FEEDS_URL + FeedFormat.RSS.toLowerCase()
104 },
105 {
106 format: FeedFormat.ATOM,
107 label: 'atom 1.0',
108 url: VideoCommentService.BASE_FEEDS_URL + FeedFormat.ATOM.toLowerCase()
109 },
110 {
111 format: FeedFormat.JSON,
112 label: 'json 1.0',
113 url: VideoCommentService.BASE_FEEDS_URL + FeedFormat.JSON.toLowerCase()
114 }
115 ]
116
117 if (videoUUID !== undefined) {
118 for (const feed of feeds) {
119 feed.url += '?videoId=' + videoUUID
120 }
121 }
122
123 return feeds
124 }
125
126 private extractVideoComment (videoComment: VideoCommentServerModel) {
127 return new VideoComment(videoComment)
128 }
129
130 private extractVideoComments (result: ResultList<VideoCommentServerModel>) {
131 const videoCommentsJson = result.data
132 const totalComments = result.total
133 const comments: VideoComment[] = []
134
135 for (const videoCommentJson of videoCommentsJson) {
136 comments.push(new VideoComment(videoCommentJson))
137 }
138
139 return { data: comments, total: totalComments }
140 }
141
142 private extractVideoCommentTree (tree: VideoCommentThreadTreeServerModel) {
143 if (!tree) return tree as VideoCommentThreadTree
144
145 tree.comment = new VideoComment(tree.comment)
146 tree.children.forEach(c => this.extractVideoCommentTree(c))
147
148 return tree as VideoCommentThreadTree
149 }
150}