108 lines
3.9 KiB
Python
108 lines
3.9 KiB
Python
'use strict';
|
|
|
|
app.controller('TenantSensorController', function (
|
|
$scope,
|
|
$window,
|
|
$translate,
|
|
TenantService,
|
|
SensorService,
|
|
TenantSensorService,
|
|
toaster,
|
|
SweetAlert) {
|
|
$scope.currentTenant = {selected:undefined};
|
|
$scope.cur_user = JSON.parse($window.localStorage.getItem("myems_admin_ui_current_user"));
|
|
$scope.getAllSensors = function () {
|
|
SensorService.getAllSensors(function (response) {
|
|
if (angular.isDefined(response.status) && response.status === 200) {
|
|
$scope.sensors = response.data;
|
|
} else {
|
|
$scope.sensors = [];
|
|
}
|
|
});
|
|
};
|
|
|
|
$scope.getSensorsByTenantID = function (id) {
|
|
TenantSensorService.getSensorsByTenantID(id, function (response) {
|
|
if (angular.isDefined(response.status) && response.status === 200) {
|
|
$scope.tenantsensors = response.data;
|
|
} else {
|
|
$scope.tenantsensors = [];
|
|
}
|
|
});
|
|
};
|
|
|
|
$scope.changeTenant=function(item,model){
|
|
$scope.currentTenant=item;
|
|
$scope.currentTenant.selected=model;
|
|
$scope.getSensorsByTenantID($scope.currentTenant.id);
|
|
};
|
|
|
|
$scope.getAllTenants = function () {
|
|
TenantService.getAllTenants(function (response) {
|
|
if (angular.isDefined(response.status) && response.status === 200) {
|
|
$scope.tenants = response.data;
|
|
} else {
|
|
$scope.tenants = [];
|
|
}
|
|
});
|
|
};
|
|
|
|
$scope.pairSensor = function (dragEl, dropEl) {
|
|
var sensorid = angular.element('#' + dragEl).scope().sensor.id;
|
|
var tenantid = $scope.currentTenant.id;
|
|
let headers = { "User-UUID": $scope.cur_user.uuid, "Token": $scope.cur_user.token };
|
|
TenantSensorService.addPair(tenantid, sensorid, 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_SENSOR_SUCCESS"),
|
|
showCloseButton: true,
|
|
});
|
|
$scope.getSensorsByTenantID($scope.currentTenant.id);
|
|
} else {
|
|
toaster.pop({
|
|
type: "error",
|
|
title: $translate.instant(response.data.title),
|
|
body: $translate.instant(response.data.description),
|
|
showCloseButton: true,
|
|
});
|
|
}
|
|
});
|
|
};
|
|
|
|
$scope.deleteSensorPair = function (dragEl, dropEl) {
|
|
if (angular.element('#' + dragEl).hasClass('source')) {
|
|
return;
|
|
}
|
|
var tenantsensorid = angular.element('#' + dragEl).scope().tenantsensor.id;
|
|
var tenantid = $scope.currentTenant.id;
|
|
let headers = { "User-UUID": $scope.cur_user.uuid, "Token": $scope.cur_user.token };
|
|
TenantSensorService.deletePair(tenantid, tenantsensorid, 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_SENSOR_SUCCESS"),
|
|
showCloseButton: true,
|
|
});
|
|
$scope.getSensorsByTenantID($scope.currentTenant.id);
|
|
} else {
|
|
toaster.pop({
|
|
type: "error",
|
|
title: $translate.instant(response.data.title),
|
|
body: $translate.instant(response.data.description),
|
|
showCloseButton: true,
|
|
});
|
|
}
|
|
});
|
|
};
|
|
|
|
$scope.getAllSensors();
|
|
$scope.getAllTenants();
|
|
|
|
$scope.$on('handleBroadcastTenantChanged', function(event) {
|
|
$scope.getAllTenants();
|
|
});
|
|
});
|