'use strict';
var tmplAppli = '<div ng-click="clicked()">' +
- '<img ng-src={{icon}}-ico.png>' +
+ '<img ng-src="{{icon}}">' +
'<span>{{label}}</span>' +
'</div>';
var tmplModal =
'<b class="close-button" ng-click="close()">×</b>' +
- '<img ng-src="{{appicon}}-ico.png">' +
- '<span class="modal-text">Application <b>{{appname}}</b></span>' +
+ '<img ng-src="{{icon}}">' +
+ '<span class="modal-text">Application <b>{{name}}</b></span>' +
'<ul class="vertical icon-left primary menu-bar">' +
'<li><a ng-click=action("start")><i class="fi-check"> Start</i></a></li>' +
- '<li><a href="#"><i class="fi-x"> Stop</i></a></li>' +
- '<li><a href="#"><i class="fi-info"> Info</i></a></li>' +
+ '<li><a ng-click=action("stop")><i class="fi-x"> Stop</i></a></li>' +
+ '<li><a ng-click=action("info")><i class="fi-info"> Info</i></a></li>' +
'</ul>' +
'';
function mymethods(scope, elem, attrs) {
scope.clicked = function () {
+
+ var notifyError = function(api, response) {
+ Notification.error ({message: "Fail /api/afm-main" + api + "=" + scope.label + " RunID="+ scope.appID, delay: 5000});
+ elem.addClass ("fail");
+ elem.removeClass ("success");
+ scope.callback (scope.appliID, api, response);
+ };
+
+ var notifySuccess = function (api, response) {
+ elem.removeClass ("fail");
+ scope.runID = response.data.response.runid;
+ scope.callback (scope.appliID, "/api/afm-main/start", response);
+ };
var closeModal = function() {
console.log ("Modal Closing");
case "start":
AppCall.get ("afm-main", "start", {id: scope.appliID}, function(response) {
- if (response.status !== 200) {
- Notification.error ({message: "Fail to start application=" + scope.label +" ID="+ scope.appliID, delay: 5000});
- elem.addClass ("fail");
- elem.removeClass ("success");
- scope.callback (scope.appliID, "/api/afm-main/start", response);
- return;
- }
-
- // Check this is a valid response from Binder
- if (response.data.request.jtype !== "AJB_reply" && response.data.request.api !== "start") {
- Notification.error ({message: "Invalid Respond to /opa/afm-main/start response.data="+response.data, delay: 5000});
- elem.addClass ("fail");
- elem.removeClass ("success");
- scope.callback (scope.appliID, "/api/afm-main/start", response);
+ if (response.status !== 200 || response.data.request.jtype !== "AJB_reply") {
+ notifyError ("start", response);
return;
}
- // Application was stated
- scope.callback (scope.appliID, "/api/afm-main/start", response);
+ notifySuccess ("start", response);
});
break;
case "stop":
+ AppCall.get ("afm-main", "stop", {id: scope.runID}, function(response) {
+ if (response.status !== 200 || response.data.request.jtype !== "AJB_reply") {
+ notifyError ("stop", response);
+ return;
+ }
+
+ notifySuccess ("stop", response);
+ });
break;
+
+ case "info":
+ AppCall.get ("afm-main", "detail", {id: scope.appID}, function(response) {
+ if (response.status !== 200 || response.data.request.jtype !== "AJB_reply") {
+ notifyError ("detail", response);
+ return;
+ }
+
+ notifySuccess ("detail", response);
+ });
+ break;
+
default:
console.log ("ActionModal unknown action=[%s]", action);
contentScope: {
action : actionModal,
close : closeModal,
- appicon : scope.icon,
- appname : scope.label,
+ icon : scope.icon,
+ label : scope.label
}, template : tmplModal
};
// Popup Modal to render application data
// extract application information from AppID+Store
if (attrs.handle && scope.store [attrs.handle].name) {
- scope.icon = AppConfig.paths.icons + scope.store [attrs.handle].name.toLowerCase();
+ scope.icon = AppConfig.paths.icons + scope.store [attrs.handle].name.toLowerCase() + '-ico.png';
scope.label = scope.store [attrs.handle].name;
scope.appliID= attrs.handle;
} else {