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=1a95980aeda70e794ef964994b6973c8d51f8500;hb=c96e457bde8495cf9103bf819f887f341a528543;hp=af31f114444888f6e6c5d888ebcd0c69fde1d5ac;hpb=67ed6552b831df66713bac9e672738796128d33f;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 af31f1144..1a95980ae 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 @@ -4,7 +4,6 @@ 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 { PluginService } from '@app/core/plugins/plugin.service' -import { I18n } from '@ngx-translate/i18n-polyfill' import { compareSemVer } from '@shared/core-utils/miscs/miscs' import { PeerTubePlugin } from '@shared/models/plugins/peertube-plugin.model' import { PluginType } from '@shared/models/plugins/plugin.type' @@ -32,12 +31,9 @@ export class PluginListInstalledComponent implements OnInit { plugins: PeerTubePlugin[] = [] updating: { [name: string]: boolean } = {} - PluginType = PluginType - onDataSubject = new Subject() constructor ( - private i18n: I18n, private pluginService: PluginService, private pluginApiService: PluginApiService, private notifier: Notifier, @@ -88,10 +84,10 @@ 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) { @@ -99,24 +95,28 @@ export class PluginListInstalledComponent implements OnInit { } getUpdateLabel (plugin: PeerTubePlugin) { - return this.i18n('Update to {{version}}', { version: plugin.latestVersion }) + 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( - this.i18n('Do you really want to uninstall {{pluginName}}?', { pluginName: plugin.name }), - this.i18n('Uninstall') + $localize`Do you really want to uninstall ${plugin.name}?`, + $localize`Uninstall` ) if (res === false) return this.pluginApiService.uninstall(plugin.name, plugin.type) .subscribe( () => { - this.notifier.success(this.i18n('{{pluginName}} uninstalled.', { pluginName: plugin.name })) + this.notifier.success($localize`${plugin.name} uninstalled.`) this.plugins = this.plugins.filter(p => p.name !== plugin.name) this.pagination.totalItems-- @@ -130,6 +130,16 @@ export class PluginListInstalledComponent implements OnInit { 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) @@ -138,7 +148,7 @@ export class PluginListInstalledComponent implements OnInit { res => { this.updating[updatingKey] = false - this.notifier.success(this.i18n('{{pluginName}} updated.', { pluginName: plugin.name })) + this.notifier.success($localize`${plugin.name} updated.`) Object.assign(plugin, res) }, @@ -151,7 +161,20 @@ export class PluginListInstalledComponent implements OnInit { 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 + } }