import { Component, OnInit } from '@angular/core'
import { ActivatedRoute, Router } from '@angular/router'
import { PluginApiService } from '@app/+admin/plugins/shared/plugin-api.service'
-import { ComponentPagination, ConfirmService, hasMoreItems, Notifier } from '@app/core'
+import { ComponentPagination, ConfirmService, hasMoreItems, Notifier, PluginService } from '@app/core'
import { PeerTubePluginIndex } from '@shared/models/plugins/peertube-plugin-index.model'
import { PluginType } from '@shared/models/plugins/plugin.type'
private searchSubject = new Subject<string>()
constructor (
- private pluginService: PluginApiService,
+ private pluginService: PluginService,
+ private pluginApiService: PluginApiService,
private notifier: Notifier,
private confirmService: ConfirmService,
private router: Router,
private route: ActivatedRoute
) {
- this.pluginTypeOptions = this.pluginService.getPluginTypeOptions()
+ this.pluginTypeOptions = this.pluginApiService.getPluginTypeOptions()
}
ngOnInit () {
loadMorePlugins () {
this.isSearching = true
- this.pluginService.searchAvailablePlugins(this.pluginType, this.pagination, this.sort, this.search)
+ this.pluginApiService.searchAvailablePlugins(this.pluginType, this.pagination, this.sort, this.search)
.subscribe(
res => {
this.isSearching = false
return !!this.installing[plugin.npmName]
}
+ getPluginOrThemeHref (name: string) {
+ return this.pluginApiService.getPluginOrThemeHref(this.pluginType, name)
+ }
+
+ getShowRouterLink (plugin: PeerTubePluginIndex) {
+ return [ '/admin', 'plugins', 'show', this.pluginService.nameToNpmName(plugin.name, this.pluginType) ]
+ }
+
+ isThemeSearch () {
+ return this.pluginType === PluginType.THEME
+ }
+
async install (plugin: PeerTubePluginIndex) {
if (this.installing[plugin.npmName]) return
this.installing[plugin.npmName] = true
- this.pluginService.install(plugin.npmName)
+ this.pluginApiService.install(plugin.npmName)
.subscribe(
() => {
this.installing[plugin.npmName] = false