Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
motif-web-admin-core / esm2015 / lib / sections / Plugins / components / plugins-section-component.js
Size: Mime:
/**
 * @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>&nbsp;</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":";;;;;AAAA,OAAO,EAAE,SAAS,EAAqB,SAAS,EAAE,MAAM,eAAe,CAAC;AACxE,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,SAAS,EAAC,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,eAAe,EAAU,MAAM,4CAA4C,CAAC;AAErF,OAAO,EAAE,OAAO,EAAS,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAE,qBAAqB,EAAE,MAAM,qDAAqD,CAAC;AAC5F,OAAO,KAAK,CAAC,MAAM,QAAQ,CAAA;AAC3B,OAAO,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAC5E,OAAO,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAIlE,OAAO,gCAAgC,CAAC;AACxC,OAAO,wCAAwC,CAAC;AAOhD,OAAO,EAAE,oCAAoC,EAAyB,MAAM,oDAAoD,CAAC;;MAG3H,OAAO,GAAG,kBAAkB;IAerB,uBAAuB,SAAvB,uBAAuB;;;;;;IAkBhC,YAAoB,MAAiB,EACzB,eAAgC,EAChC,kBAAwC;QAFhC,WAAM,GAAN,MAAM,CAAW;QACzB,oBAAe,GAAf,eAAe,CAAiB;QAChC,uBAAkB,GAAlB,kBAAkB,CAAsB;QAlBpD,kBAAa,GAAG,aAAa,CAAC;QAMtB,gBAAW,GAA0B,IAAI,qBAAqB,EAAE,CAAC;QAKzE,eAAU,GAAqB,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;QAEtC,UAAK,GAAU,EACrB,CAAC;QAKE,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAG,YAAY,CAAC,CAAC;IAE9C,CAAC;;;;;IAKD,QAAQ;QACJ,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAG,iBAAiB,CAAC,CAAC;QAC/C,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;;;;IAED,WAAW;QACP,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAG,cAAc,CAAC,CAAC;QAC5C,IAAI,CAAC,OAAO,EAAE,CAAC;IACnB,CAAC;;;;IAED,OAAO;QACH,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC;QAC/B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC5B,CAAC;;;;IAEM,gBAAgB;QACnB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAG,iBAAiB,CAAC,CAAC;QAC/C,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;;;;IAEM,WAAW;QACd,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAG,qBAAqB,CAAC,CAAC;QACnD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC,SAAS;;;;QAAC,CAAC,IAAmB,EAAE,EAAE;YACvG,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;YACjB,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,sCAAsC;QAC1C,CAAC;;;;QAAE,CAAC,KAAK,EAAE,EAAE;YACT,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,+CAA+C;YAC/C,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;YACxC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACzB,CAAC,EAAC,CAAC,CAAC;IACR,CAAC;;;;;IAEO,cAAc;QAClB,IAAI,CAAC,UAAU,GAAG,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;IACpC,CAAC;;;;;IAEO,gBAAgB;;cACd,MAAM,GAAG,CAAC,CAAC,KAAK,CAClB,IAAI,CAAC,IAAI;;;;QACT,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,KAAK,QAAQ,CAAC,EAC9C;;cACK,QAAQ,GAAG,CAAC,CAAC,KAAK,CACpB,IAAI,CAAC,IAAI;;;;QACT,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,KAAK,UAAU,CAAC,EAChD;;cACK,OAAO,GAAG,CAAC,CAAC,KAAK,CACnB,IAAI,CAAC,IAAI;;;;QACT,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,KAAK,WAAW,CAAC,EACjD;QACD,IAAI,CAAC,UAAU,GAAG;;YACd,KAAK,EAAE;gBACH,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAC,oBAAoB,EAAE;gBACjE,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAC,oBAAoB,EAAE;gBACrE,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAC,eAAe,EAAE;aAClE;SACJ,CAAA;IACL,CAAC;;;;;IAEM,eAAe,CAAC,MAAc;QACjC,IAAI,MAAM,CAAC,MAAM,KAAK,QAAQ,EAAE;YAC5B,OAAO,SAAS,CAAC;SACpB;aAAM;YACH,OAAO,SAAS,CAAC;SACpB;IACL,CAAC;;;;;IAEM,cAAc,CAAC,KAAY;QAC9B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAC7C,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;;;;;IAEO,WAAW;QACf,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAG,qBAAqB,CAAC,CAAC;;YAC/C,YAAY;QAChB,IAAI,IAAI,CAAC,WAAW,EAAE;YAClB,YAAY,GAAG,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI;;;;YAAE,CAAC,CAAC,EAAE,EAAE;;sBAC/B,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC;gBAClD,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;YAChC,CAAC,EAAC,CAAC;SACN;aAAM;YACH,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC;SAC5B;QACD,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;IACtD,CAAC;;;;;;IAEO,WAAW,CAAC,MAAc;;cACxB,UAAU,GAAG,GAAG,GAAG,MAAM,GAAG,GAAG;QACrC,OAAO,IAAI,MAAM,CAAC,GAAG,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC;IACpE,CAAC;;;;;IAED,oBAAoB,CAAC,KAAK;QACtB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAG,oCAAoC,EAAE,KAAK,CAAC,CAAC;;YACrE,UAAU,GAAG,KAAK,CAAC,IAAI;;YACvB,OAAO,GAAG,KAAK,CAAC,OAAO;QAC3B,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;IAChE,CAAC;;;;;;IAEM,iBAAiB,CAAC,UAAiB,EAAE,YAAoB;QAC5D,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAG,+BAA+B,EAAE,UAAU,CAAC,CAAC;QACzE,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC,UAAU,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC,CAAC,SAAS;;;;QAAC,CAAC,OAAO,EAAE,EAAE;YAChH,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,CAAY,sCAAsC;QAC3E,CAAC;;;;QAAE,CAAC,KAAK,EAAE,EAAE;YACT,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;YACxC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACzB,CAAC,EAAC,CAAC,CAAC;IACR,CAAC;;;;;IAED,oBAAoB,CAAC,KAA4B;QAC7C,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,YAAY,CAAC,CAAC;IACjE,CAAC;;;;;IAGD,eAAe,CAAC,KAAyB;QACrC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAG,wBAAwB,EAAE,KAAK,CAAC,CAAC;QAC7D,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC;YACzB,IAAI,EAAE,eAAe;YACrB,KAAK,EAAE,gBAAgB;YACvB,OAAO,EAAE,sBAAsB;YAC/B,IAAI,EAAE,gBAAgB,CAAC,IAAI;SAC9B,CAAC,CAAC;QACH,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC,SAAS;;;;QAAC,CAAC,IAAI,EAAE,EAAE;YAC3G,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAG,2BAA2B,EAAE,IAAI,CAAC,CAAC;YAC9D,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC;gBACzB,IAAI,EAAE,eAAe;gBACrB,KAAK,EAAE,gBAAgB;gBACvB,OAAO,EAAE,gCAAgC;gBACzC,IAAI,EAAE,gBAAgB,CAAC,OAAO;aACjC,CAAC,CAAC;YACH,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC;;;;QAAE,CAAC,KAAK,EAAE,EAAE;YACX,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,uBAAuB,EAAE,KAAK,CAAC,CAAC;YAC3D,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC;gBACzB,IAAI,EAAE,oBAAoB;gBAC1B,KAAK,EAAE,gBAAgB;gBACvB,OAAO,EAAE,0BAA0B;gBACnC,IAAI,EAAE,gBAAgB,CAAC,KAAK;gBAC5B,KAAK,EAAE,KAAK;gBACZ,QAAQ,EAAE,IAAI;aACjB,CAAC,CAAC;QACP,CAAC,EAAC,CAAC,CAAC;IACR,CAAC;;;;;IAED,oBAAoB,CAAC,KAAK;QACtB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAG,6BAA6B,EAAE,KAAK,CAAC,CAAC;QAClE,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC;YACzB,IAAI,EAAE,oBAAoB;YAC1B,KAAK,EAAE,gBAAgB;YACvB,OAAO,EAAE,0BAA0B;YACnC,IAAI,EAAE,gBAAgB,CAAC,KAAK;YAC5B,KAAK,EAAE,KAAK;YACZ,QAAQ,EAAE,IAAI;SACjB,CAAC,CAAC;IACP,CAAC;CAEJ,CAAA;;YA7MA,SAAS,SAAC;gBACP,QAAQ,EAAE,qBAAqB;gBAE/B,6kIAA+C;;aAChD;;;;YA5BM,SAAS;YACT,eAAe;YAKf,oBAAoB;;;2CA0CxB,SAAS,SAAC,6BAA6B;;AAX/B,uBAAuB;IARjC,UAAU,CAAC,SAAS,EAAE;QACrB,QAAQ,EAAE,gBAAgB;QAC1B,QAAQ,EAAE;YACN,GAAG,EAAE;gBACD,WAAW,EAAE,CAAC,oEAAoE,CAAC;aACtF;SACJ;KACJ,CAAC;6CAmB8B,SAAS;QACR,eAAe;QACZ,oBAAoB;GApB3C,uBAAuB,CAgMnC;SAhMY,uBAAuB;;;IAEhC,gDAA8B;;IAE9B,uCAA2B;;IAC3B,2CAAgC;;IAChC,0CAAwB;;;;;IACxB,8CAA4B;;;;;IAC5B,8CAAyE;;IACzE,oDAA2B;;IAE3B,+DAA6G;;IAE7G,6CAA6C;;IAE7C,wCACE;;;;;IAEU,yCAAyB;;;;;IACjC,kDAAwC;;;;;IACxC,qDAAgD","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"]}