-import { catchError } from 'rxjs/operators'
+import { Observable } from 'rxjs'
+import { catchError, map, switchMap } from 'rxjs/operators'
import { HttpClient, HttpParams } from '@angular/common/http'
import { Injectable } from '@angular/core'
-import { environment } from '../../../../environments/environment'
-import { RestExtractor, RestService } from '../../../shared'
-import { I18n } from '@ngx-translate/i18n-polyfill'
-import { PluginType } from '@shared/models/plugins/plugin.type'
-import { ComponentPagination } from '@app/shared/rest/component-pagination.model'
-import { ResultList } from '@shared/models'
-import { PeerTubePlugin } from '@shared/models/plugins/peertube-plugin.model'
-import { ManagePlugin } from '@shared/models/plugins/manage-plugin.model'
-import { InstallOrUpdatePlugin } from '@shared/models/plugins/install-plugin.model'
-import { PeerTubePluginIndex } from '@shared/models/plugins/peertube-plugin-index.model'
-import { RegisteredServerSettings, RegisterServerSettingOptions } from '@shared/models/plugins/register-server-setting.model'
+import { ComponentPagination, RestExtractor, RestService } from '@app/core'
import { PluginService } from '@app/core/plugins/plugin.service'
+import { peertubeTranslate } from '@shared/core-utils/i18n'
+import {
+ InstallOrUpdatePlugin,
+ ManagePlugin,
+ PeerTubePlugin,
+ PeerTubePluginIndex,
+ PluginType,
+ RegisteredServerSettings,
+ ResultList
+} from '@shared/models'
+import { environment } from '../../../../environments/environment'
@Injectable()
export class PluginApiService {
private authHttp: HttpClient,
private restExtractor: RestExtractor,
private restService: RestService,
- private i18n: I18n,
private pluginService: PluginService
) { }
getPluginTypeOptions () {
return [
{
- label: this.i18n('Plugins'),
+ label: $localize`Plugins`,
value: PluginType.PLUGIN
},
{
- label: this.i18n('Themes'),
+ label: $localize`Themes`,
value: PluginType.THEME
}
]
getPluginTypeLabel (type: PluginType) {
if (type === PluginType.PLUGIN) {
- return this.i18n('plugin')
+ return $localize`plugin`
}
- return this.i18n('theme')
+ return $localize`theme`
}
getPlugins (
const path = PluginApiService.BASE_PLUGIN_URL + '/' + npmName + '/registered-settings'
return this.authHttp.get<RegisteredServerSettings>(path)
- .pipe(catchError(res => this.restExtractor.handleError(res)))
+ .pipe(
+ switchMap(res => this.translateSettingsLabel(npmName, res)),
+ catchError(res => this.restExtractor.handleError(res))
+ )
}
updatePluginSettings (pluginName: string, pluginType: PluginType, settings: any) {
return this.authHttp.post(PluginApiService.BASE_PLUGIN_URL + '/install', body)
.pipe(catchError(res => this.restExtractor.handleError(res)))
}
+
+ getPluginOrThemeHref (type: PluginType, name: string) {
+ const typeString = type === PluginType.PLUGIN
+ ? 'plugin'
+ : 'theme'
+
+ return `https://www.npmjs.com/package/peertube-${typeString}-${name}`
+ }
+
+ private translateSettingsLabel (npmName: string, res: RegisteredServerSettings): Observable<RegisteredServerSettings> {
+ return this.pluginService.translationsObservable
+ .pipe(
+ map(allTranslations => allTranslations[npmName]),
+ map(translations => {
+ const registeredSettings = res.registeredSettings
+ .map(r => {
+ return Object.assign({}, r, { label: peertubeTranslate(r.label, translations) })
+ })
+
+ return { registeredSettings }
+ })
+ )
+ }
}