myems-admin/app/controllers/settings/space/spacemeter.controller.js
'use strict';
app.controller('SpaceMeterController', function(
$scope ,
$window,
$timeout,
$translate,
SpaceService,
MeterService,
VirtualMeterService,
OfflineMeterService, SpaceMeterService, toaster,SweetAlert) {
$scope.spaces = [];
$scope.currentSpaceID = 1;
$scope.spacemeters = [];
$scope.cur_user = JSON.parse($window.localStorage.getItem("myems_admin_ui_current_user"));
$scope.getAllSpaces = function() {
let headers = { "User-UUID": $scope.cur_user.uuid, "Token": $scope.cur_user.token };
SpaceService.getAllSpaces(headers, function (response) {
if (angular.isDefined(response.status) && response.status === 200) {
$scope.spaces = response.data;
} else {
$scope.spaces = [];
}
//create space tree
var treedata = {'core': {'data': [], "multiple" : false,}, "plugins" : [ "wholerow" ]};
for(var i=0; i < $scope.spaces.length; i++) {
if ($scope.spaces[i].id == 1) {
var node = {"id": $scope.spaces[i].id.toString(),
"parent": '#',
"text": $scope.spaces[i].name,
"state": { 'opened' : true, 'selected' : false },
};
} else {
var node = {"id": $scope.spaces[i].id.toString(),
"parent": $scope.spaces[i].parent_space.id.toString(),
"text": $scope.spaces[i].name,
};
};
treedata['core']['data'].push(node);
}
angular.element(spacetreewithmeter).jstree(treedata);
//space tree selected changed event handler
angular.element(spacetreewithmeter).on("changed.jstree", function (e, data) {
$scope.currentSpaceID = parseInt(data.selected[0]);
$scope.spacemeters=[];
$scope.getMetersBySpaceID($scope.currentSpaceID);
});
});
};
$scope.getMetersBySpaceID = function(id) {
var metertypes=['meters','virtualmeters','offlinemeters'];
$scope.spacemeters=[];
let headers = { "User-UUID": $scope.cur_user.uuid, "Token": $scope.cur_user.token };
angular.forEach(metertypes,function(value,index){
SpaceMeterService.getMetersBySpaceID(id,value, headers, function (response) {
if (angular.isDefined(response.status) && response.status === 200) {
angular.forEach(response.data, function(item,indx) {
response.data[indx].metertype = value;
});
$scope.spacemeters = $scope.spacemeters.concat(response.data);
}
});
});
};
$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.getAllMeters = function() {
let headers = { "User-UUID": $scope.cur_user.uuid, "Token": $scope.cur_user.token };
MeterService.getAllMeters(headers, function (response) {
if (angular.isDefined(response.status) && response.status === 200) {
$scope.meters = response.data;
$scope.currentMeterType="meters";
$timeout(function(){
$scope.changeMeterType();
},1000);
} else {
$scope.meters = [];
}
});
};
$scope.getAllOfflineMeters = function() {
let headers = { "User-UUID": $scope.cur_user.uuid, "Token": $scope.cur_user.token };
OfflineMeterService.getAllOfflineMeters(headers, function (response) {
if (angular.isDefined(response.status) && response.status === 200) {
$scope.offlinemeters = response.data;
} else {
$scope.offlinemeters = [];
}
});
};
$scope.getAllVirtualMeters = function() {
let headers = { "User-UUID": $scope.cur_user.uuid, "Token": $scope.cur_user.token };
VirtualMeterService.getAllVirtualMeters(headers, function (response) {
if (angular.isDefined(response.status) && response.status === 200) {
$scope.virtualmeters = response.data;
} else {
$scope.virtualmeters = [];
}
});
};
$scope.pairMeter=function(dragEl,dropEl){
var meterid=angular.element('#'+dragEl).scope().meter.id;
var spaceid=angular.element(spacetreewithmeter).jstree(true).get_top_selected();
let headers = { "User-UUID": $scope.cur_user.uuid, "Token": $scope.cur_user.token };
SpaceMeterService.addPair(spaceid,meterid, $scope.currentMeterType, headers, function (response) {
if (angular.isDefined(response.status) && response.status === 201) {
toaster.pop({
type: "success",
title: $translate.instant("TOASTER.SUCCESS_TITLE"),
body: $translate.instant("TOASTER.BIND_METER_SUCCESS"),
showCloseButton: true,
});
$scope.getMetersBySpaceID(spaceid);
} else {
toaster.pop({
type: "error",
title: $translate.instant(response.data.title),
body: $translate.instant(response.data.description),
showCloseButton: true,
});
}
});
};
$scope.deleteMeterPair=function(dragEl,dropEl){
if(angular.element('#'+dragEl).hasClass('source')){
return;
}
var spacemeterid = angular.element('#' + dragEl).scope().spacemeter.id;
var spaceid = angular.element(spacetreewithmeter).jstree(true).get_top_selected();
var metertype = angular.element('#' + dragEl).scope().spacemeter.metertype;
let headers = { "User-UUID": $scope.cur_user.uuid, "Token": $scope.cur_user.token };
SpaceMeterService.deletePair(spaceid, spacemeterid, metertype, headers, function (response) {
if (angular.isDefined(response.status) && response.status === 204) {
toaster.pop({
type: "success",
title: $translate.instant("TOASTER.SUCCESS_TITLE"),
body: $translate.instant("TOASTER.UNBIND_METER_SUCCESS"),
showCloseButton: true,
});
$scope.getMetersBySpaceID(spaceid);
} else {
toaster.pop({
type: "error",
title: $translate.instant(response.data.title),
body: $translate.instant(response.data.description),
showCloseButton: true,
});
}
});
};
$scope.getAllSpaces();
$scope.getAllMeters();
$scope.getAllVirtualMeters();
$scope.getAllOfflineMeters();
$scope.refreshSpaceTree = function() {
let headers = { "User-UUID": $scope.cur_user.uuid, "Token": $scope.cur_user.token };
SpaceService.getAllSpaces(headers, function (response) {
if (angular.isDefined(response.status) && response.status === 200) {
$scope.spaces = response.data;
} else {
$scope.spaces = [];
}
//create space tree
var treedata = {'core': {'data': [], "multiple" : false,}, "plugins" : [ "wholerow" ]};
for(var i=0; i < $scope.spaces.length; i++) {
if ($scope.spaces[i].id == 1) {
var node = {"id": $scope.spaces[i].id.toString(),
"parent": '#',
"text": $scope.spaces[i].name,
"state": { 'opened' : true, 'selected' : false },
};
} else {
var node = {"id": $scope.spaces[i].id.toString(),
"parent": $scope.spaces[i].parent_space.id.toString(),
"text": $scope.spaces[i].name,
};
};
treedata['core']['data'].push(node);
}
angular.element(spacetreewithmeter).jstree(true).settings.core.data = treedata['core']['data'];
angular.element(spacetreewithmeter).jstree(true).refresh();
});
};
$scope.$on('handleBroadcastSpaceChanged', function(event) {
$scope.spacemeters = [];
$scope.refreshSpaceTree();
});
});