import { HttpClient } from '@angular/common/http'
import { Injectable } from '@angular/core'
+import { peertubeLocalStorage } from '@app/shared/misc/peertube-local-storage'
import 'rxjs/add/operator/do'
import { ReplaySubject } from 'rxjs/ReplaySubject'
import { ServerConfig } from '../../../../../shared'
-import { About } from '../../../../../shared/models/config/about.model'
+import { About } from '../../../../../shared/models/server/about.model'
+import { ServerStats } from '../../../../../shared/models/server/server-stats.model'
import { environment } from '../../../environments/environment'
@Injectable()
private static BASE_VIDEO_URL = environment.apiUrl + '/api/v1/videos/'
private static CONFIG_LOCAL_STORAGE_KEY = 'server-config'
+ configLoaded = new ReplaySubject<boolean>(1)
videoPrivaciesLoaded = new ReplaySubject<boolean>(1)
videoCategoriesLoaded = new ReplaySubject<boolean>(1)
videoLicencesLoaded = new ReplaySubject<boolean>(1)
private config: ServerConfig = {
instance: {
- name: 'PeerTube'
+ name: 'PeerTube',
+ shortDescription: 'PeerTube, a federated (ActivityPub) video streaming platform ' +
+ 'using P2P (BitTorrent) directly in the web browser with WebTorrent and Angular.',
+ defaultClientRoute: '',
+ customizations: {
+ javascript: '',
+ css: ''
+ }
},
serverVersion: 'Unknown',
signup: {
}
},
video: {
+ image: {
+ size: { max: 0 },
+ extensions: []
+ },
file: {
extensions: []
}
+ },
+ user: {
+ videoQuota: -1
}
}
private videoCategories: Array<{ id: number, label: string }> = []
loadConfig () {
this.http.get<ServerConfig>(ServerService.BASE_CONFIG_URL)
.do(this.saveConfigLocally)
- .subscribe(data => this.config = data)
+ .subscribe(data => {
+ this.config = data
+
+ this.configLoaded.next(true)
+ })
}
loadVideoCategories () {
- return this.loadVideoAttributeEnum('categories', this.videoCategories, this.videoCategoriesLoaded)
+ return this.loadVideoAttributeEnum('categories', this.videoCategories, this.videoCategoriesLoaded, true)
}
loadVideoLicences () {
}
loadVideoLanguages () {
- return this.loadVideoAttributeEnum('languages', this.videoLanguages, this.videoLanguagesLoaded)
+ return this.loadVideoAttributeEnum('languages', this.videoLanguages, this.videoLanguagesLoaded, true)
}
loadVideoPrivacies () {
private loadVideoAttributeEnum (
attributeName: 'categories' | 'licences' | 'languages' | 'privacies',
hashToPopulate: { id: number, label: string }[],
- notifier: ReplaySubject<boolean>
+ notifier: ReplaySubject<boolean>,
+ sort = false
) {
return this.http.get(ServerService.BASE_VIDEO_URL + attributeName)
.subscribe(data => {
})
})
+ if (sort === true) {
+ hashToPopulate.sort((a, b) => {
+ if (a.label < b.label) return -1
+ if (a.label === b.label) return 0
+ return 1
+ })
+ }
+
notifier.next(true)
})
}
private saveConfigLocally (config: ServerConfig) {
- localStorage.setItem(ServerService.CONFIG_LOCAL_STORAGE_KEY, JSON.stringify(config))
+ peertubeLocalStorage.setItem(ServerService.CONFIG_LOCAL_STORAGE_KEY, JSON.stringify(config))
}
private loadConfigLocally () {
- const configString = localStorage.getItem(ServerService.CONFIG_LOCAL_STORAGE_KEY)
+ const configString = peertubeLocalStorage.getItem(ServerService.CONFIG_LOCAL_STORAGE_KEY)
if (configString) {
try {