Repository URL to install this package:
Version:
0.3.1 ▾
|
motif-web-admin-core
/
esm2015
/
lib
/
sections
/
Plugins
/
components
/
plugins-section-component.js
|
---|
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, ViewChild } from '@angular/core';
import { PluginView } from 'web-console-core';
import { NGXLogger } from 'web-console-core';
import { RegistryService } from '@wa-motif-open-api/plugin-registry-service';
import { process } from '@progress/kendo-data-query';
import { WCSubscriptionHandler } from '../../../components/Commons/wc-subscription-handler';
import * as _ from 'lodash';
import { WCNotificationCenter, NotificationType } from 'web-console-ui-kit';
import { faPuzzlePiece } from '@fortawesome/free-solid-svg-icons';
import 'rxjs/add/operator/debounceTime';
import 'rxjs/add/operator/distinctUntilChanged';
import { UninstallConfirmationDialogComponent } from '../dialogs/uninstall-confirmation-dialog-component';
/** @type {?} */
const LOG_TAG = '[PluginsSection]';
let PluginsSectionComponent = class PluginsSectionComponent {
/**
* @param {?} logger
* @param {?} registryService
* @param {?} notificationCenter
*/
constructor(logger, registryService, notificationCenter) {
this.logger = logger;
this.registryService = registryService;
this.notificationCenter = notificationCenter;
this.faPuzzlePiece = faPuzzlePiece;
this._subHandler = new WCSubscriptionHandler();
this.statsModel = { items: [] };
this.state = {};
this.logger.debug(LOG_TAG, 'Opening...');
}
/**
* Angular ngOnInit
* @return {?}
*/
ngOnInit() {
this.logger.debug(LOG_TAG, 'Initializing...');
this.refreshData();
}
/**
* @return {?}
*/
ngOnDestroy() {
this.logger.debug(LOG_TAG, 'ngOnDestroy ');
this.freeMem();
}
/**
* @return {?}
*/
freeMem() {
this.data = null;
this.gridData = null;
this._subHandler.unsubscribe();
this._subHandler = null;
}
/**
* @return {?}
*/
onRefreshClicked() {
this.logger.debug(LOG_TAG, 'Refresh clicked');
this.refreshData();
}
/**
* @return {?}
*/
refreshData() {
this.logger.debug(LOG_TAG, 'refreshData called.');
this.loading = true;
this._subHandler.add(this.registryService.getPlugins(true, 'REGISTERED').subscribe((/**
* @param {?} data
* @return {?}
*/
(data) => {
this.data = data;
this.displayData();
this.rebuildStatsInfo();
this.loading = false;
// console.log("refreshData: ", data);
}), (/**
* @param {?} error
* @return {?}
*/
(error) => {
this.clearStatsInfo();
// console.error("refreshData error: ", error);
this.gridData = process([], this.state);
this.loading = false;
})));
}
/**
* @private
* @return {?}
*/
clearStatsInfo() {
this.statsModel = { items: [] };
}
/**
* @private
* @return {?}
*/
rebuildStatsInfo() {
/** @type {?} */
const active = _.sumBy(this.data, (/**
* @param {?} __0
* @return {?}
*/
({ status }) => Number(status === "ACTIVE")));
/** @type {?} */
const inactive = _.sumBy(this.data, (/**
* @param {?} __0
* @return {?}
*/
({ status }) => Number(status === "RESOLVED")));
/** @type {?} */
const inError = _.sumBy(this.data, (/**
* @param {?} __0
* @return {?}
*/
({ status }) => Number(status === "INSTALLED")));
this.statsModel = {
//cssClass:"green-stats-info"
items: [
{ label: "active", value: active, cssClass: "stats-info-primary" },
{ label: "inactive", value: inactive, cssClass: "stats-info-default" },
{ label: "in error", value: inError, cssClass: "stats-info-ko" }
]
};
}
/**
* @param {?} plugin
* @return {?}
*/
statusColorCode(plugin) {
if (plugin.status === 'ACTIVE') {
return '#1ab31a';
}
else {
return 'inherit';
}
}
/**
* @param {?} event
* @return {?}
*/
onFilterChange(event) {
this.filterValue = event.srcElement['value'];
this.displayData();
}
/**
* @private
* @return {?}
*/
displayData() {
this.logger.debug(LOG_TAG, 'displayData called.');
/** @type {?} */
let filteredData;
if (this.filterValue) {
filteredData = _.filter(this.data, (/**
* @param {?} o
* @return {?}
*/
(o) => {
/** @type {?} */
const matcher = this.buildRegExp(this.filterValue);
return matcher.test(o.name);
}));
}
else {
filteredData = this.data;
}
this.gridData = process(filteredData, this.state);
}
/**
* @private
* @param {?} filter
* @return {?}
*/
buildRegExp(filter) {
/** @type {?} */
const wildcarded = '*' + filter + '*';
return new RegExp('^' + wildcarded.split('*').join('.*') + '$');
}
/**
* @param {?} event
* @return {?}
*/
onUninstallOKPressed(event) {
this.logger.debug(LOG_TAG, 'onUninstallOKPressed pressed for: ', event);
/** @type {?} */
let pluginName = event.name;
/** @type {?} */
let version = event.version;
this._uninstallConfirmationDialog.show(pluginName, version);
}
/**
* @param {?} pluginName
* @param {?} deleteConfig
* @return {?}
*/
doUninstallPlugin(pluginName, deleteConfig) {
this.logger.debug(LOG_TAG, 'doUninstallPlugin called for:', pluginName);
this.loading = true;
this._subHandler.add(this.registryService.uninstallPlugin(pluginName, { removeConfig: true }).subscribe((/**
* @param {?} results
* @return {?}
*/
(results) => {
this.displayData();
this.rebuildStatsInfo();
this.loading = false; // console.log("refreshData: ", data);
}), (/**
* @param {?} error
* @return {?}
*/
(error) => {
this.gridData = process([], this.state);
this.loading = false;
})));
}
/**
* @param {?} event
* @return {?}
*/
onUninstallConfirmed(event) {
this.doUninstallPlugin(event.pluginName, event.deleteConfig);
}
/**
* @param {?} event
* @return {?}
*/
onInstallPlugin(event) {
this.logger.debug(LOG_TAG, 'onInstallPlugin event:', event);
this.notificationCenter.post({
name: 'InstallPlugin',
title: 'Plugin Install',
message: 'Installing plugin...',
type: NotificationType.Info
});
this._subHandler.add(this.registryService.installPlugin(event.file, this.overwriteExisting).subscribe((/**
* @param {?} data
* @return {?}
*/
(data) => {
this.logger.info(LOG_TAG, 'Plugin installation done:', data);
this.notificationCenter.post({
name: 'InstallPlugin',
title: 'Plugin Install',
message: 'Plugin installed successfully.',
type: NotificationType.Success
});
this.refreshData();
}), (/**
* @param {?} error
* @return {?}
*/
(error) => {
this.logger.error(LOG_TAG, 'Import license error:', error);
this.notificationCenter.post({
name: 'InstallPluginError',
title: 'Plugin Install',
message: 'Error installing plugin:',
type: NotificationType.Error,
error: error,
closable: true
});
})));
}
/**
* @param {?} error
* @return {?}
*/
onInstallPluginError(error) {
this.logger.error(LOG_TAG, 'onInstallPluginError error:', error);
this.notificationCenter.post({
name: 'InstallPluginError',
title: 'Install Plugin',
message: 'Error installing plugin:',
type: NotificationType.Error,
error: error,
closable: true
});
}
};
PluginsSectionComponent.decorators = [
{ type: Component, args: [{
selector: 'app-plugins-section',
template: "<wc-dashboard-header [title]=\"'Plugins'\"></wc-dashboard-header>\n\n<wc-stats-info-component [model]=\"statsModel\"></wc-stats-info-component>\n\n<wa-uninstall-confirmation-dialog-component #uninstallConfirmationDialog (confirm)=\"onUninstallConfirmed($event)\"></wa-uninstall-confirmation-dialog-component>\n\n<wc-loading-overlay [visible]='loading'></wc-loading-overlay>\n\n<div class=\"row spread\" >\n\n <div class=\"flex-toolbar\" style=\"display:flex;align-items: center;\">\n <kendo-textbox-container floatingLabel=\"Filter\">\n <input #filterInput kendoTextBox (afterValueChanged)=\"onFilterChange($event)\"/>\n </kendo-textbox-container>\n <div>\n <label> </label>\n <kendo-buttongroup look=\"flat\">\n <button kendoButton \n motif-acl=\"com.vipera.osgi.core.registry.api.rest.RegistryApi:UPDATE:installPlugin\"\n [toggleable]=\"false\" \n (click)=\"installPluginSlideDownPanel.toggle()\">\n <fa-icon [icon]=\"faPuzzlePiece\"></fa-icon>Install Plugin\n </button>\n </kendo-buttongroup>\n </div>\n </div>\n\n <div class=\"flex-cmd\">\n <kendo-buttongroup look=\"flat\">\n <button kendoButton [toggleable]=\"false\" [icon]=\"'refresh'\" (click)=\"onRefreshClicked()\">Refresh</button>\n </kendo-buttongroup>\n </div>\n\n</div>\n\n<div class=\"row fill\">\n\n <div style=\"height: 98%;\">\n\n <wc-upload-panel #installPluginSlideDownPanel [confirmationTitle]=\"'Do install plugin?'\" (upload)=\"onInstallPlugin($event)\" (uploadError)=\"onInstallPluginError($event)\">\n <div style=\"padding-top:8px;display: flex;\">\n <label class=\"switch-control-label\" style=\"padding-top: 0.3rem;padding-right: 10px;\"> \n Overwrite Existing\n </label>\n <p-inputSwitch [styleClass]=\"'mini-switch'\" [(ngModel)]=\"overwriteExisting\"></p-inputSwitch>\n </div>\n </wc-upload-panel>\n\n <kendo-grid #datagrid [data]=\"gridData\" style=\"height: 100%;\"> \n\n <kendo-grid-column\n field=\"name\" title=\"Name\" >\n </kendo-grid-column>\n\n <kendo-grid-column field=\"version\" title=\"Version\" width=\"150\">\n </kendo-grid-column>\n\n <kendo-grid-column field=\"status\" title=\"Status\" width=\"150\">\n <ng-template kendoGridCellTemplate let-dataItem>\n <span class=\"whole-cell\" [style.color]=\"statusColorCode(dataItem)\">\n {{ dataItem.status }}\n </span>\n </ng-template>\n </kendo-grid-column>\n\n <kendo-grid-column title=\"\" width=\"150\" minResizableWidth=\"140\">\n <ng-template kendoGridCellTemplate let-dataItem let-columnIndex=\"columnIndex\" let-rowIndex=\"rowIndex\" let-column=\"column\">\n <wc-grid-editor-command \n motif-acl=\"com.vipera.osgi.core.registry.api.rest.RegistryApi:DELETE:uninstallPlugin\"\n motif-acl-hidden=\"true\"\n [alignMode]=\"'end'\"\n [hasConfirmation]=\"true\"\n [confirmationTitle]=\"'Uninstall ?'\"\n [rowIndex]=\"rowIndex\" \n [columnIndex]=\"columnIndex\" \n [column]=\"column\" \n [commandIcon]=\"'wa-ico-no'\"\n [dataItem]=\"dataItem\"\n (commandConfirm)=\"onUninstallOKPressed(dataItem)\" \n >\n </wc-grid-editor-command>\n </ng-template>\n </kendo-grid-column>\n \n \n </kendo-grid>\n </div>\n\n</div>",
styles: [":host{display:flex;flex:1;flex-direction:column}.log-pane{white-space:pre}.editor.slidedown>div>kendo-daterange>div>label,.editor.slidedown>div>label{padding-bottom:5px}"]
}] }
];
/** @nocollapse */
PluginsSectionComponent.ctorParameters = () => [
{ type: NGXLogger },
{ type: RegistryService },
{ type: WCNotificationCenter }
];
PluginsSectionComponent.propDecorators = {
_uninstallConfirmationDialog: [{ type: ViewChild, args: ['uninstallConfirmationDialog',] }]
};
PluginsSectionComponent = tslib_1.__decorate([
PluginView('Plugins', {
iconName: 'wa-ico-plugins',
userData: {
acl: {
permissions: ["com.vipera.osgi.core.registry.api.rest.RegistryApi:READ:getPlugins"]
}
}
}),
tslib_1.__metadata("design:paramtypes", [NGXLogger,
RegistryService,
WCNotificationCenter])
], PluginsSectionComponent);
export { PluginsSectionComponent };
if (false) {
/** @type {?} */
PluginsSectionComponent.prototype.faPuzzlePiece;
/** @type {?} */
PluginsSectionComponent.prototype.data;
/** @type {?} */
PluginsSectionComponent.prototype.gridData;
/** @type {?} */
PluginsSectionComponent.prototype.loading;
/**
* @type {?}
* @private
*/
PluginsSectionComponent.prototype.filterValue;
/**
* @type {?}
* @private
*/
PluginsSectionComponent.prototype._subHandler;
/** @type {?} */
PluginsSectionComponent.prototype.overwriteExisting;
/** @type {?} */
PluginsSectionComponent.prototype._uninstallConfirmationDialog;
/** @type {?} */
PluginsSectionComponent.prototype.statsModel;
/** @type {?} */
PluginsSectionComponent.prototype.state;
/**
* @type {?}
* @private
*/
PluginsSectionComponent.prototype.logger;
/**
* @type {?}
* @private
*/
PluginsSectionComponent.prototype.registryService;
/**
* @type {?}
* @private
*/
PluginsSectionComponent.prototype.notificationCenter;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plugins-section-component.js","sourceRoot":"ng://motif-web-admin-core/","sources":["lib/sections/Plugins/components/plugins-section-component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, OnDestroy, ViewChild } from '@angular/core';\nimport { PluginView } from 'web-console-core';\nimport { NGXLogger} from 'web-console-core';\nimport { RegistryService, Plugin } from '@wa-motif-open-api/plugin-registry-service';\nimport { SafeStyle } from '@angular/platform-browser';\nimport { process, State } from '@progress/kendo-data-query';\nimport { WCSubscriptionHandler } from '../../../components/Commons/wc-subscription-handler';\nimport * as _ from 'lodash'\nimport { WCNotificationCenter, NotificationType } from 'web-console-ui-kit';\nimport { faPuzzlePiece } from '@fortawesome/free-solid-svg-icons';\n\n\nimport { Subject } from 'rxjs/Subject';\nimport 'rxjs/add/operator/debounceTime';\nimport 'rxjs/add/operator/distinctUntilChanged';\n\nimport {\n    GridDataResult\n} from '@progress/kendo-angular-grid';\n\nimport { WCStatsInfoModel } from '../../../components/Stats/stats-info-component';\nimport { UninstallConfirmationDialogComponent, UninstallDialogResult } from '../dialogs/uninstall-confirmation-dialog-component';\nimport { WCUploadPanelEvent } from '../../../components';\n\nconst LOG_TAG = '[PluginsSection]';\n\n@Component({\n    selector: 'app-plugins-section',\n    styleUrls: [ './plugins-section-component.scss' ],\n    templateUrl: './plugins-section-component.html'\n  })\n  @PluginView('Plugins', {\n    iconName: 'wa-ico-plugins',\n    userData: {\n        acl: {\n            permissions: [\"com.vipera.osgi.core.registry.api.rest.RegistryApi:READ:getPlugins\"]\n        }\n    }\n})\nexport class PluginsSectionComponent implements OnInit, OnDestroy {\n\n    faPuzzlePiece = faPuzzlePiece;\n\n    public data: Array<Plugin>;\n    public gridData: GridDataResult; // = process(sampleProducts, this.state);\n    public loading: boolean;\n    private filterValue: string;\n    private _subHandler: WCSubscriptionHandler = new WCSubscriptionHandler();\n    overwriteExisting: boolean;\n\n    @ViewChild('uninstallConfirmationDialog') _uninstallConfirmationDialog: UninstallConfirmationDialogComponent;\n\n    statsModel: WCStatsInfoModel = { items: [] };\n\n    public state: State = {\n    };\n\n    constructor(private logger: NGXLogger,\n        private registryService: RegistryService,\n        private notificationCenter: WCNotificationCenter) {\n        this.logger.debug(LOG_TAG , 'Opening...');\n\n    }\n\n    /**\n     * Angular ngOnInit\n     */\n    ngOnInit() {\n        this.logger.debug(LOG_TAG , 'Initializing...');\n        this.refreshData();\n    }\n\n    ngOnDestroy() {\n        this.logger.debug(LOG_TAG , 'ngOnDestroy ');\n        this.freeMem();\n    }\n\n    freeMem() {\n        this.data = null;\n        this.gridData = null;\n        this._subHandler.unsubscribe();\n        this._subHandler = null;\n    }\n\n    public onRefreshClicked(): void {\n        this.logger.debug(LOG_TAG , 'Refresh clicked');\n        this.refreshData();\n    }\n\n    public refreshData() {\n        this.logger.debug(LOG_TAG , 'refreshData called.');\n        this.loading = true;\n        this._subHandler.add(this.registryService.getPlugins(true, 'REGISTERED').subscribe((data: Array<Plugin>) => {\n            this.data = data;\n            this.displayData();\n            this.rebuildStatsInfo();\n            this.loading = false;\n            // console.log(\"refreshData: \", data);\n        }, (error) => {\n            this.clearStatsInfo();\n            // console.error(\"refreshData error: \", error);\n            this.gridData = process([], this.state);\n            this.loading = false;\n        }));\n    }\n\n    private clearStatsInfo(){\n        this.statsModel = { items: [] };\n    }\n\n    private rebuildStatsInfo(){\n        const active = _.sumBy(\n            this.data,\n            ({ status }) => Number(status === \"ACTIVE\")\n        );\n        const inactive = _.sumBy(\n            this.data,\n            ({ status }) => Number(status === \"RESOLVED\")\n        );\n        const inError = _.sumBy(\n            this.data,\n            ({ status }) => Number(status === \"INSTALLED\")\n        );\n        this.statsModel = { //cssClass:\"green-stats-info\"\n            items: [\n                { label: \"active\", value: active, cssClass:\"stats-info-primary\" },\n                { label: \"inactive\", value: inactive, cssClass:\"stats-info-default\" },\n                { label: \"in error\", value: inError, cssClass:\"stats-info-ko\" }\n            ]\n        } \n    }\n\n    public statusColorCode(plugin: Plugin): SafeStyle {\n        if (plugin.status === 'ACTIVE') {\n            return '#1ab31a';\n        } else {\n            return 'inherit';\n        }\n    }\n\n    public onFilterChange(event: Event) {\n        this.filterValue = event.srcElement['value'];\n        this.displayData();\n    }\n\n    private displayData(): void {\n        this.logger.debug(LOG_TAG , 'displayData called.');\n        let filteredData;\n        if (this.filterValue) {\n            filteredData = _.filter(this.data, (o) => {\n                const matcher = this.buildRegExp(this.filterValue);\n                return matcher.test(o.name);\n            });\n        } else {\n            filteredData = this.data;\n        }\n        this.gridData = process(filteredData, this.state);\n    }\n\n    private buildRegExp(filter: string) {\n        const wildcarded = '*' + filter + '*';\n        return new RegExp('^' + wildcarded.split('*').join('.*') + '$');\n    }\n\n    onUninstallOKPressed(event){\n        this.logger.debug(LOG_TAG , 'onUninstallOKPressed pressed for: ', event);\n        let pluginName = event.name;\n        let version = event.version;\n        this._uninstallConfirmationDialog.show(pluginName, version);\n    }\n\n    public doUninstallPlugin(pluginName:string, deleteConfig:boolean) {\n        this.logger.debug(LOG_TAG , 'doUninstallPlugin called for:', pluginName);\n        this.loading = true;\n        this._subHandler.add(this.registryService.uninstallPlugin(pluginName, { removeConfig: true }).subscribe((results) => {\n            this.displayData();\n            this.rebuildStatsInfo();\n            this.loading = false;            // console.log(\"refreshData: \", data);\n        }, (error) => {\n            this.gridData = process([], this.state);\n            this.loading = false;\n        }));\n    }\n\n    onUninstallConfirmed(event: UninstallDialogResult){\n        this.doUninstallPlugin(event.pluginName, event.deleteConfig);\n    }\n\n\n    onInstallPlugin(event: WCUploadPanelEvent){\n        this.logger.debug(LOG_TAG , 'onInstallPlugin event:', event);\n        this.notificationCenter.post({\n            name: 'InstallPlugin',\n            title: 'Plugin Install',\n            message: 'Installing plugin...',\n            type: NotificationType.Info\n        });\n        this._subHandler.add(this.registryService.installPlugin(event.file, this.overwriteExisting).subscribe((data) => {\n            this.logger.info(LOG_TAG , 'Plugin installation done:', data);\n            this.notificationCenter.post({\n                name: 'InstallPlugin',\n                title: 'Plugin Install',\n                message: 'Plugin installed successfully.',\n                type: NotificationType.Success\n            });\n            this.refreshData();\n          }, (error) => {\n            this.logger.error(LOG_TAG, 'Import license error:', error);\n            this.notificationCenter.post({\n                name: 'InstallPluginError',\n                title: 'Plugin Install',\n                message: 'Error installing plugin:',\n                type: NotificationType.Error,\n                error: error,\n                closable: true\n            });\n        }));    \n    } \n    \n    onInstallPluginError(error){\n        this.logger.error(LOG_TAG , 'onInstallPluginError error:', error);\n        this.notificationCenter.post({\n            name: 'InstallPluginError',\n            title: 'Install Plugin',\n            message: 'Error installing plugin:',\n            type: NotificationType.Error,\n            error: error,\n            closable: true\n        });\n    }\n\n}\n"]}