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 

/ esm5 / lib / sections / CountersAndThresholds / components / thresholds / thresholds-component.js

/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
 */
import { Component, EventEmitter, Output, Input } from '@angular/core';
import { NGXLogger } from 'web-console-core';
import { WCNotificationCenter, NotificationType } from 'web-console-ui-kit';
import { CountersService } from '@wa-motif-open-api/counters-thresholds-service';
import { WCSubscriptionHandler } from '../../../../components/Commons/wc-subscription-handler';
import { ThresholdsInfosModel } from './data/model';
import { faEdit } from '@fortawesome/free-solid-svg-icons';
/** @type {?} */
var LOG_TAG = '[ThresholdsComponent]';
/**
 * @record
 */
export function SelectionEvent() { }
if (false) {
    /** @type {?} */
    SelectionEvent.prototype.thresholdName;
    /** @type {?} */
    SelectionEvent.prototype.data;
}
/** @enum {string} */
var EditType = {
    Delete: 'Delete',
    Edit: 'Edit',
    StatusChange: 'StatusChange',
};
export { EditType };
/**
 * @record
 */
export function EditEvent() { }
if (false) {
    /** @type {?} */
    EditEvent.prototype.editType;
    /** @type {?} */
    EditEvent.prototype.dataItem;
}
var ThresholdsComponent = /** @class */ (function () {
    function ThresholdsComponent(logger, notificationCenter, countersService) {
        this.logger = logger;
        this.notificationCenter = notificationCenter;
        this.countersService = countersService;
        this.loading = false;
        this._subHandler = new WCSubscriptionHandler();
        this.faEdit = faEdit;
        this.selectionChange = new EventEmitter();
        this.edit = new EventEmitter();
        this.statusConfirmationTitleProvider = {
            getTitle: /**
             * @param {?} rowData
             * @return {?}
             */
            function (rowData) {
                if (rowData.enabled) {
                    return "Disable ?";
                }
                else {
                    return "Enable ?";
                }
            }
        };
        this.commands = [
            {
                commandIcon: 'wa-ico-edit',
                commandId: EditType.Edit,
                title: 'Edit'
            },
            {
                commandIcon: 'wa-ico-no',
                commandId: EditType.Delete,
                title: 'Delete',
                hasConfirmation: true,
                confirmationTitle: 'Delete ?'
            }
        ];
        this.tableModel = new ThresholdsInfosModel();
    }
    /**
     * @return {?}
     */
    ThresholdsComponent.prototype.ngOnInit = /**
     * @return {?}
     */
    function () {
        this.reloadData();
    };
    /**
     * @return {?}
     */
    ThresholdsComponent.prototype.ngOnDestroy = /**
     * @return {?}
     */
    function () {
        this.logger.debug(LOG_TAG, 'ngOnDestroy ');
        this.freeMem();
    };
    /**
     * @return {?}
     */
    ThresholdsComponent.prototype.freeMem = /**
     * @return {?}
     */
    function () {
        this.tableModel.close();
    };
    /**
     * @return {?}
     */
    ThresholdsComponent.prototype.reloadData = /**
     * @return {?}
     */
    function () {
        var _this = this;
        this.logger.debug(LOG_TAG, 'reloadData called');
        this.loading = true;
        if (this._counterInfo) {
            this._subHandler.add(this.countersService.getThresholdInfoList(this._counterInfo).subscribe((/**
             * @param {?} data
             * @return {?}
             */
            function (data) {
                _this.logger.debug(LOG_TAG, 'getThresholdInfoList done: ', data);
                _this.tableModel.loadData(data);
                _this.loading = false;
                _this.clearSelection();
            }), (/**
             * @param {?} error
             * @return {?}
             */
            function (error) {
                _this.logger.error(LOG_TAG, 'getThresholdInfoList error: ', error);
                _this.notificationCenter.post({
                    name: 'GetThresholdsListError',
                    title: 'Get Thresholds List',
                    message: 'Error getting thresholds list:',
                    type: NotificationType.Error,
                    error: error,
                    closable: true
                });
                _this.clearSelection();
                _this.loading = false;
            })));
        }
        else {
            this.tableModel.close();
            this.loading = false;
            this.clearSelection();
        }
    };
    /**
     * @private
     * @return {?}
     */
    ThresholdsComponent.prototype.clearSelection = /**
     * @private
     * @return {?}
     */
    function () {
        this.selectedThreshold = null;
        this.selectionChange.emit({
            thresholdName: this.selectedThreshold,
            data: null
        });
    };
    Object.defineProperty(ThresholdsComponent.prototype, "counterInfo", {
        get: /**
         * @return {?}
         */
        function () {
            return this._counterInfo;
        },
        set: /**
         * @param {?} counterInfo
         * @return {?}
         */
        function (counterInfo) {
            this.logger.debug(LOG_TAG, 'set counterInfo:', counterInfo);
            this._counterInfo = counterInfo;
            this.reloadData();
        },
        enumerable: true,
        configurable: true
    });
    /**
     * @param {?} dataItem
     * @return {?}
     */
    ThresholdsComponent.prototype.onStatusTogglePressed = /**
     * @param {?} dataItem
     * @return {?}
     */
    function (dataItem) {
        this.logger.debug(LOG_TAG, 'onStatusTogglePressed dataItem: ', dataItem);
        this.edit.emit({
            editType: EditType.StatusChange,
            dataItem: dataItem
        });
    };
    /**
     * @param {?} event
     * @return {?}
     */
    ThresholdsComponent.prototype.onCommandConfirm = /**
     * @param {?} event
     * @return {?}
     */
    function (event) {
        this.logger.debug(LOG_TAG, 'onCommandConfirm event: ', event);
        this.edit.emit({
            editType: EditType[event.id],
            dataItem: event.rowData.dataItem
        });
    };
    /**
     * @param {?} event
     * @return {?}
     */
    ThresholdsComponent.prototype.onCommandClick = /**
     * @param {?} event
     * @return {?}
     */
    function (event) {
        this.logger.debug(LOG_TAG, 'onCommandClick event: ', event);
        this.edit.emit({
            editType: EditType[event.id],
            dataItem: event.rowData.dataItem
        });
    };
    /**
     * @param {?} event
     * @return {?}
     */
    ThresholdsComponent.prototype.onSelectionChange = /**
     * @param {?} event
     * @return {?}
     */
    function (event) {
        this.logger.debug(LOG_TAG, 'onSelectionChange event: ', event);
        /** @type {?} */
        var data = null;
        if (event.selectedRows.length > 0) {
            this.selectedThreshold = event.selectedRows[0].dataItem.name;
            data = event.selectedRows[0].dataItem;
        }
        else {
            this.selectedThreshold = null;
        }
        this.selectionChange.emit({
            thresholdName: this.selectedThreshold,
            data: data
        });
    };
    ThresholdsComponent.decorators = [
        { type: Component, args: [{
                    // tslint:disable-next-line:component-selector
                    selector: 'wa-threshols-component',
                    template: "<wc-loading-overlay [visible]='loading'></wc-loading-overlay>\n\n<kendo-grid #datagrid [data]=\"tableModel.data\" (selectionChange)=\"onSelectionChange($event)\">\n  <kendo-grid-column field=\"name\" title=\"Name\" width=\"150\"> </kendo-grid-column>\n\n  <kendo-grid-column field=\"description\" title=\"Description\">\n  </kendo-grid-column>\n\n  <kendo-grid-column\n    field=\"created\"\n    title=\"Created\"\n    width=\"150\"\n    format=\"{0:dd/MM/yyyy HH:mm:ss}\"\n  >\n  </kendo-grid-column>\n\n  <kendo-grid-column field=\"enabled\" title=\"Status\">\n    <ng-template\n      kendoGridCellTemplate\n      let-dataItem\n      let-columnIndex=\"columnIndex\"\n      let-rowIndex=\"rowIndex\"\n      let-column=\"column\"\n    >\n    <wc-grid-editor-command\n    [motif-acl]=\"['com.vipera.osgi.bss.countersthresholds.api.rest.CountersThresholdsApi:CREATE:enableThresholdInfo', \n                  'com.vipera.osgi.bss.countersthresholds.api.rest.CountersThresholdsApi:DELETE:disableThresholdInfo']\"\n    [rowIndex]=\"rowIndex\" \n    [hasConfirmation]=\"true\"\n    [confirmationTitleProvider]=\"statusConfirmationTitleProvider\"\n    [columnIndex]=\"columnIndex\" \n    [column]=\"column\" \n    [value]=\"dataItem[column.field]\" \n    [dataItem]=\"dataItem\"\n    (commandConfirm)=\"onStatusTogglePressed(dataItem)\"  \n    >\n    <span *ngIf=\"dataItem.enabled\" class=\"badge badge-status badge-enabled\">\n            ENABLED\n        </span>\n        <span *ngIf=\"!dataItem.enabled\" class=\"badge badge-status  badge-disabled\">\n                DISABLED\n        </span>\n    </wc-grid-editor-command>\n\n  </ng-template>\n  </kendo-grid-column>\n\n  <kendo-grid-column media=\"(min-width: 80px)\" title=\"Deny\" width=\"80\">\n                <ng-template kendoGridCellTemplate let-dataItem>\n                  <label\n                    class=\"k-icon grid-cell-checkbox grid-cell-checkbox-{{\n                      dataItem.deny\n                    }}\"\n                  ></label>\n                </ng-template>\n              </kendo-grid-column>\n\n              <kendo-grid-column media=\"(min-width: 80px)\" title=\"Type\" width=\"80\">\n                        <ng-template kendoGridCellTemplate let-dataItem>\n                          <label>{{dataItem.type}}</label>\n                        </ng-template>\n                      </kendo-grid-column>\n        \n\n  <kendo-grid-column title=\"\">\n    <ng-template\n      kendoGridCellTemplate\n      let-dataItem\n      let-columnIndex=\"columnIndex\"\n      let-rowIndex=\"rowIndex\"\n      let-column=\"column\"\n    >\n      <wc-grid-editor-commands-group\n      [motif-acl]=\"['com.vipera.osgi.bss.countersthresholds.api.rest.CountersThresholdsApi:UPDATE:updateThresholdInfo',\n                    'com.vipera.osgi.bss.countersthresholds.api.rest.CountersThresholdsApi:DELETE:deleteThresholdInfo']\"\n      motif-acl-hidden=\"true\"\n      [rowIndex]=\"rowIndex\"\n      [columnIndex]=\"columnIndex\" \n      [column]=\"column\" \n      [value]=\"dataItem[column.field]\" \n      [dataItem]=\"dataItem\"\n      [commands]=\"commands\"\n        [alignMode]=\"'end'\"\n        (commandConfirm)=\"onCommandConfirm($event)\"\n        (commandClick)=\"onCommandClick($event)\"\n></wc-grid-editor-commands-group>\n    </ng-template>\n  </kendo-grid-column>\n\n  <div *kendoGridDetailTemplate=\"let dataItem\">\n                <wa-threshold-details [dataItem]=\"dataItem\"></wa-threshold-details>\n  </div>\n    \n\n</kendo-grid>\n",
                    styles: [".badge{border-radius:4px;display:inline-block;padding:1px 7px}.badge-status{cursor:pointer;text-decoration:none;font-size:.63rem;line-height:1.3;font-weight:700;padding:3px 7px;text-align:center;vertical-align:baseline;white-space:nowrap}.badge-enabled{background-color:green;color:#fff}.badge-disabled{background-color:gray;color:#454545}.counter-info-row-details{padding:0}.counter-info-row-details p{margin:0;padding:.1rem 0;color:#595959}.counter-info-row-details p a{color:#539653;margin-left:10px}"]
                }] }
    ];
    /** @nocollapse */
    ThresholdsComponent.ctorParameters = function () { return [
        { type: NGXLogger },
        { type: WCNotificationCenter },
        { type: CountersService }
    ]; };
    ThresholdsComponent.propDecorators = {
        selectionChange: [{ type: Output }],
        edit: [{ type: Output }],
        counterInfo: [{ type: Input }]
    };
    return ThresholdsComponent;
}());
export { ThresholdsComponent };
if (false) {
    /** @type {?} */
    ThresholdsComponent.prototype.loading;
    /**
     * @type {?}
     * @private
     */
    ThresholdsComponent.prototype._subHandler;
    /** @type {?} */
    ThresholdsComponent.prototype.tableModel;
    /** @type {?} */
    ThresholdsComponent.prototype.faEdit;
    /**
     * @type {?}
     * @private
     */
    ThresholdsComponent.prototype._counterInfo;
    /** @type {?} */
    ThresholdsComponent.prototype.selectedThreshold;
    /** @type {?} */
    ThresholdsComponent.prototype.selectionChange;
    /** @type {?} */
    ThresholdsComponent.prototype.edit;
    /** @type {?} */
    ThresholdsComponent.prototype.statusConfirmationTitleProvider;
    /** @type {?} */
    ThresholdsComponent.prototype.commands;
    /**
     * @type {?}
     * @private
     */
    ThresholdsComponent.prototype.logger;
    /**
     * @type {?}
     * @private
     */
    ThresholdsComponent.prototype.notificationCenter;
    /**
     * @type {?}
     * @private
     */
    ThresholdsComponent.prototype.countersService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"thresholds-component.js","sourceRoot":"ng://motif-web-admin-core/","sources":["lib/sections/CountersAndThresholds/components/thresholds/thresholds-component.ts"],"names":[],"mappings":"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","sourcesContent":["import { WCGridEditorCommandsConfig, WCGridEditorCommandComponentEvent, WCConfirmationTitleProvider  } from 'web-console-ui-kit';\nimport { Component, OnInit, OnDestroy, EventEmitter, Output, Input } from '@angular/core';\nimport { NGXLogger} from 'web-console-core';\nimport { WCNotificationCenter, NotificationType } from 'web-console-ui-kit';\nimport { CountersService, ThresholdInfoEntity } from '@wa-motif-open-api/counters-thresholds-service';\nimport { WCSubscriptionHandler } from '../../../../components/Commons/wc-subscription-handler';\nimport { ThresholdsInfosModel } from './data/model'; \nimport { faEdit } from '@fortawesome/free-solid-svg-icons';\n\nconst LOG_TAG = '[ThresholdsComponent]';\n\nexport interface SelectionEvent {\n    thresholdName: string;\n    data: any\n}\n\nexport enum EditType {\n    Delete = 'Delete',\n    Edit = 'Edit',\n    StatusChange = 'StatusChange'\n}\n\nexport interface EditEvent {\n    editType: EditType\n    dataItem: ThresholdInfoEntity;\n}\n\n@Component({\n    // tslint:disable-next-line:component-selector\n    selector: 'wa-threshols-component',\n    styleUrls: ['./thresholds-component.scss'],\n    templateUrl: './thresholds-component.html'\n})\nexport class ThresholdsComponent implements OnInit, OnDestroy {\n\n\n    loading = false;\n    private _subHandler: WCSubscriptionHandler = new WCSubscriptionHandler();\n    public tableModel: ThresholdsInfosModel;\n    faEdit = faEdit;\n    private _counterInfo: string;\n    selectedThreshold: string;\n\n    @Output() selectionChange : EventEmitter<SelectionEvent> = new EventEmitter();\n    @Output() edit: EventEmitter<EditEvent> = new EventEmitter<EditEvent>();\n\n    statusConfirmationTitleProvider: WCConfirmationTitleProvider = {\n        getTitle(rowData): string {\n            if (rowData.enabled){\n                return \"Disable ?\";\n            } else {\n                return \"Enable ?\";\n            }\n        }\n    }\n    \n    commands: WCGridEditorCommandsConfig = [\n        { \n            commandIcon: 'wa-ico-edit',\n            commandId: EditType.Edit,\n            title: 'Edit'\n        },\n        { \n            commandIcon: 'wa-ico-no',\n            commandId: EditType.Delete,\n            title: 'Delete',\n            hasConfirmation: true,\n            confirmationTitle: 'Delete ?' \n        }\n    ];\n    \n    constructor(\n        private logger: NGXLogger,\n        private notificationCenter: WCNotificationCenter,\n        private countersService: CountersService\n    ) {\n        this.tableModel = new ThresholdsInfosModel();\n    }\n\n    ngOnInit() {\n        this.reloadData();\n    }\n\n    ngOnDestroy() {\n        this.logger.debug(LOG_TAG , 'ngOnDestroy ');\n        this.freeMem();\n    }\n\n    freeMem() {\n        this.tableModel.close();\n    }\n\n    reloadData() {\n        this.logger.debug(LOG_TAG, 'reloadData called');\n        this.loading = true;\n        if (this._counterInfo){\n            this._subHandler.add(this.countersService.getThresholdInfoList(this._counterInfo).subscribe( (data: Array<ThresholdInfoEntity>) => {\n                this.logger.debug(LOG_TAG, 'getThresholdInfoList done: ', data);\n                this.tableModel.loadData(data);\n                this.loading = false;\n                this.clearSelection();\n            }, (error) => {\n                this.logger.error(LOG_TAG, 'getThresholdInfoList error: ', error);\n                this.notificationCenter.post({\n                    name: 'GetThresholdsListError',\n                    title: 'Get Thresholds List',\n                    message: 'Error getting thresholds list:',\n                    type: NotificationType.Error,\n                    error: error,\n                    closable: true\n                });\n                this.clearSelection();\n                this.loading = false;\n            }));\n        } else {\n            this.tableModel.close();\n            this.loading = false;\n            this.clearSelection();\n        }\n\n    }\n\n    private clearSelection(){\n        this.selectedThreshold = null;\n        this.selectionChange.emit({\n            thresholdName: this.selectedThreshold,\n            data: null\n        });\n    }\n\n    @Input() public set counterInfo(counterInfo: string) {\n        this.logger.debug(LOG_TAG, 'set counterInfo:', counterInfo);\n        this._counterInfo = counterInfo;\n        this.reloadData();\n    }\n\n    public get counterInfo(): string {\n        return this._counterInfo;\n    }\n\n    onStatusTogglePressed(dataItem): void {\n        this.logger.debug(LOG_TAG, 'onStatusTogglePressed dataItem: ', dataItem);\n        this.edit.emit({\n            editType: EditType.StatusChange,\n            dataItem: dataItem\n        })\n    }\n\n    onCommandConfirm(event: WCGridEditorCommandComponentEvent) {\n        this.logger.debug(LOG_TAG, 'onCommandConfirm event: ', event);\n        this.edit.emit({\n            editType: EditType[event.id],\n            dataItem: event.rowData.dataItem\n        })\n    }\n\n    onCommandClick(event: WCGridEditorCommandComponentEvent){\n        this.logger.debug(LOG_TAG, 'onCommandClick event: ', event);\n        this.edit.emit({\n            editType: EditType[event.id],\n            dataItem: event.rowData.dataItem\n        })\n    }\n\n    onSelectionChange(event) {\n        this.logger.debug(LOG_TAG, 'onSelectionChange event: ', event);\n        let data = null;\n        if (event.selectedRows.length>0){\n            this.selectedThreshold = event.selectedRows[0].dataItem.name;\n            data = event.selectedRows[0].dataItem;\n        } else {\n            this.selectedThreshold = null;\n        }\n        this.selectionChange.emit({\n            thresholdName: this.selectedThreshold,\n            data: data\n        });\n    }\n\n}\n"]}