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

vipera-npm-registry / motif-web-admin-core   js

Repository URL to install this package:

Version: 0.3.1 

/ esm2015 / lib / sections / MainDashboard / components / main-dashboard-section-component.js

/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
 */
import * as tslib_1 from "tslib";
import { UsersInfoUpdater } from './../data/updaters/UsersInfoUpdater';
import { Component } from '@angular/core';
import { PluginView } from 'web-console-core';
import { NGXLogger } from 'web-console-core';
import { Gridster } from 'web-console-ui-kit';
import { SecurityService } from '@wa-motif-open-api/security-service';
import { InfoService } from '@wa-motif-open-api/info-service';
import { ServerStatusUpdater } from '../data/updaters/ServerInfo/ServerStatusUpdater';
import { ServerInfoUpdater } from '../data/updaters/ServerInfo/ServerInfoUpdater';
import { OAuth2InfoUpdater } from '../data/updaters/OAuth2InfoUpdater';
/** @type {?} */
const LOG_TAG = '[MainDashboardSectionComponent]';
let MainDashboardSectionComponent = class MainDashboardSectionComponent {
    /**
     * @param {?} logger
     * @param {?} securityService
     * @param {?} infoService
     */
    constructor(logger, securityService, infoService) {
        this.logger = logger;
        this.securityService = securityService;
        this.infoService = infoService;
        this.motifServerInstanceNameItem = { cols: 8, rows: 2, y: 0, x: 0 };
        this.motifServerInstanceItem = { cols: 8, rows: 3, y: 2, x: 0 };
        this.processLoadGaugeItem = { cols: 3, rows: 3, y: 0, x: 8 };
        this.cpuLoadGaugeItem = { cols: 3, rows: 3, y: 0, x: 11 };
        this.memoryInfoGaugeItem = { cols: 3, rows: 3, y: 2, x: 8 };
        this.memoryInfoItem = { cols: 3, rows: 2, y: 2, x: 8 };
        this.usersInfoItem = { cols: 3, rows: 5, y: 0, x: 14 };
        this.oauth2InfoItem = { cols: 3, rows: 2, y: 0, x: 0 };
        this.diskInfoGaugeItem = { cols: 3, rows: 3, y: 2, x: 8 };
        this.logger.debug(LOG_TAG, 'Opening...');
        this.options = {
            itemChangeCallback: this.itemChange,
            itemResizeCallback: this.itemResize,
            gridType: Gridster.GridType.Fixed,
            compactType: Gridster.CompactType.None,
            draggable: {
                enabled: true
            },
            resizable: {
                enabled: true,
            },
            displayGrid: 'onDrag&Resize',
            minCols: 3,
            maxCols: 100,
            minRows: 3,
            maxRows: 100,
            maxItemCols: 100,
            minItemCols: 1,
            maxItemRows: 100,
            minItemRows: 1,
            maxItemArea: 2500,
            minItemArea: 1,
            defaultItemCols: 1,
            defaultItemRows: 1,
            fixedColWidth: 70,
            fixedRowHeight: 70
        };
    }
    /**
     * Angular ngOnInit
     * @return {?}
     */
    ngOnInit() {
        this.logger.debug(LOG_TAG, 'Initializing...');
        this.statusUpdater = new ServerStatusUpdater(this.logger, this.infoService);
        this.statusUpdater.start(4 * 1000);
        this.infoUpdater = new ServerInfoUpdater(this.logger, this.infoService);
        this.infoUpdater.start(60 * 1000);
        this.usersInfoUpdater = new UsersInfoUpdater(this.logger, this.infoService);
        this.usersInfoUpdater.start(30 * 1000);
        this.oauth2InfoUpdater = new OAuth2InfoUpdater(this.logger, this.infoService);
        this.oauth2InfoUpdater.start(5 * 1000);
    }
    /**
     * @return {?}
     */
    ngOnDestroy() {
        this.logger.debug(LOG_TAG, 'ngOnDestroy ');
        this.freeMem();
    }
    /**
     * @return {?}
     */
    freeMem() {
        this.statusUpdater.stop();
        this.infoUpdater.stop();
        this.usersInfoUpdater.stop();
        this.oauth2InfoUpdater.stop();
    }
    /**
     * @private
     * @param {?} item
     * @param {?} itemComponent
     * @return {?}
     */
    itemChange(item, itemComponent) {
        console.info('itemChanged', item, itemComponent);
    }
    /**
     * @private
     * @param {?} item
     * @param {?} itemComponent
     * @return {?}
     */
    itemResize(item, itemComponent) {
        console.info('itemResized', item, itemComponent);
    }
    /**
     * @return {?}
     */
    get serverStatus() {
        return this.statusUpdater.data;
    }
    /**
     * @return {?}
     */
    get serverInfo() {
        return this.infoUpdater.data;
    }
    /**
     * @return {?}
     */
    get usersInfo() {
        return this.usersInfoUpdater.data;
    }
    /**
     * @return {?}
     */
    get oauth2Info() {
        return this.oauth2InfoUpdater.data;
    }
};
MainDashboardSectionComponent.decorators = [
    { type: Component, args: [{
                selector: 'main-dashboard-section',
                template: "<wc-dashboard-header [title]=\"'Dashboard'\"></wc-dashboard-header>\n\n<div class=\"row fill\">\n\n    <gridster [options]=\"options\">\n\n        <gridster-item [item]=\"motifServerInstanceItem\">\n            <wc-panel [title]=\"'MOTIF Instance'\">\n                <wa-server-info-widget-panel></wa-server-info-widget-panel>\n            </wc-panel>\n        </gridster-item>\n\n        <gridster-item [item]=\"motifServerInstanceItem\">\n            <wc-panel [title]=\"'Current MOTIF Instance'\">\n                <wc-data-counter\n                    [class]=\"'serverInstanceInfo'\" \n                    [title]=\"serverInfo ? serverInfo.motifVersion : 'N/A'\" \n                    [value]=\"serverInfo ? serverInfo.instanceName : 'N/A'\"></wc-data-counter>\n            </wc-panel>\n        </gridster-item>\n\n        <gridster-item [item]=\"processLoadGaugeItem\">\n                <wc-panel [title]=\"'Process CPU Usage'\">\n                    <ngx-gauge [type]=\"'semi'\" \n                        [value]=\"serverStatus.processLoadPerc\" \n                        [label]=\"''\"  \n                        [append]=\"'%'\"\n                        [thick]=\"10\"\n                        [foregroundColor]=\"'#fc0'\"\n                        [cap]=\"'flat'\">\n                    </ngx-gauge>\n                </wc-panel>\n        </gridster-item>\n    \n        <gridster-item [item]=\"cpuLoadGaugeItem\">\n                <wc-panel [title]=\"'System CPU Load'\">\n                    <ngx-gauge [type]=\"'semi'\" \n                        [value]=\"serverStatus.systemLoadPerc\" \n                        [label]=\"''\"  \n                        [append]=\"'%'\"\n                        [thick]=\"10\"\n                        [foregroundColor]=\"'#fc0'\"\n                        [cap]=\"'flat'\">\n                    </ngx-gauge>\n                </wc-panel>\n        </gridster-item>\n\n        <gridster-item [item]=\"memoryInfoGaugeItem\">\n                <wc-panel [title]=\"'Memory - Used Heap'\">\n                    <ngx-gauge [type]=\"'semi'\" \n                        [value]=\"serverStatus.memoryUsage.heapUsedPerc\" \n                        [label]=\"''\"  \n                        [append]=\"'%'\"\n                        [thick]=\"10\"\n                        [foregroundColor]=\"'#fc0'\"\n                        [cap]=\"'flat'\">\n                    </ngx-gauge>\n                </wc-panel>\n        </gridster-item>\n\n        <gridster-item [item]=\"diskInfoGaugeItem\">\n                <wc-panel [title]=\"'Disk - Space Used'\">\n                    <ngx-gauge [type]=\"'semi'\" \n                        [value]=\"serverStatus.diskUsage.diskUsedPerc\" \n                        [label]=\"''\"  \n                        [append]=\"'%'\"\n                        [thick]=\"10\"\n                        [foregroundColor]=\"'#fc0'\"\n                        [cap]=\"'flat'\">\n                    </ngx-gauge>\n                </wc-panel>\n        </gridster-item>\n\n        <gridster-item [item]=\"memoryInfoItem\">\n                <wc-panel [title]=\"'Memory Info'\">\n                    <wa-memory-info-widget-panel [serverStatus]=\"serverStatus\" ></wa-memory-info-widget-panel>\n                </wc-panel>\n        </gridster-item>\n\n        <gridster-item [item]=\"usersInfoItem\">\n                <wc-panel [title]=\"'Users'\">\n                        <wa-users-info-widget-panel [usersInfo]=\"usersInfo\"></wa-users-info-widget-panel>\n                </wc-panel>\n        </gridster-item>\n        \n        <gridster-item [item]=\"oauth2InfoItem\">\n            <wc-panel [title]=\"'OAUTH2'\">\n                <wa-oauth2-info-widget-panel [oauth2Info]=\"oauth2Info\"></wa-oauth2-info-widget-panel>\n            </wc-panel>\n         </gridster-item>\n\n\n    </gridster>\n\n</div>\n",
                styles: [":host{display:flex;flex:1;flex-direction:column}.dashboard-item-label{text-align:center;padding:4px}.dashboard-item-label-primary{font-size:1rem}.dashboard-item-label-secondary{font-size:.8rem}wc-panel .serverInstanceInfo.counter .value{font-size:3rem!important;padding-bottom:20px!important}"]
            }] }
];
/** @nocollapse */
MainDashboardSectionComponent.ctorParameters = () => [
    { type: NGXLogger },
    { type: SecurityService },
    { type: InfoService }
];
MainDashboardSectionComponent = tslib_1.__decorate([
    PluginView('Dashboard', {
        iconName: 'wa-ico-dashboard',
        index: 10,
        userData: {
            acl: {
                permissions: ['com.vipera.osgi.foundation.scheduler.api.rest.InfoApiServiceRestApi:READ:getUsersInfo',
                    'com.vipera.osgi.foundation.scheduler.api.rest.InfoApiServiceRestApi:READ:getSessionsInfo',
                    'com.vipera.osgi.foundation.scheduler.api.rest.InfoApiServiceRestApi:READ:getServerStatus',
                    'com.vipera.osgi.foundation.scheduler.api.rest.InfoApiServiceRestApi:READ:getServerInfo',
                    'com.vipera.osgi.foundation.scheduler.api.rest.InfoApiServiceRestApi:READ:getOAuth2Info',
                    'com.vipera.osgi.foundation.scheduler.api.rest.InfoApiServiceRestApi:READ:getChannelInfo']
            }
        }
    }),
    tslib_1.__metadata("design:paramtypes", [NGXLogger,
        SecurityService,
        InfoService])
], MainDashboardSectionComponent);
export { MainDashboardSectionComponent };
if (false) {
    /** @type {?} */
    MainDashboardSectionComponent.prototype.model;
    /** @type {?} */
    MainDashboardSectionComponent.prototype.options;
    /**
     * @type {?}
     * @private
     */
    MainDashboardSectionComponent.prototype.statusUpdater;
    /**
     * @type {?}
     * @private
     */
    MainDashboardSectionComponent.prototype.infoUpdater;
    /**
     * @type {?}
     * @private
     */
    MainDashboardSectionComponent.prototype.usersInfoUpdater;
    /**
     * @type {?}
     * @private
     */
    MainDashboardSectionComponent.prototype.oauth2InfoUpdater;
    /**
     * @type {?}
     * @private
     */
    MainDashboardSectionComponent.prototype.refreshInterval;
    /** @type {?} */
    MainDashboardSectionComponent.prototype.motifServerInstanceNameItem;
    /** @type {?} */
    MainDashboardSectionComponent.prototype.motifServerInstanceItem;
    /** @type {?} */
    MainDashboardSectionComponent.prototype.processLoadGaugeItem;
    /** @type {?} */
    MainDashboardSectionComponent.prototype.cpuLoadGaugeItem;
    /** @type {?} */
    MainDashboardSectionComponent.prototype.memoryInfoGaugeItem;
    /** @type {?} */
    MainDashboardSectionComponent.prototype.memoryInfoItem;
    /** @type {?} */
    MainDashboardSectionComponent.prototype.usersInfoItem;
    /** @type {?} */
    MainDashboardSectionComponent.prototype.oauth2InfoItem;
    /** @type {?} */
    MainDashboardSectionComponent.prototype.diskInfoGaugeItem;
    /**
     * @type {?}
     * @private
     */
    MainDashboardSectionComponent.prototype.logger;
    /**
     * @type {?}
     * @private
     */
    MainDashboardSectionComponent.prototype.securityService;
    /**
     * @type {?}
     * @private
     */
    MainDashboardSectionComponent.prototype.infoService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"main-dashboard-section-component.js","sourceRoot":"ng://motif-web-admin-core/","sources":["lib/sections/MainDashboard/components/main-dashboard-section-component.ts"],"names":[],"mappings":"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","sourcesContent":["import { UsersInfoUpdater } from './../data/updaters/UsersInfoUpdater';\nimport { Subscription } from 'rxjs';\nimport { DashboardModel } from './../data/dashboard-model';\nimport { Component, OnInit, OnDestroy, ViewChild } from '@angular/core';\nimport { PluginView } from 'web-console-core';\nimport { NGXLogger} from 'web-console-core';\nimport { Gridster } from 'web-console-ui-kit'\nimport { SecurityService, Session } from '@wa-motif-open-api/security-service'\nimport { interval } from 'rxjs';\nimport { InfoService, ServerInfo, ServerStatus, UsersInfo, OAuth2Info } from '@wa-motif-open-api/info-service'\nimport { ServerStatusUpdater } from '../data/updaters/ServerInfo/ServerStatusUpdater';\nimport { ServerInfoUpdater } from '../data/updaters/ServerInfo/ServerInfoUpdater';\nimport { OAuth2InfoUpdater } from '../data/updaters/OAuth2InfoUpdater';\n\nconst LOG_TAG = '[MainDashboardSectionComponent]';\n\n\n@Component({\n    selector: 'main-dashboard-section',\n    styleUrls: [ './main-dashboard-section-component.scss' ],\n    templateUrl: './main-dashboard-section-component.html'\n  })\n  @PluginView('Dashboard', {\n    iconName: 'wa-ico-dashboard',\n    index: 10,\n    userData: {\n        acl: {\n            permissions: ['com.vipera.osgi.foundation.scheduler.api.rest.InfoApiServiceRestApi:READ:getUsersInfo',\n                          'com.vipera.osgi.foundation.scheduler.api.rest.InfoApiServiceRestApi:READ:getSessionsInfo',\n                          'com.vipera.osgi.foundation.scheduler.api.rest.InfoApiServiceRestApi:READ:getServerStatus',\n                          'com.vipera.osgi.foundation.scheduler.api.rest.InfoApiServiceRestApi:READ:getServerInfo',\n                          'com.vipera.osgi.foundation.scheduler.api.rest.InfoApiServiceRestApi:READ:getOAuth2Info',\n                          'com.vipera.osgi.foundation.scheduler.api.rest.InfoApiServiceRestApi:READ:getChannelInfo']\n        }\n    }\n})\nexport class MainDashboardSectionComponent implements OnInit, OnDestroy {\n\n    model: DashboardModel;\n\n    options: Gridster.GridsterConfig;\n\n    private statusUpdater:ServerStatusUpdater;\n    private infoUpdater:ServerInfoUpdater;\n    private usersInfoUpdater: UsersInfoUpdater;\n    private oauth2InfoUpdater: OAuth2InfoUpdater;\n\n    private refreshInterval: any;\n    \n    constructor(private logger: NGXLogger,\n        private securityService: SecurityService,\n        private infoService: InfoService\n        ) {\n        this.logger.debug(LOG_TAG , 'Opening...');\n        \n        \n        this.options = {\n            itemChangeCallback: this.itemChange,\n            itemResizeCallback: this.itemResize,\n            gridType: Gridster.GridType.Fixed,\n            compactType: Gridster.CompactType.None,\n            draggable: {\n              enabled: true\n            },\n            resizable: {\n              enabled: true,\n            },\n            displayGrid: 'onDrag&Resize',\n            minCols: 3,\n            maxCols: 100,\n            minRows: 3,\n            maxRows: 100,\n            maxItemCols: 100,\n            minItemCols: 1,\n            maxItemRows: 100,\n            minItemRows: 1,\n            maxItemArea: 2500,\n            minItemArea: 1,\n            defaultItemCols: 1,\n            defaultItemRows: 1,\n            fixedColWidth: 70,\n            fixedRowHeight: 70\n          };\n    }\n\n    motifServerInstanceNameItem:Gridster.GridsterItem = {cols: 8, rows: 2, y: 0, x: 0};\n    motifServerInstanceItem:Gridster.GridsterItem = {cols: 8, rows: 3, y: 2, x: 0};\n    processLoadGaugeItem:Gridster.GridsterItem = {cols: 3, rows: 3, y: 0, x: 8};\n    cpuLoadGaugeItem:Gridster.GridsterItem = {cols: 3, rows: 3, y: 0, x: 11};\n    memoryInfoGaugeItem:Gridster.GridsterItem = {cols: 3, rows: 3, y: 2, x: 8 };\n    memoryInfoItem:Gridster.GridsterItem = {cols: 3, rows: 2, y: 2, x: 8 };\n    usersInfoItem:Gridster.GridsterItem = {cols: 3, rows: 5, y: 0, x: 14 };\n    oauth2InfoItem:Gridster.GridsterItem = {cols: 3, rows: 2, y: 0, x: 0 };\n    diskInfoGaugeItem:Gridster.GridsterItem = {cols: 3, rows: 3, y: 2, x: 8 };\n    \n    /**\n     * Angular ngOnInit\n     */\n    ngOnInit() {\n        this.logger.debug(LOG_TAG , 'Initializing...');\n        this.statusUpdater = new ServerStatusUpdater(this.logger, this.infoService);\n        this.statusUpdater.start(4 * 1000);\n\n        this.infoUpdater = new ServerInfoUpdater(this.logger, this.infoService);\n        this.infoUpdater.start(60 * 1000);\n\n        this.usersInfoUpdater =  new UsersInfoUpdater(this.logger, this.infoService);\n        this.usersInfoUpdater.start(30 * 1000);\n\n        this.oauth2InfoUpdater = new OAuth2InfoUpdater(this.logger, this.infoService);\n        this.oauth2InfoUpdater.start(5 * 1000);\n    }\n\n    ngOnDestroy() {\n        this.logger.debug(LOG_TAG , 'ngOnDestroy ');\n        this.freeMem();\n    }\n\n    freeMem() {\n        this.statusUpdater.stop();\n        this.infoUpdater.stop();\n        this.usersInfoUpdater.stop();\n        this.oauth2InfoUpdater.stop();\n      }\n\n\n    private itemChange(item, itemComponent) {\n        console.info('itemChanged', item, itemComponent);\n    }\n\n    private itemResize(item, itemComponent) {\n        console.info('itemResized', item, itemComponent);\n    }\n\n    public get serverStatus(): any {\n      return this.statusUpdater.data;\n    }\n\n    public get serverInfo(): any {\n      return this.infoUpdater.data;\n    }\n\n    public get usersInfo(): UsersInfo {\n      return this.usersInfoUpdater.data;\n    }\n\n    public get oauth2Info(): OAuth2Info {\n      return this.oauth2InfoUpdater.data;\n    } \n\n}\n"]}