X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=client%2Fsrc%2Fapp%2F%2Badmin%2Fplugins%2Fplugin-list-installed%2Fplugin-list-installed.component.ts;h=6d66869dd1c08499503805ab9cd9d1ac5434c6ca;hb=2accfdd8ecd092de7e8c71fbd1235e139ad29832;hp=9745bc36b8aa5ea6be964f8c9059dfe2d9ecc78d;hpb=d00dc28dd73ad9dd419d5a5ac6ac747cefbc6e8b;p=github%2FChocobozzz%2FPeerTube.git diff --git a/client/src/app/+admin/plugins/plugin-list-installed/plugin-list-installed.component.ts b/client/src/app/+admin/plugins/plugin-list-installed/plugin-list-installed.component.ts index 9745bc36b..6d66869dd 100644 --- a/client/src/app/+admin/plugins/plugin-list-installed/plugin-list-installed.component.ts +++ b/client/src/app/+admin/plugins/plugin-list-installed/plugin-list-installed.component.ts @@ -1,10 +1,11 @@ +import { Subject } from 'rxjs' import { Component, OnInit } from '@angular/core' -import { PluginType } from '@shared/models/plugins/plugin.type' -import { I18n } from '@ngx-translate/i18n-polyfill' +import { ActivatedRoute, Router } from '@angular/router' import { PluginApiService } from '@app/+admin/plugins/shared/plugin-api.service' -import { ComponentPagination, hasMoreItems } from '@app/shared/rest/component-pagination.model' -import { Notifier } from '@app/core' -import { PeerTubePlugin } from '@shared/models/plugins/peertube-plugin.model' +import { ComponentPagination, ConfirmService, hasMoreItems, Notifier } from '@app/core' +import { PluginService } from '@app/core/plugins/plugin.service' +import { compareSemVer } from '@shared/core-utils' +import { PeerTubePlugin, PluginType } from '@shared/models' @Component({ selector: 'my-plugin-list-installed', @@ -12,27 +13,44 @@ import { PeerTubePlugin } from '@shared/models/plugins/peertube-plugin.model' styleUrls: [ './plugin-list-installed.component.scss' ] }) export class PluginListInstalledComponent implements OnInit { - pluginTypeOptions: { label: string, value: PluginType }[] = [] - pluginType: PluginType = PluginType.PLUGIN + pluginType: PluginType pagination: ComponentPagination = { currentPage: 1, - itemsPerPage: 10 + itemsPerPage: 10, + totalItems: null } sort = 'name' plugins: PeerTubePlugin[] = [] + updating: { [name: string]: boolean } = {} + + onDataSubject = new Subject() constructor ( - private i18n: I18n, - private pluginService: PluginApiService, - private notifier: Notifier + private pluginService: PluginService, + private pluginApiService: PluginApiService, + private notifier: Notifier, + private confirmService: ConfirmService, + private router: Router, + private route: ActivatedRoute ) { - this.pluginTypeOptions = this.pluginService.getPluginTypeOptions() } ngOnInit () { - this.reloadPlugins() + if (!this.route.snapshot.queryParams['pluginType']) { + const queryParams = { pluginType: PluginType.PLUGIN } + + this.router.navigate([], { queryParams }) + } + + this.route.queryParams.subscribe(query => { + if (!query['pluginType']) return + + this.pluginType = parseInt(query['pluginType'], 10) + + this.reloadPlugins() + }) } reloadPlugins () { @@ -43,15 +61,17 @@ export class PluginListInstalledComponent implements OnInit { } loadMorePlugins () { - this.pluginService.getPlugins(this.pluginType, this.pagination, this.sort) - .subscribe( - res => { + this.pluginApiService.getPlugins(this.pluginType, this.pagination, this.sort) + .subscribe({ + next: res => { this.plugins = this.plugins.concat(res.data) this.pagination.totalItems = res.total + + this.onDataSubject.next(res.data) }, - err => this.notifier.error(err.message) - ) + error: err => this.notifier.error(err.message) + }) } onNearOfBottom () { @@ -64,9 +84,97 @@ export class PluginListInstalledComponent implements OnInit { getNoResultMessage () { if (this.pluginType === PluginType.PLUGIN) { - return this.i18n('You don\'t have plugins installed yet.') + return $localize`You don't have plugins installed yet.` } - return this.i18n('You don\'t have themes installed yet.') + return $localize`You don't have themes installed yet.` + } + + isUpdateAvailable (plugin: PeerTubePlugin) { + return plugin.latestVersion && compareSemVer(plugin.latestVersion, plugin.version) > 0 + } + + getUpdateLabel (plugin: PeerTubePlugin) { + return $localize`Update to ${plugin.latestVersion}` + } + + isUpdating (plugin: PeerTubePlugin) { + return !!this.updating[this.getUpdatingKey(plugin)] + } + + isTheme (plugin: PeerTubePlugin) { + return plugin.type === PluginType.THEME + } + + async uninstall (plugin: PeerTubePlugin) { + const res = await this.confirmService.confirm( + $localize`Do you really want to uninstall ${plugin.name}?`, + $localize`Uninstall` + ) + if (res === false) return + + this.pluginApiService.uninstall(plugin.name, plugin.type) + .subscribe({ + next: () => { + this.notifier.success($localize`${plugin.name} uninstalled.`) + + this.plugins = this.plugins.filter(p => p.name !== plugin.name) + this.pagination.totalItems-- + }, + + error: err => this.notifier.error(err.message) + }) + } + + async update (plugin: PeerTubePlugin) { + const updatingKey = this.getUpdatingKey(plugin) + if (this.updating[updatingKey]) return + + if (this.isMajorUpgrade(plugin)) { + const res = await this.confirmService.confirm( + $localize`This is a major plugin upgrade. Please go on the plugin homepage to check potential release notes.`, + $localize`Upgrade`, + $localize`Proceed upgrade` + ) + + if (res === false) return + } + + this.updating[updatingKey] = true + + this.pluginApiService.update(plugin.name, plugin.type) + .pipe() + .subscribe({ + next: res => { + this.updating[updatingKey] = false + + this.notifier.success($localize`${plugin.name} updated.`) + + Object.assign(plugin, res) + }, + + error: err => this.notifier.error(err.message) + }) + } + + getShowRouterLink (plugin: PeerTubePlugin) { + return [ '/admin', 'plugins', 'show', this.pluginService.nameToNpmName(plugin.name, plugin.type) ] + } + + getPluginOrThemeHref (name: string) { + return this.pluginApiService.getPluginOrThemeHref(this.pluginType, name) + } + + private getUpdatingKey (plugin: PeerTubePlugin) { + return plugin.name + plugin.type + } + + private isMajorUpgrade (plugin: PeerTubePlugin) { + if (!plugin.latestVersion) return false + + const latestMajor = plugin.latestVersion.split('.')[0] + const currentMajor = plugin.version.split('.')[0] + + return latestMajor > currentMajor } }