Repository URL to install this package:
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, EventEmitter, Output } 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 { CounterInfosModel } from './data/model';
import { faEdit } from '@fortawesome/free-solid-svg-icons';
/** @type {?} */
var LOG_TAG = '[CounterInfosComponent]';
/**
* @record
*/
export function SelectionEvent() { }
if (false) {
/** @type {?} */
SelectionEvent.prototype.counterInfoName;
/** @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 CounterInfosComponent = /** @class */ (function () {
function CounterInfosComponent(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.selectableSettings = {
mode: 'single',
enabled: true,
checkboxOnly: false
};
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 ?'
}
];
}
/**
* @return {?}
*/
CounterInfosComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.tableModel = new CounterInfosModel();
this.reloadData();
};
/**
* @return {?}
*/
CounterInfosComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.logger.debug(LOG_TAG, 'ngOnDestroy ');
this.freeMem();
};
/**
* @return {?}
*/
CounterInfosComponent.prototype.freeMem = /**
* @return {?}
*/
function () {
this.tableModel.close();
};
/**
* @return {?}
*/
CounterInfosComponent.prototype.reloadData = /**
* @return {?}
*/
function () {
var _this = this;
this.logger.debug(LOG_TAG, 'reloadData called');
this.loading = true;
this._subHandler.add(this.countersService.getCounterInfoList().subscribe((/**
* @param {?} data
* @return {?}
*/
function (data) {
_this.logger.debug(LOG_TAG, 'getCounterInfoList done: ', data);
_this.tableModel.loadData(data);
_this.clearSelection();
_this.loading = false;
}), (/**
* @param {?} error
* @return {?}
*/
function (error) {
_this.logger.error(LOG_TAG, 'getCounterInfoList error: ', error);
_this.notificationCenter.post({
name: 'GetCounterInfosError',
title: 'Get Counter Infos',
message: 'Error getting counter infos:',
type: NotificationType.Error,
error: error,
closable: true
});
_this.clearSelection();
_this.loading = false;
})));
};
/**
* @param {?} event
* @return {?}
*/
CounterInfosComponent.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.selectedCounterInfo = event.selectedRows[0].dataItem.name;
data = event.selectedRows[0].dataItem;
}
else {
this.selectedCounterInfo = null;
}
this.selectionChange.emit({
counterInfoName: this.selectedCounterInfo,
data: data
});
};
/**
* @private
* @return {?}
*/
CounterInfosComponent.prototype.clearSelection = /**
* @private
* @return {?}
*/
function () {
this.selectedCounterInfo = null;
this.selectionChange.emit({
counterInfoName: this.selectedCounterInfo,
data: null
});
};
/**
* @param {?} dataItem
* @return {?}
*/
CounterInfosComponent.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 {?}
*/
CounterInfosComponent.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 {?}
*/
CounterInfosComponent.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
});
};
CounterInfosComponent.decorators = [
{ type: Component, args: [{
// tslint:disable-next-line:component-selector
selector: 'wa-counter-infos-component',
template: "<wc-loading-overlay [visible]='loading'></wc-loading-overlay>\n\n<kendo-grid #datagrid [data]=\"tableModel.data\" [selectable]=\"selectableSettings\" (selectionChange)=\"onSelectionChange($event)\"\n style=\"height: 70%;\">\n\n <kendo-grid-column field=\"name\" title=\"Name\" width=\"150\">\n </kendo-grid-column>\n\n <kendo-grid-column field=\"description\" title=\"Description\">\n </kendo-grid-column>\n\n <kendo-grid-column field=\"pattern\" title=\"Pattern\">\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 kendoGridCellTemplate let-dataItem let-columnIndex=\"columnIndex\" let-rowIndex=\"rowIndex\" let-column=\"column\">\n <wc-grid-editor-command\n [motif-acl]=\"['com.vipera.osgi.bss.countersthresholds.api.rest.CountersThresholdsApi:CREATE:enableCounterInfo', \n 'com.vipera.osgi.bss.countersthresholds.api.rest.CountersThresholdsApi:DELETE:disableCounterInfo']\"\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 </ng-template>\n</kendo-grid-column>\n\n <kendo-grid-column title=\"\">\n <ng-template kendoGridCellTemplate let-dataItem let-columnIndex=\"columnIndex\" let-rowIndex=\"rowIndex\" let-column=\"column\">\n <wc-grid-editor-commands-group\n [motif-acl]=\"['com.vipera.osgi.bss.countersthresholds.api.rest.CountersThresholdsApi:UPDATE:updateCounterInfo',\n 'com.vipera.osgi.bss.countersthresholds.api.rest.CountersThresholdsApi:DELETE:deleteCounterInfo']\"\n motif-acl-hidden=\"true\"\n [commands]=\"commands\" \n [alignMode]=\"'end'\" \n [rowIndex]=\"rowIndex\"\n [columnIndex]=\"columnIndex\" \n [column]=\"column\" \n [value]=\"dataItem[column.field]\" \n [dataItem]=\"dataItem\"\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-counter-info-details [dataItem]=\"dataItem\"></wa-counter-info-details>\n </div>\n\n</kendo-grid>\n\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}.counter-info-row-details{padding:0}.counter-info-row-details p{margin:0;padding:.1rem 0}.counter-info-row-details p a{margin-left:10px}"]
}] }
];
/** @nocollapse */
CounterInfosComponent.ctorParameters = function () { return [
{ type: NGXLogger },
{ type: WCNotificationCenter },
{ type: CountersService }
]; };
CounterInfosComponent.propDecorators = {
selectionChange: [{ type: Output }],
edit: [{ type: Output }]
};
return CounterInfosComponent;
}());
export { CounterInfosComponent };
if (false) {
/** @type {?} */
CounterInfosComponent.prototype.loading;
/**
* @type {?}
* @private
*/
CounterInfosComponent.prototype._subHandler;
/** @type {?} */
CounterInfosComponent.prototype.tableModel;
/** @type {?} */
CounterInfosComponent.prototype.faEdit;
/** @type {?} */
CounterInfosComponent.prototype.selectedCounterInfo;
/** @type {?} */
CounterInfosComponent.prototype.selectionChange;
/** @type {?} */
CounterInfosComponent.prototype.edit;
/** @type {?} */
CounterInfosComponent.prototype.selectableSettings;
/** @type {?} */
CounterInfosComponent.prototype.statusConfirmationTitleProvider;
/** @type {?} */
CounterInfosComponent.prototype.commands;
/**
* @type {?}
* @private
*/
CounterInfosComponent.prototype.logger;
/**
* @type {?}
* @private
*/
CounterInfosComponent.prototype.notificationCenter;
/**
* @type {?}
* @private
*/
CounterInfosComponent.prototype.countersService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"counter-infos-component.js","sourceRoot":"ng://motif-web-admin-core/","sources":["lib/sections/CountersAndThresholds/components/counter-infos/counter-infos-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, CounterInfoEntity } from '@wa-motif-open-api/counters-thresholds-service';\nimport { WCSubscriptionHandler } from '../../../../components/Commons/wc-subscription-handler';\nimport { CounterInfosModel } from './data/model';\nimport { faEdit } from '@fortawesome/free-solid-svg-icons';\nimport { SelectableSettings } from '@progress/kendo-angular-grid';\n\nexport { CounterInfoEntity }  from '@wa-motif-open-api/counters-thresholds-service';\n\nconst LOG_TAG = '[CounterInfosComponent]';\n\nexport interface SelectionEvent {\n    counterInfoName: 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: CounterInfoEntity;\n}\n\n@Component({\n    // tslint:disable-next-line:component-selector\n    selector: 'wa-counter-infos-component',\n    styleUrls: ['./counter-infos-component.scss'],\n    templateUrl: './counter-infos-component.html'\n})\nexport class CounterInfosComponent implements OnInit, OnDestroy {\n\n    loading = false;\n    private _subHandler: WCSubscriptionHandler = new WCSubscriptionHandler();\n    public tableModel: CounterInfosModel;\n    faEdit = faEdit;\n    selectedCounterInfo: string;\n\n    @Output() selectionChange : EventEmitter<SelectionEvent> = new EventEmitter();\n    @Output() edit: EventEmitter<EditEvent> = new EventEmitter<EditEvent>();\n\n    public selectableSettings: SelectableSettings = {\n        mode: 'single',\n        enabled: true,\n        checkboxOnly: false\n    }   \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\n    ngOnInit() {\n        this.tableModel = new CounterInfosModel();\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        this._subHandler.add(this.countersService.getCounterInfoList().subscribe( (data: Array<CounterInfoEntity>) => {\n            this.logger.debug(LOG_TAG, 'getCounterInfoList done: ', data);\n            this.tableModel.loadData(data);\n            this.clearSelection();\n            this.loading = false;\n        }, (error) => {\n            this.logger.error(LOG_TAG, 'getCounterInfoList error: ', error);\n            this.notificationCenter.post({\n                name: 'GetCounterInfosError',\n                title: 'Get Counter Infos',\n                message: 'Error getting counter infos:',\n                type: NotificationType.Error,\n                error: error,\n                closable: true\n            });\n            this.clearSelection();\n            this.loading = false;\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.selectedCounterInfo = event.selectedRows[0].dataItem.name;\n            data = event.selectedRows[0].dataItem;\n        } else {\n            this.selectedCounterInfo = null;\n        }\n        this.selectionChange.emit({\n            counterInfoName: this.selectedCounterInfo,\n            data: data\n        });\n    }\n\n    private clearSelection(){\n        this.selectedCounterInfo = null;\n        this.selectionChange.emit({\n            counterInfoName: this.selectedCounterInfo,\n            data: null\n        });\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\n}\n \n"]}