399 lines
13 KiB
Python
399 lines
13 KiB
Python
'use strict';
|
|
|
|
app.controller('EnergyFlowDiagramLinkController', function($scope,$common ,$timeout,$uibModal, $translate, MeterService, VirtualMeterService, OfflineMeterService, EnergyFlowDiagramLinkService, EnergyFlowDiagramService, EnergyFlowDiagramNodeService, toaster,SweetAlert) {
|
|
$scope.currentEnergyFlowDiagram = {selected:undefined};
|
|
$scope.is_show_add_link = false;
|
|
$scope.energyflowdiagrams = [];
|
|
$scope.energyflowdiagramlinks = [];
|
|
$scope.energyflowdiagramnodes = [];
|
|
$scope.meters = [];
|
|
$scope.offlinemeters = [];
|
|
$scope.virtualmeters = [];
|
|
$scope.mergedMeters = [];
|
|
|
|
$scope.getAllEnergyFlowDiagrams = function() {
|
|
EnergyFlowDiagramService.getAllEnergyFlowDiagrams(function(error, data) {
|
|
if (!error) {
|
|
$scope.energyflowdiagrams = data;
|
|
} else {
|
|
$scope.energyflowdiagrams = [];
|
|
}
|
|
});
|
|
};
|
|
|
|
$scope.changeEnergyFlowDiagram=function(item,model){
|
|
$scope.currentEnergyFlowDiagram=item;
|
|
$scope.currentEnergyFlowDiagram.selected=model;
|
|
$scope.is_show_add_link = true;
|
|
$scope.getLinksByEnergyFlowDiagramID($scope.currentEnergyFlowDiagram.id);
|
|
$scope.getNodesByEnergyFlowDiagramID($scope.currentEnergyFlowDiagram.id);
|
|
};
|
|
|
|
$scope.getLinksByEnergyFlowDiagramID = function(id) {
|
|
|
|
EnergyFlowDiagramLinkService.getLinksByEnergyFlowDiagramID(id, function(error, data) {
|
|
if (!error) {
|
|
$scope.energyflowdiagramlinks=data;
|
|
$scope.showEnergyFlowDiagramMeter()
|
|
} else {
|
|
$scope.energyflowdiagramlinks = [];
|
|
}
|
|
});
|
|
};
|
|
|
|
$scope.getNodesByEnergyFlowDiagramID = function(id) {
|
|
|
|
EnergyFlowDiagramNodeService.getNodesByEnergyFlowDiagramID(id, function(error, data) {
|
|
if (!error) {
|
|
$scope.energyflowdiagramnodes=data;
|
|
console.log($scope.energyflowdiagramnodes);
|
|
} else {
|
|
$scope.energyflowdiagramnodes = [];
|
|
}
|
|
});
|
|
};
|
|
|
|
$scope.addEnergyFlowDiagramLink = function() {
|
|
|
|
var modalInstance = $uibModal.open({
|
|
templateUrl: 'views/settings/energyflowdiagram/energyflowdiagramlink.model.html',
|
|
controller: 'ModalAddEnergyFlowDiagramLinkCtrl',
|
|
windowClass: "animated fadeIn",
|
|
resolve: {
|
|
params: function() {
|
|
return {
|
|
energyflowdiagramnodes: angular.copy($scope.energyflowdiagramnodes),
|
|
mergedmeters: angular.copy($scope.mergedmeters),
|
|
};
|
|
}
|
|
}
|
|
});
|
|
modalInstance.result.then(function(energyflowdiagramlink) {
|
|
var energyflowdiagramid = $scope.currentEnergyFlowDiagram.id;
|
|
if (energyflowdiagramlink.source_node != null) {
|
|
energyflowdiagramlink.source_node_id = energyflowdiagramlink.source_node.id;
|
|
}
|
|
if (energyflowdiagramlink.target_node != null) {
|
|
energyflowdiagramlink.target_node_id = energyflowdiagramlink.target_node.id;
|
|
}
|
|
if (energyflowdiagramlink.meter != null) {
|
|
energyflowdiagramlink.meter_uuid = energyflowdiagramlink.meter.uuid;
|
|
}
|
|
|
|
EnergyFlowDiagramLinkService.addEnergyFlowDiagramLink(energyflowdiagramid, energyflowdiagramlink, function(error, status) {
|
|
if (angular.isDefined(status) && status == 201) {
|
|
var templateName = "ENERGY_FLOW_DIAGRAM.LINK";
|
|
templateName = $translate.instant(templateName);
|
|
|
|
var popType = 'TOASTER.SUCCESS';
|
|
var popTitle = $common.toaster.success_title;
|
|
var popBody = $common.toaster.success_add_body;
|
|
|
|
popType = $translate.instant(popType);
|
|
popTitle = $translate.instant(popTitle);
|
|
popBody = $translate.instant(popBody,{template: templateName});
|
|
|
|
toaster.pop({
|
|
type: popType,
|
|
title: popTitle,
|
|
body: popBody,
|
|
showCloseButton: true,
|
|
});
|
|
$scope.getLinksByEnergyFlowDiagramID($scope.currentEnergyFlowDiagram.id);
|
|
$scope.$emit('handleEmitEnergyFlowDiagramLinkChanged');
|
|
} else {
|
|
var templateName = "ENERGY_FLOW_DIAGRAM.LINK";
|
|
templateName = $translate.instant(templateName);
|
|
|
|
var popType = 'TOASTER.ERROR';
|
|
var popTitle = $common.toaster.error_title;
|
|
var popBody = $common.toaster.error_add_body;
|
|
|
|
popType = $translate.instant(popType);
|
|
popTitle = $translate.instant(popTitle);
|
|
popBody = $translate.instant(popBody,{template: templateName});
|
|
|
|
toaster.pop({
|
|
type: popType,
|
|
title: popTitle,
|
|
body: popBody,
|
|
showCloseButton: true,
|
|
});
|
|
}
|
|
});
|
|
}, function() {
|
|
|
|
});
|
|
};
|
|
|
|
$scope.editEnergyFlowDiagramLink = function(energyflowdiagramlink) {
|
|
var modalInstance = $uibModal.open({
|
|
templateUrl: 'views/settings/energyflowdiagram/energyflowdiagramlink.model.html',
|
|
controller: 'ModalEditEnergyFlowDiagramLinkCtrl',
|
|
windowClass: "animated fadeIn",
|
|
resolve: {
|
|
params: function() {
|
|
return {
|
|
energyflowdiagramlink: angular.copy(energyflowdiagramlink),
|
|
energyflowdiagramnodes: angular.copy($scope.energyflowdiagramnodes),
|
|
mergedmeters: angular.copy($scope.mergedmeters),
|
|
};
|
|
}
|
|
}
|
|
});
|
|
|
|
modalInstance.result.then(function(modifiedEnergyFlowDiagramLink) {
|
|
if (modifiedEnergyFlowDiagramLink.source_node != null) {
|
|
modifiedEnergyFlowDiagramLink.source_node_id = modifiedEnergyFlowDiagramLink.source_node.id;
|
|
}
|
|
if (modifiedEnergyFlowDiagramLink.target_node != null) {
|
|
modifiedEnergyFlowDiagramLink.target_node_id = modifiedEnergyFlowDiagramLink.target_node.id;
|
|
}
|
|
if (modifiedEnergyFlowDiagramLink.meter != null) {
|
|
modifiedEnergyFlowDiagramLink.meter_uuid = modifiedEnergyFlowDiagramLink.meter.uuid;
|
|
}
|
|
EnergyFlowDiagramLinkService.editEnergyFlowDiagramLink($scope.currentEnergyFlowDiagram.id, modifiedEnergyFlowDiagramLink, function(error, status) {
|
|
if (angular.isDefined(status) && status == 200) {
|
|
var templateName = "ENERGY_FLOW_DIAGRAM.LINK";
|
|
templateName = $translate.instant(templateName);
|
|
|
|
var popType = 'TOASTER.SUCCESS';
|
|
var popTitle = $common.toaster.success_title;
|
|
var popBody = $common.toaster.success_update_body;
|
|
|
|
popType = $translate.instant(popType);
|
|
popTitle = $translate.instant(popTitle);
|
|
popBody = $translate.instant(popBody,{template: templateName});
|
|
|
|
toaster.pop({
|
|
type: popType,
|
|
title: popTitle,
|
|
body: popBody,
|
|
showCloseButton: true,
|
|
});
|
|
$scope.getLinksByEnergyFlowDiagramID($scope.currentEnergyFlowDiagram.id);
|
|
$scope.$emit('handleEmitEnergyFlowDiagramLinkChanged');
|
|
} else {
|
|
var templateName = "ENERGY_FLOW_DIAGRAM.LINK";
|
|
templateName = $translate.instant(templateName);
|
|
|
|
var popType = 'TOASTER.ERROR';
|
|
var popTitle = $common.toaster.error_title;
|
|
var popBody = $common.toaster.error_update_body;
|
|
|
|
popType = $translate.instant(popType);
|
|
popTitle = $translate.instant(popTitle);
|
|
popBody = $translate.instant(popBody,{template: templateName});
|
|
|
|
toaster.pop({
|
|
type: popType,
|
|
title: popTitle,
|
|
body: popBody,
|
|
showCloseButton: true,
|
|
});
|
|
}
|
|
});
|
|
}, function() {
|
|
//do nothing;
|
|
});
|
|
};
|
|
|
|
$scope.deleteEnergyFlowDiagramLink = function(energyflowdiagramlink) {
|
|
SweetAlert.swal({
|
|
title: $translate.instant($common.sweet.title),
|
|
text: $translate.instant($common.sweet.text),
|
|
type: "warning",
|
|
showCancelButton: true,
|
|
confirmButtonColor: "#DD6B55",
|
|
confirmButtonText: $translate.instant($common.sweet.confirmButtonText),
|
|
cancelButtonText: $translate.instant($common.sweet.cancelButtonText),
|
|
closeOnConfirm: true,
|
|
closeOnCancel: true
|
|
},
|
|
function(isConfirm) {
|
|
if (isConfirm) {
|
|
EnergyFlowDiagramLinkService.deleteEnergyFlowDiagramLink($scope.currentEnergyFlowDiagram.id, energyflowdiagramlink.id, function(error, status) {
|
|
if (angular.isDefined(status) && status == 204) {
|
|
var templateName = "ENERGY_FLOW_DIAGRAM.LINK";
|
|
templateName = $translate.instant(templateName);
|
|
|
|
var popType = 'TOASTER.SUCCESS';
|
|
var popTitle = $common.toaster.success_title;
|
|
var popBody = $common.toaster.success_delete_body;
|
|
|
|
popType = $translate.instant(popType);
|
|
popTitle = $translate.instant(popTitle);
|
|
popBody = $translate.instant(popBody, {template: templateName});
|
|
|
|
toaster.pop({
|
|
type: popType,
|
|
title: popTitle,
|
|
body: popBody,
|
|
showCloseButton: true,
|
|
});
|
|
$scope.getLinksByEnergyFlowDiagramID($scope.currentEnergyFlowDiagram.id);
|
|
$scope.$emit('handleEmitEnergyFlowDiagramLinkChanged');
|
|
} else if (angular.isDefined(status) && status == 400) {
|
|
var popType = 'TOASTER.ERROR';
|
|
var popTitle = error.title;
|
|
var popBody = error.description;
|
|
|
|
popType = $translate.instant(popType);
|
|
popTitle = $translate.instant(popTitle);
|
|
popBody = $translate.instant(popBody);
|
|
|
|
toaster.pop({
|
|
type: popType,
|
|
title: popTitle,
|
|
body: popBody,
|
|
showCloseButton: true,
|
|
});
|
|
} else {
|
|
var templateName = "ENERGY_FLOW_DIAGRAM.LINK";
|
|
templateName = $translate.instant(templateName);
|
|
|
|
var popType = 'TOASTER.ERROR';
|
|
var popTitle = $common.toaster.error_title;
|
|
var popBody = $common.toaster.error_delete_body;
|
|
|
|
popType = $translate.instant(popType);
|
|
popTitle = $translate.instant(popTitle);
|
|
popBody = $translate.instant(popBody, {template: templateName});
|
|
|
|
toaster.pop({
|
|
type: popType,
|
|
title: popTitle,
|
|
body: popBody,
|
|
showCloseButton: true,
|
|
});
|
|
}
|
|
});
|
|
}
|
|
});
|
|
};
|
|
|
|
$scope.colorMeterType=function(type){
|
|
if(type=='meters'){
|
|
return 'btn-primary'
|
|
}else if(type=='virtualmeters'){
|
|
return 'btn-info'
|
|
}else{
|
|
return 'btn-success'
|
|
}
|
|
};
|
|
|
|
// $scope.changeMeterType=function(){
|
|
// switch($scope.currentMeterType){
|
|
// case 'meters':
|
|
// $scope.currentmeters=$scope.meters;
|
|
// break;
|
|
// case 'virtualmeters':
|
|
// $scope.currentmeters=$scope.virtualmeters;
|
|
// break;
|
|
// case 'offlinemeters':
|
|
// $scope.currentmeters=$scope.offlinemeters;
|
|
// break;
|
|
// }
|
|
// };
|
|
|
|
$scope.showEnergyFlowDiagramMeter = function(energyflowdiagramlink) {
|
|
|
|
if (energyflowdiagramlink == null || energyflowdiagramlink.meter == null) {
|
|
return '-';
|
|
} else {
|
|
return '(' + energyflowdiagramlink.meter.type + ')' + energyflowdiagramlink.meter.name;
|
|
}
|
|
};
|
|
|
|
$scope.getMergedMeters = function() {
|
|
$scope.mergedmeters = [];
|
|
$scope.meters = [];
|
|
$scope.offlinemeters = [];
|
|
$scope.virtualmeters = [];
|
|
MeterService.getAllMeters(function(error, data) {
|
|
if (!error) {
|
|
$scope.meters = data;
|
|
for(var i = 0; i < $scope.meters.length; i++) {
|
|
var mergedmeter = {"uuid": $scope.meters[i].uuid, "name": "meter/"+$scope.meters[i].name};
|
|
$scope.mergedmeters.push(mergedmeter);
|
|
}
|
|
// $scope.currentMeterType="meters";
|
|
// $timeout(function(){
|
|
// $scope.changeMeterType();
|
|
// },1000);
|
|
} else {
|
|
$scope.meters = [];
|
|
}
|
|
});
|
|
|
|
OfflineMeterService.getAllOfflineMeters(function(error, data) {
|
|
if (!error) {
|
|
$scope.offlinemeters = data;
|
|
for(var i = 0; i < $scope.offlinemeters.length; i++) {
|
|
var mergedmeter = {"uuid": $scope.offlinemeters[i].uuid, "name": "offlinemeter/"+$scope.offlinemeters[i].name};
|
|
$scope.mergedmeters.push(mergedmeter);
|
|
}
|
|
} else {
|
|
$scope.offlinemeters = [];
|
|
}
|
|
});
|
|
|
|
VirtualMeterService.getAllVirtualMeters(function(error, data) {
|
|
if (!error) {
|
|
$scope.virtualmeters = data;
|
|
for(var i = 0; i < $scope.virtualmeters.length; i++) {
|
|
var mergedmeter = {"uuid": $scope.virtualmeters[i].uuid, "name": "virtualmeter/"+$scope.virtualmeters[i].name};
|
|
$scope.mergedmeters.push(mergedmeter);
|
|
}
|
|
} else {
|
|
$scope.virtualmeters = [];
|
|
}
|
|
});
|
|
};
|
|
|
|
$scope.getAllEnergyFlowDiagrams();
|
|
$scope.getMergedMeters();
|
|
|
|
$scope.$on('handleBroadcastEnergyFlowDiagramChanged', function(event) {
|
|
$scope.getAllEnergyFlowDiagrams();
|
|
});
|
|
|
|
$scope.$on('handleBroadcastEnergyFlowDiagramNodeChanged', function(event) {
|
|
$scope.getNodesByEnergyFlowDiagramID($scope.currentEnergyFlowDiagram.id);
|
|
});
|
|
});
|
|
|
|
app.controller('ModalAddEnergyFlowDiagramLinkCtrl', function($scope, $uibModalInstance, params) {
|
|
|
|
$scope.operation = "ENERGY_FLOW_DIAGRAM.ADD_LINK";
|
|
$scope.energyflowdiagramlink = {
|
|
source_node: {id: null, name: null},
|
|
target_node: {id: null, name: null},
|
|
meter: {id: null, uuid: null, name: null, type: null},
|
|
};
|
|
$scope.energyflowdiagramnodes = params.energyflowdiagramnodes;
|
|
$scope.mergedmeters = params.mergedmeters;
|
|
$scope.ok = function() {
|
|
|
|
$uibModalInstance.close($scope.energyflowdiagramlink);
|
|
};
|
|
|
|
$scope.cancel = function() {
|
|
$uibModalInstance.dismiss('cancel');
|
|
};
|
|
});
|
|
|
|
app.controller('ModalEditEnergyFlowDiagramLinkCtrl', function($scope, $uibModalInstance, params) {
|
|
$scope.operation = "ENERGY_FLOW_DIAGRAM.EDIT_LINK";
|
|
$scope.energyflowdiagramlink = params.energyflowdiagramlink;
|
|
$scope.energyflowdiagramnodes = params.energyflowdiagramnodes;
|
|
$scope.mergedmeters = params.mergedmeters;
|
|
$scope.ok = function() {
|
|
$uibModalInstance.close($scope.energyflowdiagramlink);
|
|
};
|
|
|
|
$scope.cancel = function() {
|
|
$uibModalInstance.dismiss('cancel');
|
|
};
|
|
});
|