diff options
Diffstat (limited to 'sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module')
8 files changed, 357 insertions, 0 deletions
diff --git a/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/pom.xml b/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/pom.xml new file mode 100644 index 00000000..72264b86 --- /dev/null +++ b/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/pom.xml @@ -0,0 +1,14 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project + xmlns="http://maven.apache.org/POM/4.0.0" + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> + <modelVersion>4.0.0</modelVersion> + <parent> + <artifactId>mwtnLog</artifactId> + <groupId>com.highstreet.technologies.odl.dlux</groupId> + <version>0.5.1-SNAPSHOT</version> + </parent> + <artifactId>mwtnLog-module</artifactId> + <name>${prefix} ${project.artifactId}</name> + <packaging>jar</packaging> +</project>
\ No newline at end of file diff --git a/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/images/mwtnLog.png b/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/images/mwtnLog.png Binary files differnew file mode 100755 index 00000000..8d0bcad5 --- /dev/null +++ b/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/images/mwtnLog.png diff --git a/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/mwtnLog-custom.css b/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/mwtnLog-custom.css new file mode 100644 index 00000000..47c5864d --- /dev/null +++ b/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/mwtnLog-custom.css @@ -0,0 +1,58 @@ +/** + * Add your application related css here + */ +.owl .uib-tab a { + border: 1px solid #000; + background-color: white; + color: #3276b1; +} + +.owl .uib-tab.active a { + background-color: #3276b1; + color: white; +} + +.mwtnLogGrid { + height: 600px; + background-color: white; +} + +.mwtnLogGrid span { + color: #393939; +} + +.mwtnLogGrid div.debug { + color: #393939; + background-color: white; +} +.mwtnLogGrid div.error { + color: #ff0000; + background-color: #ffeeee; + font-weight: bold; +} + +.mwtnLogGrid div.info { + color: #3276b1; + background-color: #eeeeff; +} + +.mwtnLogGrid div.warning { + color: #ffa500; + background-color: #ffeedd; +} + +.rotated { + transform: rotate(180deg); + -webkit-transform: rotate(180deg); + -ms-transform: rotate(180deg); + -moz-transform: rotate(180deg); + -o-transform: rotate(180deg); +} + +h3.modal-title { + color: #393939; +} + +.modal-body span { + color: #393939; +}
\ No newline at end of file diff --git a/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/mwtnLog.controller.js b/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/mwtnLog.controller.js new file mode 100644 index 00000000..c4135e6b --- /dev/null +++ b/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/mwtnLog.controller.js @@ -0,0 +1,151 @@ +/* + * Copyright (c) 2016 highstreet technologies GmbH and others. All rights reserved. + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v1.0 which accompanies this distribution, + * and is available at http://www.eclipse.org/legal/epl-v10.html + */ + +define(['app/mwtnLog/mwtnLog.module', + 'app/mwtnLog/mwtnLog.services', + 'app/mwtnCommons/mwtnCommons.module'], + function(mwtnLogApp) { + + mwtnLogApp.register.controller('mwtnLogCtrl', ['uiGridConstants', '$uibModal', '$scope', '$rootScope', '$mwtnCommons', '$mwtnLogView', '$mwtnLog' , + function(uiGridConstants, $uibModal, $scope, $rootScope, $mwtnCommons, $mwtnLogView, $mwtnLog) { + + var COMPONENT = 'mwtnLogCtrl'; + $mwtnLog.info({component: COMPONENT, message: 'mwtnLogCtrl started!'}); + // $mwtnLog.error({component: COMPONENT, message: 'Just a test of logging an error.'}); + // $mwtnLog.warning({component: COMPONENT, message: 'Just a test of logging a warning.'}); + // $mwtnLog.debug({component: COMPONENT, message: 'Just a test of logging debug information.'}); + + $rootScope.section_logo = 'src/app/mwtnLog/images/mwtnLog.png'; // Add your topbar logo location here such as 'assets/images/logo_topology.gif' + + $scope.highlightFilteredHeader = $mwtnLogView.highlightFilteredHeader; + + var rowTemplate = '<div ng-click="grid.appScope.fnOne(row)" ng-repeat="col in colContainer.renderedColumns track by col.colDef.name" ng-class="[\'ui-grid-cell\', row.entity.type]" ui-grid-cell></div>'; + var iconCell = '<div class="ui-grid-cell-contents tooltip-uigrid" title="TOOLTIP"><i ng-class="{\'fa\':true, \'{{COL_FIELD}}\':true}" aria-hidden="true"></i></div>'; + + $scope.gridOptions = JSON.parse(JSON.stringify($mwtnLogView.gridOptions)); + $scope.gridOptions.rowTemplate = rowTemplate; + $scope.gridOptions.columnDefs = [ + // { field: 'id', type: 'number', displayName: 'No.', headerCellClass: $scope.highlightFilteredHeader, width : 50, cellClass: 'number', pinnedLeft : true }, + { field: 'icon', type: 'string', displayName: '', headerCellClass: $scope.highlightFilteredHeader, width: 25, enableSorting: false, enableFiltering:false, cellTemplate: iconCell }, + { field: 'timestamp', type: 'string', displayName: 'Timestamp', headerCellClass: $scope.highlightFilteredHeader, width : 200,sort: { + direction: uiGridConstants.DESC, + priority: 1 + } }, + { field: 'type', type: 'string', displayName: 'Type', headerCellClass: $scope.highlightFilteredHeader, width: 70 }, + { field: 'component', type: 'string', displayName: 'Component', headerCellClass: $scope.highlightFilteredHeader, width : 200 }, + { field: 'message', type: 'string', displayName: 'Message', headerCellClass: $scope.highlightFilteredHeader, width : 500 } + ]; + + $scope.progress = { + show: true, + max: 200, + value: 160 + }; + + $scope.clearLog = function () { + + var modalInstance = $uibModal.open({ + animation: true, + ariaLabelledBy: 'modal-title', + ariaDescribedBy: 'modal-body', + templateUrl: 'src/app/mwtnLog/templates/clearLogConfirmation.tpl.html', + controller: 'ClearLogCtrl', + size: 'lg', + resolve: { + now: function () { + return new Date().toISOString(); + } + } + }); + + modalInstance.result.then(function () { + var spec = { + functionId : 'mwtn', + docType : 'log', + query: { + match_all: {} + } + }; + $mwtnLogView.deleteDocType(spec).then(function(deleted){ + $scope.gridOptions.data = []; + $mwtnLog.info({component: COMPONENT, message: 'Log cleared!'}); + }, function(error){ + $mwtnLog.error({component: COMPONENT, message:JSON.stringify(error)}); + }); + }, function () { + $mwtnLog.info({component: COMPONENT, message: 'Mount dismissed!'}); + }); + }; + + var getIconFromType = function(type) { + var mapping = { + debug : '', + info : 'fa-info-circle', + warning : 'fa-exclamation-triangle', + error : 'fa-times-circle' + }; + return mapping[type]; + }; + + var processLogEntries = function(logEntries) { + if (logEntries.data.hits.hits) { + logEntries.data.hits.hits.map(function(entry){ + var log = { + id: entry._id, + icon: getIconFromType(entry._source.type), + timestamp: entry._source.timestamp, + type: entry._source.type, + component: entry._source.component, + message: entry._source.message, + }; + $scope.gridOptions.data.push(log); + }); + $scope.progress.max = logEntries.data.hits.total; + $scope.progress.value = $scope.gridOptions.data.length; + $scope.progress.show = $scope.gridOptions.data.length < logEntries.data.hits.total; + } + }; + + $scope.refreshLog = function() { + $scope.gridOptions.data = []; + var from = 0; + var size = 100; + $scope.processing = true; + $mwtnLogView.getAllLogEntries(from, size).then(function(logEntries){ + $scope.processing = false; + processLogEntries(logEntries); + from = from + size; + while (from < $scope.progress.max) { + $mwtnLogView.getAllLogEntries(from, size).then(function(logEntries){ + processLogEntries(logEntries); + }, function(error){ + console.error(JSON.stringify(error)); + }); + from = from + size; + } + }, function(error){ + console.error(JSON.stringify(error)); + }); + }; + $scope.refreshLog(); + + }]); + + mwtnLogApp.register.controller('ClearLogCtrl', ['$scope', '$uibModalInstance', + function ($scope, $uibModalInstance) { + + $scope.ok = function () { + $uibModalInstance.close('ok'); + }; + + $scope.cancel = function () { + $uibModalInstance.dismiss('cancel'); + }; + }]); + +}); diff --git a/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/mwtnLog.module.js b/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/mwtnLog.module.js new file mode 100644 index 00000000..faece4fc --- /dev/null +++ b/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/mwtnLog.module.js @@ -0,0 +1,56 @@ +/* + * Copyright (c) 2016 highstreet technologies GmbH and others. All rights reserved. + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v1.0 which accompanies this distribution, + * and is available at http://www.eclipse.org/legal/epl-v10.html + */ + +define(['angularAMD', + 'app/routingConfig', + 'app/core/core.services', + 'common/config/env.module', + 'app/mwtnCommons/mwtnCommons.module'], function(ng) { + var mwtnLogApp = angular.module('app.mwtnLog', ['ui.grid', 'ui.bootstrap', 'app.core', + 'ui.router.state', 'config', 'ui.grid.exporter', + 'ui.grid.moveColumns', 'ui.grid.pinning', 'ui.grid.selection', + 'ui.grid.resizeColumns' ]); + + mwtnLogApp.config(function($stateProvider, $compileProvider, $controllerProvider, $provide, NavHelperProvider, $translateProvider) { + mwtnLogApp.register = { + controller : $controllerProvider.register, + directive : $compileProvider.directive, + factory : $provide.factory, + service : $provide.service + }; + + + NavHelperProvider.addControllerUrl('app/mwtnLog/mwtnLog.controller'); + NavHelperProvider.addToMenu('mwtnLog', { + "link" : "#/mwtnLog", + "active" : "main.mwtnLog", + "title" : "Logs", + "icon" : "fa fa-list", // Add navigation icon css class here + "page" : { + "title" : "Logs", + "description" : "mwtnLog" + } + }); + + var access = routingConfig.accessLevels; + + $stateProvider.state('main.mwtnLog', { + url: 'mwtnLog', + access: access.admin, + views : { + 'content' : { + templateUrl: 'src/app/mwtnLog/mwtnLog.tpl.html', + controller: 'mwtnLogCtrl' + } + } + }); + + }); + + return mwtnLogApp; +}); diff --git a/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/mwtnLog.services.js b/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/mwtnLog.services.js new file mode 100644 index 00000000..ef900e2a --- /dev/null +++ b/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/mwtnLog.services.js @@ -0,0 +1,40 @@ +/* + * Copyright (c) 2016 highstreet technologies GmbH and others. All rights reserved. + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v1.0 which accompanies this distribution, + * and is available at http://www.eclipse.org/legal/epl-v10.html + */ + +define(['app/mwtnLog/mwtnLog.module','app/mwtnCommons/mwtnCommons.services'],function(mwtnLogApp) { + + mwtnLogApp.register.factory('$mwtnLogView', function($q, $mwtnCommons, $mwtnDatabase, $mwtnLog) { + + var service = {}; + + service.checkModules = $mwtnCommons.checkModules; + service.highlightFilteredHeader = $mwtnCommons.highlightFilteredHeader; + service.gridOptions = $mwtnCommons.gridOptions; + service.formatTimeStamp = $mwtnCommons.formatTimeStamp; + service.deleteDocType = $mwtnDatabase.deleteDocType; + + + service.getAllLogEntries = function(from, size) { + var sort = [ { + timestamp : { + order : 'desc' + } + }]; + var deferred = $q.defer(); + $mwtnDatabase.getAllData('mwtn', 'log', from, size, sort).then(function(success){ + deferred.resolve(success); + }, function(error){ + $mwtnLog.error({component: '$mwtnLogView.getAllLogEntries', message: JSON.stringify(error.data)}); + deferred.reject(error); + }); + return deferred.promise; + }; + + return service; + }); +}); diff --git a/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/mwtnLog.tpl.html b/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/mwtnLog.tpl.html new file mode 100644 index 00000000..f20f154b --- /dev/null +++ b/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/mwtnLog.tpl.html @@ -0,0 +1,26 @@ +<ht-header help-link='sdnr/mwtnLog/0.4.0/README.md'></ht-header> +<div id="mwtnLogGrid" ui-grid="gridOptions" ui-grid-exporter ui-grid-selection ui-grid-pinning ui-grid-resize-columns ui-grid-move-columns + class="mwtnLogGrid"></div> + <uib-progressbar ng-show="progress.show" class="progress-striped" type="warning" max="progress.max" value="progress.value" ><i>{{progress.value}} / {{progress.max}}</i></uib-progressbar> + +<div class="text-right"> + <br/> + <button type="button" id="clearLog" class="btn btn-warning" ng-click="clearLog()"> + <i class="fa fa-times" aria-hidden="true"></i> + <span>Clear log</span> + </button> + <!-- see gird menu Export ... + <button type="button" id="saveLog" class="btn btn-primary" ng-click="saveLog()"> + <i class="fa fa-save" aria-hidden="true"></i> + <span>Save...</span> + </button> --> + <button type="button" id="refreshLog" class="btn btn-primary" ng-click="refreshLog()"> + <i class="fa fa-refresh" ng-class="{'fa-pulse':processing}" aria-hidden="true"></i> + <span>{{'MWTN_REFRESH' | translate}}</span> + </button> +</div> + +<hr /> +<div class="owl"> + <span class="white">ONAP SDN-R | ONF Wireless for @distversion@ - Build: @buildtime@</span> +</div>
\ No newline at end of file diff --git a/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/templates/clearLogConfirmation.tpl.html b/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/templates/clearLogConfirmation.tpl.html new file mode 100644 index 00000000..cdd87c6a --- /dev/null +++ b/sdnr/wireless-transport/code-Carbon-SR1/ux/mwtnLog/mwtnLog-module/src/main/resources/mwtnLog/templates/clearLogConfirmation.tpl.html @@ -0,0 +1,12 @@ + +<div class="modal-header"> + <h3 class="modal-title" id="modal-title">{{'Clear Log Confirmation' | translate}}</h3> +</div> +<div class="modal-body" id="modal-body"> + <p>All log entries stored in the database will be deleted.</p> + <p>Please make, sure you have exported the log entries, otherwise they will get lost.</p> +</div> +<div class="modal-footer"> + <button class="btn btn-primary" type="button" ng-click="ok()">{{'Clear log' | translate}}</button> + <button class="btn btn-warning" type="button" ng-click="cancel()">{{'Cancel' | translate}}</button> +</div>
\ No newline at end of file |