134 lines
4.9 KiB
Python
134 lines
4.9 KiB
Python
'use strict';
|
|
|
|
app.controller('MeterPointController', function (
|
|
$scope,
|
|
$window,
|
|
$timeout,
|
|
$translate,
|
|
MeterService,
|
|
DataSourceService,
|
|
PointService,
|
|
MeterPointService,
|
|
toaster) {
|
|
$scope.cur_user = JSON.parse($window.localStorage.getItem("myems_admin_ui_current_user"));
|
|
$scope.currentMeter = {selected:undefined};
|
|
$scope.getAllDataSources = function () {
|
|
let headers = { "User-UUID": $scope.cur_user.uuid, "Token": $scope.cur_user.token };
|
|
DataSourceService.getAllDataSources(headers, function (response) {
|
|
if (angular.isDefined(response.status) && response.status === 200) {
|
|
$scope.datasources = response.data;
|
|
if ($scope.datasources.length > 0) {
|
|
$scope.currentDataSource = $scope.datasources[0].id;
|
|
$scope.getPointsByDataSourceID($scope.currentDataSource);
|
|
}
|
|
} else {
|
|
$scope.datasources = [];
|
|
}
|
|
});
|
|
};
|
|
|
|
$scope.getPointsByDataSourceID = function (id) {
|
|
let headers = { "User-UUID": $scope.cur_user.uuid, "Token": $scope.cur_user.token };
|
|
PointService.getPointsByDataSourceID(id, headers, function (response) {
|
|
if (angular.isDefined(response.status) && response.status === 200) {
|
|
$scope.points = response.data;
|
|
} else {
|
|
$scope.points = [];
|
|
}
|
|
});
|
|
};
|
|
|
|
$scope.getPointsByMeterID = function (id) {
|
|
MeterPointService.getPointsByMeterID(id, function (response) {
|
|
if (angular.isDefined(response.status) && response.status === 200) {
|
|
$scope.meterpoints = response.data;
|
|
} else {
|
|
$scope.meterpoints = [];
|
|
}
|
|
});
|
|
};
|
|
|
|
$scope.changeMeter=function(item,model){
|
|
$scope.currentMeter=item;
|
|
$scope.currentMeter.selected=model;
|
|
$scope.getPointsByMeterID($scope.currentMeter.id);
|
|
};
|
|
|
|
$scope.changeDataSource = function (item, model) {
|
|
$scope.currentDataSource = model;
|
|
$scope.getPointsByDataSourceID($scope.currentDataSource);
|
|
};
|
|
|
|
$scope.getAllMeters = function () {
|
|
MeterService.getAllMeters(function (response) {
|
|
if (angular.isDefined(response.status) && response.status === 200) {
|
|
$scope.meters = response.data;
|
|
$timeout(function () {
|
|
$scope.getPointsByMeterID($scope.currentMeter.id);
|
|
}, 1000);
|
|
} else {
|
|
$scope.meters = [];
|
|
}
|
|
});
|
|
|
|
};
|
|
|
|
$scope.pairPoint = function (dragEl, dropEl) {
|
|
var pointid = angular.element('#' + dragEl).scope().point.id;
|
|
var meterid = $scope.currentMeter.id;
|
|
let headers = { "User-UUID": $scope.cur_user.uuid, "Token": $scope.cur_user.token };
|
|
MeterPointService.addPair(meterid, pointid, 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_POINT_SUCCESS"),
|
|
showCloseButton: true,
|
|
});
|
|
$scope.getPointsByMeterID($scope.currentMeter.id);
|
|
} else {
|
|
toaster.pop({
|
|
type: "error",
|
|
title: $translate.instant(response.data.title),
|
|
body: $translate.instant(response.data.description),
|
|
showCloseButton: true,
|
|
});
|
|
}
|
|
});
|
|
};
|
|
|
|
$scope.deletePointPair = function (dragEl, dropEl) {
|
|
if (angular.element('#' + dragEl).hasClass('source')) {
|
|
return;
|
|
}
|
|
var meterpointid = angular.element('#' + dragEl).scope().meterpoint.id;
|
|
var meterid = $scope.currentMeter.id;
|
|
let headers = { "User-UUID": $scope.cur_user.uuid, "Token": $scope.cur_user.token };
|
|
MeterPointService.deletePair(meterid, meterpointid, 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_POINT_SUCCESS"),
|
|
showCloseButton: true,
|
|
});
|
|
$scope.getPointsByMeterID($scope.currentMeter.id);
|
|
} else {
|
|
toaster.pop({
|
|
type: "error",
|
|
title: $translate.instant(response.data.title),
|
|
body: $translate.instant(response.data.description),
|
|
showCloseButton: true,
|
|
});
|
|
}
|
|
});
|
|
};
|
|
|
|
$scope.getAllDataSources();
|
|
$scope.getAllMeters();
|
|
|
|
$scope.$on('handleBroadcastMeterChanged', function(event) {
|
|
$scope.getAllMeters();
|
|
});
|
|
});
|