-import { Observable } from 'rxjs'
+import { Observable, of } from 'rxjs'
import { catchError, map, switchMap } from 'rxjs/operators'
import { HttpClient, HttpParams } from '@angular/common/http'
import { Injectable } from '@angular/core'
import { ComponentPaginationLight, RestExtractor, RestPagination, RestService } from '@app/core'
import { Video, VideoChannel, VideoChannelService, VideoService } from '@app/shared/shared-main'
-import { peertubeLocalStorage } from '@root-helpers/peertube-web-storage'
import {
ResultList,
Video as VideoServerModel,
private restService: RestService,
private videoService: VideoService,
private playlistService: VideoPlaylistService
- ) {
- // Add ability to override search endpoint if the user updated this local storage key
- const searchUrl = peertubeLocalStorage.getItem('search-url')
- if (searchUrl) SearchService.BASE_SEARCH_URL = searchUrl
- }
+ ) { }
searchVideos (parameters: {
search?: string
}): Observable<ResultList<Video>> {
const { search, uuids, componentPagination, advancedSearch } = parameters
+ if (advancedSearch?.resultType !== undefined && advancedSearch.resultType !== 'videos') {
+ return of({ total: 0, data: [] })
+ }
+
const url = SearchService.BASE_SEARCH_URL + 'videos'
let pagination: RestPagination
if (componentPagination) {
- pagination = this.restService.componentPaginationToRestPagination(componentPagination)
+ pagination = this.restService.componentToRestPagination(componentPagination)
}
let params = new HttpParams()
}): Observable<ResultList<VideoChannel>> {
const { search, advancedSearch, componentPagination, handles } = parameters
+ if (advancedSearch?.resultType !== undefined && advancedSearch.resultType !== 'channels') {
+ return of({ total: 0, data: [] })
+ }
+
const url = SearchService.BASE_SEARCH_URL + 'video-channels'
let pagination: RestPagination
if (componentPagination) {
- pagination = this.restService.componentPaginationToRestPagination(componentPagination)
+ pagination = this.restService.componentToRestPagination(componentPagination)
}
let params = new HttpParams()
}): Observable<ResultList<VideoPlaylist>> {
const { search, advancedSearch, componentPagination, uuids } = parameters
+ if (advancedSearch?.resultType !== undefined && advancedSearch.resultType !== 'playlists') {
+ return of({ total: 0, data: [] })
+ }
+
const url = SearchService.BASE_SEARCH_URL + 'video-playlists'
let pagination: RestPagination
if (componentPagination) {
- pagination = this.restService.componentPaginationToRestPagination(componentPagination)
+ pagination = this.restService.componentToRestPagination(componentPagination)
}
let params = new HttpParams()