mirror of
https://github.com/bwssytems/ha-bridge.git
synced 2025-12-18 16:17:30 +00:00
5853 lines
185 KiB
JavaScript
5853 lines
185 KiB
JavaScript
var app = angular.module('habridge', ['ngRoute', 'ngToast', 'rzModule', 'ngDialog', 'base64', 'scrollable-table', 'ngResource', 'ngStorage', 'colorpicker.module', 'ngFileUpload']);
|
|
|
|
app.config(function ($locationProvider, $routeProvider) {
|
|
$locationProvider.hashPrefix('!');
|
|
|
|
$routeProvider.when('/', {
|
|
templateUrl: 'views/configuration.html',
|
|
controller: 'ViewingController',
|
|
requiresAuthentication: true
|
|
}).when('/system', {
|
|
templateUrl: 'views/system.html',
|
|
controller: 'SystemController',
|
|
requiresAuthentication: true
|
|
}).when('/logs', {
|
|
templateUrl: 'views/logs.html',
|
|
controller: 'LogsController',
|
|
requiresAuthentication: true
|
|
}).when('/editdevice', {
|
|
templateUrl: 'views/editdevice.html',
|
|
controller: 'EditController',
|
|
requiresAuthentication: true
|
|
}).when('/veradevices', {
|
|
templateUrl: 'views/veradevice.html',
|
|
controller: 'VeraController',
|
|
requiresAuthentication: true
|
|
}).when('/verascenes', {
|
|
templateUrl: 'views/verascene.html',
|
|
controller: 'VeraController',
|
|
requiresAuthentication: true
|
|
}).when('/fibarodevices', {
|
|
templateUrl: 'views/fibarodevice.html',
|
|
controller: 'FibaroController',
|
|
requiresAuthentication: true
|
|
}).when('/fibaroscenes', {
|
|
templateUrl: 'views/fibaroscene.html',
|
|
controller: 'FibaroController',
|
|
requiresAuthentication: true
|
|
}).when('/harmonydevices', {
|
|
templateUrl: 'views/harmonydevice.html',
|
|
controller: 'HarmonyController',
|
|
requiresAuthentication: true
|
|
}).when('/harmonyactivities', {
|
|
templateUrl: 'views/harmonyactivity.html',
|
|
controller: 'HarmonyController',
|
|
requiresAuthentication: true
|
|
}).when('/nest', {
|
|
templateUrl: 'views/nestactions.html',
|
|
controller: 'NestController',
|
|
requiresAuthentication: true
|
|
}).when('/huedevices', {
|
|
templateUrl: 'views/huedevice.html',
|
|
controller: 'HueController',
|
|
requiresAuthentication: true
|
|
}).when('/haldevices', {
|
|
templateUrl: 'views/haldevice.html',
|
|
controller: 'HalController',
|
|
requiresAuthentication: true
|
|
}).when('/mqttmessages', {
|
|
templateUrl: 'views/mqttpublish.html',
|
|
controller: 'MQTTController',
|
|
requiresAuthentication: true
|
|
}).when('/hassdevices', {
|
|
templateUrl: 'views/hassdevice.html',
|
|
controller: 'HassController',
|
|
requiresAuthentication: true
|
|
}).when('/homewizarddevices', {
|
|
templateUrl: 'views/homewizarddevice.html',
|
|
controller: 'HomeWizardController',
|
|
requiresAuthentication: true
|
|
}).when('/domoticzdevices', {
|
|
templateUrl: 'views/domoticzdevice.html',
|
|
controller: 'DomoticzController',
|
|
requiresAuthentication: true
|
|
}).when('/somfydevices', {
|
|
templateUrl: 'views/somfydevice.html',
|
|
controller: 'SomfyController',
|
|
requiresAuthentication: true
|
|
}).when('/lifxdevices', {
|
|
templateUrl: 'views/lifxdevice.html',
|
|
controller: 'LifxController',
|
|
requiresAuthentication: true
|
|
}).when('/openhabdevices', {
|
|
templateUrl: 'views/openhabdevice.html',
|
|
controller: 'OpenHABController',
|
|
requiresAuthentication: true
|
|
}).when('/moziotdevices', {
|
|
templateUrl: 'views/moziotdevice.html',
|
|
controller: 'MozIotController',
|
|
requiresAuthentication: true
|
|
}).when('/fhemdevices', {
|
|
templateUrl: 'views/fhemdevice.html',
|
|
controller: 'FhemController',
|
|
requiresAuthentication: true
|
|
}).when('/broadlinkdevices', {
|
|
templateUrl: 'views/broadlinkdevice.html',
|
|
controller: 'BroadlinkController',
|
|
requiresAuthentication: true
|
|
}).when('/homegeniedevices', {
|
|
templateUrl: 'views/homegeniedevice.html',
|
|
controller: 'HomeGenieController',
|
|
requiresAuthentication: true
|
|
}).when('/login', {
|
|
templateUrl: 'views/login.html',
|
|
controller: 'LoginController'
|
|
}).otherwise({
|
|
templateUrl: 'views/configuration.html',
|
|
controller: 'ViewingController',
|
|
requiresAuthentication: true
|
|
});
|
|
});
|
|
|
|
app.run(function ($rootScope, $location, Auth, bridgeService) {
|
|
bridgeService.getHABridgeVersion();
|
|
|
|
$rootScope.$on('securitySetupReceived', function (event, data) {
|
|
Auth.init();
|
|
if (Auth.isLoggedIn()) {
|
|
bridgeService.loadBridgeSettings();
|
|
bridgeService.getSecurityInfo();
|
|
bridgeService.viewMapTypes();
|
|
$location.path("/");
|
|
} else {
|
|
event.preventDefault();
|
|
$location.path("/login");
|
|
}
|
|
});
|
|
|
|
$rootScope.$on('securityError', function (event, data) {
|
|
Auth.logout();
|
|
event.preventDefault();
|
|
$location.path("/login");
|
|
});
|
|
|
|
$rootScope.$on('securityReinit', function (event, data) {
|
|
event.preventDefault();
|
|
bridgeService.state.testuser = "";
|
|
Auth.logout();
|
|
$location.path("/");
|
|
});
|
|
|
|
$rootScope.$on('$routeChangeStart', function (event, next) {
|
|
if (!Auth.checkPermissionForView(next)) {
|
|
event.preventDefault();
|
|
$location.path("/login");
|
|
} else {
|
|
$location.path(next.originalPath);
|
|
|
|
}
|
|
});
|
|
|
|
});
|
|
|
|
String.prototype.replaceAll = function (search, replace) {
|
|
//if replace is not sent, return original string otherwise it will
|
|
//replace search string with 'undefined'.
|
|
if (replace === undefined) {
|
|
return this.toString();
|
|
}
|
|
|
|
return this.replace(new RegExp('[' + search + ']', 'g'), replace);
|
|
};
|
|
|
|
|
|
app.service('bridgeService', function ($rootScope, $http, $base64, $location, ngToast, Upload) {
|
|
var self = this;
|
|
this.state = {
|
|
base: "./api/devices",
|
|
bridgelocation: ".",
|
|
systemsbase: "./system",
|
|
huebase: "./api",
|
|
configs: [],
|
|
backups: [],
|
|
devices: [],
|
|
device: {},
|
|
mapandid: [],
|
|
type: "",
|
|
settings: [],
|
|
myToastMsg: [],
|
|
logMsgs: [],
|
|
loggerInfo: [],
|
|
mapTypes: [],
|
|
olddevicename: "",
|
|
logShowAll: false,
|
|
isInControl: false,
|
|
showVera: false,
|
|
showFibaro: false,
|
|
showHarmony: false,
|
|
showNest: false,
|
|
showHue: false,
|
|
showHal: false,
|
|
showMqtt: false,
|
|
showHass: false,
|
|
showHomeWizard: false,
|
|
showDomoticz: false,
|
|
showSomfy: false,
|
|
showLifx: false,
|
|
showOpenHAB: false,
|
|
showMozIot: false,
|
|
showFHEM: false,
|
|
showBroadlink: false,
|
|
showHomeGenie: false,
|
|
habridgeversion: {},
|
|
viewDevId: "",
|
|
queueDevId: "",
|
|
securityInfo: {},
|
|
filterDevicesByIpAddress: null,
|
|
filterDevicesOnlyFiltered: false,
|
|
filterDeviceType: null
|
|
};
|
|
|
|
this.displayWarn = function (errorTitle, error) {
|
|
var toastContent = errorTitle;
|
|
if (error !== null && typeof (error) !== 'undefined') {
|
|
if (error.data !== null)
|
|
toastContent = toastContent + " " + error.data.message + " with status: " + error.statusText + " - " + error.status;
|
|
else
|
|
toastContent = error;
|
|
}
|
|
ngToast.create({
|
|
className: "warning",
|
|
dismissButton: true,
|
|
dismissOnTimeout: false,
|
|
content: toastContent
|
|
});
|
|
};
|
|
|
|
this.displayError = function (errorTitle, error) {
|
|
var toastContent = errorTitle;
|
|
if (error !== null && typeof (error) !== 'undefined')
|
|
toastContent = toastContent + " " + error.data.message + " with status: " + error.statusText + " - " + error.status;
|
|
ngToast.create({
|
|
className: "danger",
|
|
dismissButton: true,
|
|
dismissOnTimeout: false,
|
|
content: toastContent
|
|
});
|
|
};
|
|
|
|
this.displayErrorMessage = function (errorTitle, errorMessage) {
|
|
ngToast.create({
|
|
className: "danger",
|
|
dismissButton: true,
|
|
dismissOnTimeout: false,
|
|
content: errorTitle + errorMessage
|
|
});
|
|
};
|
|
|
|
this.displaySuccess = function (theTitle) {
|
|
ngToast.create({
|
|
className: "success",
|
|
content: theTitle
|
|
});
|
|
};
|
|
|
|
this.displayTimer = function (theTitle, timeMillis) {
|
|
ngToast.create({
|
|
className: "success",
|
|
timeout: timeMillis,
|
|
dismissOnClick: false,
|
|
content: theTitle + " in " + timeMillis / 1000 + " seconds"
|
|
});
|
|
};
|
|
|
|
this.viewDevices = function () {
|
|
return $http.get(this.state.base).then(
|
|
function (response) {
|
|
self.state.devices = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayError("Cannot get devices from habridge: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.renumberDevices = function () {
|
|
return $http.post(this.state.base + "/exec/renumber").then(
|
|
function (response) {
|
|
self.viewDevices();
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayError("Cannot renumber devices from habridge: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.compareUniqueId = function (r1, r2) {
|
|
if (r1.id === r2.id)
|
|
return 0;
|
|
return parseInt(r1.id) > parseInt(r2.id) ? 1 : -1;
|
|
};
|
|
|
|
this.clearDevice = function () {
|
|
self.state.device = {};
|
|
self.state.olddevicename = null;
|
|
};
|
|
|
|
this.getHABridgeVersion = function () {
|
|
return $http.get(this.state.systemsbase + "/habridge/version").then(
|
|
function (response) {
|
|
self.state.habridgeversion = {
|
|
version: response.data.version,
|
|
isSecure: response.data.isSecure
|
|
};
|
|
$rootScope.$broadcast('securitySetupReceived', 'done');
|
|
},
|
|
function (error) {
|
|
self.displayWarn("Cannot get version: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.getTestUser = function () {
|
|
if (self.state.testuser === undefined || self.state.testuser === "") {
|
|
var linkParams = {};
|
|
linkParams = {
|
|
seconds: 3,
|
|
silent: true
|
|
};
|
|
return $http.put(this.state.systemsbase + "/presslinkbutton", linkParams).then(
|
|
function (response) {
|
|
self.getAUser();
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Cannot get testuser: ", error);
|
|
}
|
|
);
|
|
}
|
|
};
|
|
|
|
this.getAUser = function () {
|
|
return $http.post(this.state.huebase, "{\"devicetype\":\"test_ha_bridge\"}").then(
|
|
function (response) {
|
|
self.state.testuser = response.data[0].success.username;
|
|
self.getWhitelist();
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Cannot get a user: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.getSecurityInfo = function () {
|
|
return $http.get(this.state.systemsbase + "/securityinfo").then(
|
|
function (response) {
|
|
self.state.securityInfo = response.data;
|
|
self.getTestUser();
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Cannot get security info: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.changeSecuritySettings = function (useLinkButton, secureHueApi, execGarden, useHttps, keyfilePath, keyfilePassword) {
|
|
if(useHttps) {
|
|
if(!keyfilePassword || keyfilePassword.length == 0 || !keyfilePassword.trim()) {
|
|
self.displayErrorMessage("Use HTTPS - ", "Key File Password cannot be empty.");
|
|
return;
|
|
}
|
|
|
|
if(!keyfilePath || keyfilePath.length == 0 || !keyfilePath.trim()) {
|
|
self.displayErrorMessage("Use HTTPS - ", "Key File Path cannot be empty.");
|
|
return;
|
|
}
|
|
}
|
|
|
|
var newSecurityInfo = {};
|
|
newSecurityInfo = {
|
|
useLinkButton: useLinkButton,
|
|
secureHueApi: secureHueApi,
|
|
execGarden: execGarden,
|
|
useHttps: useHttps,
|
|
keyfilePath: keyfilePath,
|
|
keyfilePassword: keyfilePassword
|
|
};
|
|
|
|
return $http.post(this.state.systemsbase + "/changesecurityinfo", newSecurityInfo).then(
|
|
function (response) {
|
|
self.state.securityInfo = response.data;
|
|
self.displaySuccess("Updated security settings.");
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Update security settings Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.isSecure = function () {
|
|
if (self.state.habridgeversion === undefined)
|
|
return true;
|
|
if (self.state.habridgeversion.isSecure === undefined)
|
|
return true;
|
|
|
|
return self.state.habridgeversion.isSecure;
|
|
};
|
|
|
|
this.changePassword = function (aPassword, aPassword2) {
|
|
var newUserInfo = {};
|
|
newUserInfo = {
|
|
username: self.state.loggedInUser,
|
|
password: aPassword,
|
|
password2: aPassword2
|
|
};
|
|
var theEncodedPayload = $base64.encode(angular.toJson(newUserInfo));
|
|
return $http.post(this.state.systemsbase + "/setpassword", theEncodedPayload).then(
|
|
function (response) {
|
|
self.displaySuccess("Password updated");
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Update password Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.addUser = function (username, aPassword, aPassword2) {
|
|
var newUserInfo = {};
|
|
newUserInfo = {
|
|
username: username,
|
|
password: aPassword,
|
|
password2: aPassword2
|
|
};
|
|
var theEncodedPayload = $base64.encode(angular.toJson(newUserInfo));
|
|
return $http.put(this.state.systemsbase + "/adduser", theEncodedPayload).then(
|
|
function (response) {
|
|
self.displaySuccess("User added");
|
|
if (!self.isSecure()) {
|
|
self.getHABridgeVersion();
|
|
}
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("User add Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.delUser = function (username) {
|
|
var newUserInfo = {};
|
|
newUserInfo = {
|
|
username: username
|
|
};
|
|
var theEncodedPayload = $base64.encode(angular.toJson(newUserInfo));
|
|
return $http.put(this.state.systemsbase + "/deluser", theEncodedPayload).then(
|
|
function (response) {
|
|
self.displaySuccess("User deleted");
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("User add Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.pushLinkButton = function () {
|
|
return $http.put(this.state.systemsbase + "/presslinkbutton").then(
|
|
function (response) {
|
|
self.displayTimer("Link your device", self.state.settings.linkbuttontimeout * 1000);
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Cannot get security info: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.getWhitelist = function () {
|
|
return $http.get(this.state.systemsbase + "/whitelist").then(
|
|
function (response) {
|
|
self.state.whitelist = response.data;
|
|
},
|
|
function (error) {
|
|
self.displayWarn("Cannot get swhitelist: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.setWhitelist = function (whitelist) {
|
|
return $http.post(this.state.systemsbase + "/setwhitelist", whitelist).then(
|
|
function (response) {
|
|
self.state.whitelist = response.data;
|
|
self.displaySuccess("Updated whitelist.");
|
|
},
|
|
function (error) {
|
|
self.displayWarn("Update whitelist Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.aContainsB = function (a, b) {
|
|
return a.indexOf(b) >= 0;
|
|
};
|
|
|
|
this.deviceContainsType = function (device, aType) {
|
|
if (device.mapType !== undefined && device.mapType !== null && device.mapType.indexOf(aType) >= 0)
|
|
return true;
|
|
|
|
if (device.deviceType !== undefined && device.deviceType !== null && device.deviceType.indexOf(aType) >= 0)
|
|
return true;
|
|
|
|
if (device.onUrl !== undefined && device.onUrl !== null && device.onUrl.indexOf(aType) >= 0)
|
|
return true;
|
|
|
|
if (device.dimUrl !== undefined && device.dimUrl !== null && device.dimUrl.indexOf(aType) >= 0)
|
|
return true;
|
|
|
|
if (device.offUrl !== undefined && device.offUrl !== null && device.offUrl.indexOf(aType) >= 0)
|
|
return true;
|
|
|
|
if (device.colorUrl !== undefined && device.colorUrl !== null && device.colorUrl.indexOf(aType) >= 0)
|
|
return true;
|
|
|
|
|
|
return false;
|
|
};
|
|
|
|
this.compareHarmonyNumber = function (r1, r2) {
|
|
if (r1.device !== undefined) {
|
|
if (r1.device.id === r2.device.id)
|
|
return 0;
|
|
return r1.device.id > r2.device.id ? 1 : -1;
|
|
}
|
|
if (r1.activity !== undefined) {
|
|
if (r1.activity.id === r2.activity.id)
|
|
return 0;
|
|
return r1.activity.id > r2.activity.id ? 1 : -1;
|
|
}
|
|
return 0;
|
|
};
|
|
|
|
this.compareHarmonyLabel = function (r1, r2) {
|
|
if (r1.device !== undefined) {
|
|
if (r1.device.label === r2.device.label)
|
|
return 0;
|
|
return r1.device.label > r2.device.label ? 1 : -1;
|
|
}
|
|
if (r1.activity !== undefined) {
|
|
if (r1.activity.label === r2.activity.label)
|
|
return 0;
|
|
return r1.activity.label > r2.activity.label ? 1 : -1;
|
|
}
|
|
return 0;
|
|
};
|
|
|
|
this.compareHarmonyHub = function (r1, r2) {
|
|
if (r1.hub !== undefined) {
|
|
if (r1.hub === r2.hub)
|
|
return 0;
|
|
return r1.hub > r2.hub ? 1 : -1;
|
|
}
|
|
return 0;
|
|
};
|
|
|
|
this.updateShowVera = function () {
|
|
this.state.showVera = self.state.settings.veraconfigured;
|
|
return;
|
|
};
|
|
|
|
this.updateShowFibaro = function () {
|
|
this.state.showFibaro = self.state.settings.fibaroconfigured;
|
|
return;
|
|
};
|
|
|
|
this.updateShowNest = function () {
|
|
this.state.showNest = self.state.settings.nestconfigured;
|
|
return;
|
|
};
|
|
|
|
this.updateShowHarmony = function () {
|
|
this.state.showHarmony = self.state.settings.harmonyconfigured;
|
|
return;
|
|
};
|
|
|
|
this.updateShowHue = function () {
|
|
this.state.showHue = self.state.settings.hueconfigured;
|
|
return;
|
|
};
|
|
|
|
this.updateShowHal = function () {
|
|
this.state.showHal = self.state.settings.halconfigured;
|
|
return;
|
|
};
|
|
|
|
this.updateShowMqtt = function () {
|
|
this.state.showMqtt = self.state.settings.mqttconfigured;
|
|
return;
|
|
};
|
|
|
|
this.updateShowHomeWizard = function () {
|
|
this.state.showHomeWizard = self.state.settings.homewizardconfigured;
|
|
return;
|
|
};
|
|
|
|
this.updateShowHass = function () {
|
|
this.state.showHass = self.state.settings.hassconfigured;
|
|
return;
|
|
};
|
|
|
|
this.updateShowDomoticz = function () {
|
|
this.state.showDomoticz = self.state.settings.domoticzconfigured;
|
|
return;
|
|
};
|
|
|
|
this.updateShowSomfy = function () {
|
|
this.state.showSomfy = self.state.settings.somfyconfigured;
|
|
return;
|
|
};
|
|
|
|
this.updateShowLifx = function () {
|
|
this.state.showLifx = self.state.settings.lifxconfigured;
|
|
return;
|
|
};
|
|
|
|
this.updateShowOpenHAB = function () {
|
|
this.state.showOpenHAB = self.state.settings.openhabconfigured;
|
|
return;
|
|
};
|
|
|
|
this.updateShowMozIot = function () {
|
|
this.state.showMozIot = self.state.settings.moziotconfigured;
|
|
return;
|
|
};
|
|
|
|
this.updateShowFhem = function () {
|
|
this.state.showFHEM = self.state.settings.fhemconfigured;
|
|
return;
|
|
};
|
|
|
|
this.updateShowBroadlink = function () {
|
|
this.state.showBroadlink = self.state.settings.broadlinkconfigured;
|
|
return;
|
|
};
|
|
|
|
this.updateShowHomeGenie = function () {
|
|
this.state.showHomeGenie = self.state.settings.homegenieconfigured;
|
|
return;
|
|
};
|
|
|
|
this.loadBridgeSettings = function () {
|
|
return $http.get(this.state.systemsbase + "/settings").then(
|
|
function (response) {
|
|
self.state.settings = response.data;
|
|
self.updateShowVera();
|
|
self.updateShowFibaro();
|
|
self.updateShowHarmony();
|
|
self.updateShowNest();
|
|
self.updateShowHue();
|
|
self.updateShowHal();
|
|
self.updateShowMqtt();
|
|
self.updateShowHass();
|
|
self.updateShowHomeWizard();
|
|
self.updateShowDomoticz();
|
|
self.updateShowSomfy();
|
|
self.updateShowLifx();
|
|
self.updateShowOpenHAB();
|
|
self.updateShowMozIot();
|
|
self.updateShowFhem();
|
|
self.updateShowBroadlink();
|
|
self.updateShowHomeGenie();
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Load Bridge Settings Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewBackups = function () {
|
|
return $http.get(this.state.base + "/backup/available").then(
|
|
function (response) {
|
|
self.state.backups = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get Backups Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewConfigs = function () {
|
|
return $http.get(this.state.systemsbase + "/backup/available").then(
|
|
function (response) {
|
|
self.state.configs = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get Configs Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewLogs = function () {
|
|
return $http.get(this.state.systemsbase + "/logmsgs").then(
|
|
function (response) {
|
|
self.state.logMsgs = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get log messages Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewLoggerInfo = function () {
|
|
return $http.get(this.state.systemsbase + "/logmgmt/loggers/" + self.state.logShowAll).then(
|
|
function (response) {
|
|
self.state.loggerInfo = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get logger info Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewNestItems = function () {
|
|
if (!this.state.showNest)
|
|
return;
|
|
return $http.get(this.state.base + "/nest/items").then(
|
|
function (response) {
|
|
self.state.nestitems = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get Nest Items Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewHueDevices = function () {
|
|
if (!this.state.showHue)
|
|
return;
|
|
return $http.get(this.state.base + "/hue/devices").then(
|
|
function (response) {
|
|
self.state.huedevices = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get Hue Items Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewVeraDevices = function () {
|
|
if (!this.state.showVera)
|
|
return;
|
|
return $http.get(this.state.base + "/vera/devices").then(
|
|
function (response) {
|
|
self.state.veradevices = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get Vera Devices Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewVeraScenes = function () {
|
|
if (!this.state.showVera)
|
|
return;
|
|
return $http.get(this.state.base + "/vera/scenes").then(
|
|
function (response) {
|
|
self.state.verascenes = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get Vera Scenes Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewFibaroDevices = function () {
|
|
if (!this.state.showFibaro)
|
|
return;
|
|
return $http.get(this.state.base + "/fibaro/devices").then(
|
|
function (response) {
|
|
self.state.fibarodevices = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get Fibaro Devices Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewFibaroScenes = function () {
|
|
if (!this.state.showFibaro)
|
|
return;
|
|
return $http.get(this.state.base + "/fibaro/scenes").then(
|
|
function (response) {
|
|
self.state.fibaroscenes = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get Fibaro Scenes Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewHarmonyActivities = function () {
|
|
if (!this.state.showHarmony)
|
|
return;
|
|
return $http.get(this.state.base + "/harmony/activities").then(
|
|
function (response) {
|
|
self.state.harmonyactivities = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get Harmony Activities Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewHarmonyDevices = function () {
|
|
if (!this.state.showHarmony)
|
|
return;
|
|
return $http.get(this.state.base + "/harmony/devices").then(
|
|
function (response) {
|
|
self.state.harmonydevices = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get Harmony Devices Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewHalDevices = function () {
|
|
if (!this.state.showHal)
|
|
return;
|
|
return $http.get(this.state.base + "/hal/devices").then(
|
|
function (response) {
|
|
self.state.haldevices = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get Hal Devices Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewMQTTDevices = function () {
|
|
if (!this.state.showMqtt)
|
|
return;
|
|
return $http.get(this.state.base + "/mqtt/devices").then(
|
|
function (response) {
|
|
self.state.mqttbrokers = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get MQTT Devices Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewHassDevices = function () {
|
|
if (!this.state.showHass)
|
|
return;
|
|
return $http.get(this.state.base + "/hass/devices").then(
|
|
function (response) {
|
|
self.state.hassdevices = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get Hass Devices Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewHomeWizardDevices = function () {
|
|
if (!this.state.showHomeWizard)
|
|
return;
|
|
return $http.get(this.state.base + "/homewizard/devices").then(
|
|
function (response) {
|
|
self.state.homewizarddevices = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get HomeWizard Devices Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewDomoticzDevices = function () {
|
|
if (!this.state.showDomoticz)
|
|
return;
|
|
return $http.get(this.state.base + "/domoticz/devices").then(
|
|
function (response) {
|
|
self.state.domoticzdevices = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get Domoticz Devices Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewSomfyDevices = function () {
|
|
if (!this.state.showSomfy)
|
|
return;
|
|
return $http.get(this.state.base + "/somfy/devices").then(
|
|
function (response) {
|
|
self.state.somfydevices = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get Somfy Devices Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
|
|
this.viewLifxDevices = function () {
|
|
if (!this.state.showLifx)
|
|
return;
|
|
return $http.get(this.state.base + "/lifx/devices").then(
|
|
function (response) {
|
|
self.state.lifxdevices = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get Lifx Devices Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewOpenHABDevices = function () {
|
|
if (!this.state.showOpenHAB)
|
|
return;
|
|
return $http.get(this.state.base + "/openhab/devices").then(
|
|
function (response) {
|
|
self.state.openhabdevices = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get OpenHAB Devices Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewMozIotDevices = function () {
|
|
if (!this.state.showMozIot)
|
|
return;
|
|
return $http.get(this.state.base + "/moziot/devices").then(
|
|
function (response) {
|
|
self.state.moziotdevices = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get Mozilla IOT Devices Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewFhemDevices = function () {
|
|
if (!this.state.showFHEM)
|
|
return;
|
|
return $http.get(this.state.base + "/fhem/devices").then(
|
|
function (response) {
|
|
self.state.fhemdevices = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get FHEM Devices Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewBroadlinkDevices = function () {
|
|
if (!this.state.showBroadlink)
|
|
return;
|
|
return $http.get(this.state.base + "/broadlink/devices").then(
|
|
function (response) {
|
|
self.state.broadlinkdevices = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get Broadlink Devices Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.viewHomeGenieDevices = function () {
|
|
if (!this.state.showHomeGenie)
|
|
return;
|
|
return $http.get(this.state.base + "/homegenie/devices").then(
|
|
function (response) {
|
|
self.state.homegeniedevices = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get HomeGenie Devices Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.refreshDevices = function (typeIndex) {
|
|
return $http.get(this.state.base + "/refresh/" + typeIndex).then(
|
|
function (response) {
|
|
self.displaySuccess("Refresh devices request complete");
|
|
},
|
|
function (error) {
|
|
self.displayWarn("Refresh devices request Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.formatCallItem = function (currentItem) {
|
|
if (currentItem.indexOf("item") < 0) {
|
|
if (currentItem.startsWith("[") || currentItem.startsWith("{"))
|
|
currentItem = "[{\"item\":" + currentItem + "}]";
|
|
else
|
|
currentItem = "[{\"item\":\"" + currentItem + "\"}]";
|
|
} else if (currentItem.startsWith("{"))
|
|
currentItem = "[" + currentItem + "]";
|
|
|
|
return currentItem;
|
|
};
|
|
|
|
this.getCallObjects = function (deviceString) {
|
|
if (deviceString === undefined || deviceString === "")
|
|
return null;
|
|
|
|
deviceString = self.formatCallItem(deviceString);
|
|
|
|
var newDevices = angular.fromJson(deviceString);
|
|
var i, s, len = newDevices.length;
|
|
for (i = 0; i < len; ++i) {
|
|
if (i in newDevices) {
|
|
s = newDevices[i];
|
|
if (s.type !== undefined && s.type !== null)
|
|
s.type = self.getMapType(s.type);
|
|
if (angular.isObject(s.item))
|
|
s.item = angular.toJson(s.item);
|
|
}
|
|
}
|
|
return newDevices;
|
|
};
|
|
|
|
this.updateCallObjectsType = function (theDevices) {
|
|
var i, s, type, len = theDevices.length;
|
|
for (i = 0; i < len; ++i) {
|
|
if (i in theDevices) {
|
|
s = theDevices[i];
|
|
if (s.type !== undefined && s.type !== null) {
|
|
type = self.getMapType(s.type[0]);
|
|
s.type = type[0];
|
|
}
|
|
if (s.delay === "" || s.delay === null)
|
|
delete s.delay;
|
|
if (s.count === "" || s.count === null)
|
|
delete s.count;
|
|
if (s.filterIPs === "" || s.filterIPs === null)
|
|
delete s.filterIPs;
|
|
if (s.httpVerb === "" || s.httpVerb === null)
|
|
delete s.httpVerb;
|
|
if (s.httpBody === "" || s.httpBody === null)
|
|
delete s.httpBody;
|
|
if (s.httpHeaders === "" || s.httpHeaders === null)
|
|
delete s.httpHeaders;
|
|
if (s.contentType === "" || s.contentType === null)
|
|
delete s.contentType;
|
|
}
|
|
}
|
|
return theDevices;
|
|
};
|
|
|
|
this.viewMapTypes = function () {
|
|
return $http.get(this.state.base + "/map/types").then(
|
|
function (response) {
|
|
self.state.mapTypes = response.data;
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Get mapTypes Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.getMapType = function (aMapType) {
|
|
var i, s, len = self.state.mapTypes.length;
|
|
for (i = 0; i < len; ++i) {
|
|
if (i in self.state.mapTypes) {
|
|
s = self.state.mapTypes[i];
|
|
if (aMapType === s[0])
|
|
return self.state.mapTypes[i];
|
|
}
|
|
}
|
|
return null;
|
|
};
|
|
|
|
this.updateLogLevels = function (logComponents) {
|
|
return $http.put(this.state.systemsbase + "/logmgmt/update", logComponents).then(
|
|
function (response) {
|
|
self.state.loggerInfo = response.data;
|
|
self.displaySuccess("Updated " + logComponents.length + " loggers for log levels.");
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Update Log components Error: ", error);
|
|
}
|
|
);
|
|
|
|
};
|
|
|
|
this.findDeviceByMapId = function (id, target, type) {
|
|
for (var i = 0; i < this.state.devices.length; i++) {
|
|
if (this.state.devices[i].mapId === id && this.state.devices[i].mapType === type && this.state.devices[i].targetDevice === target)
|
|
return true;
|
|
}
|
|
return false;
|
|
};
|
|
|
|
this.findNestItemByMapId = function (id, type) {
|
|
for (var i = 0; i < this.state.devices.length; i++) {
|
|
if (this.state.devices[i].mapId === id && this.aContainsB(this.state.devices[i].mapType, type))
|
|
return true;
|
|
}
|
|
return false;
|
|
};
|
|
|
|
this.bulkAddDevice = function (devices) {
|
|
return $http.post(this.state.base, devices).then(
|
|
function (response) {
|
|
self.displaySuccess("Bulk device add successful.");
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Bulk Add new Device Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.addDevice = function (aDevice) {
|
|
var device = {};
|
|
angular.extend(device, aDevice);
|
|
if (device.deviceType === null || device.deviceType === "")
|
|
device.deviceType = "custom";
|
|
if (device.targetDevice === null || device.targetDevice === "")
|
|
device.targetDevice = "Encapsulated";
|
|
if (device.id) {
|
|
var putUrl = this.state.base + "/" + device.id;
|
|
return $http.put(putUrl, device).then(
|
|
function (response) {},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Edit Device Error: ", error);
|
|
}
|
|
);
|
|
} else {
|
|
if (device.deviceType === null || device.deviceType === "")
|
|
device.deviceType = "custom";
|
|
return $http.post(this.state.base, device).then(
|
|
function (response) {},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Add new Device Error: ", error);
|
|
}
|
|
);
|
|
}
|
|
};
|
|
|
|
this.backupDeviceDb = function (afilename) {
|
|
return $http.put(this.state.base + "/backup/create", {
|
|
filename: afilename
|
|
}).then(
|
|
function (response) {
|
|
self.viewBackups();
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Backup Device Db Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.restoreBackup = function (afilename) {
|
|
return $http.post(this.state.base + "/backup/restore", {
|
|
filename: afilename
|
|
}).then(
|
|
function (response) {
|
|
self.viewBackups();
|
|
self.viewDevices();
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Backup Db Restore Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.deleteBackup = function (afilename) {
|
|
return $http.post(this.state.base + "/backup/delete", {
|
|
filename: afilename
|
|
}).then(
|
|
function (response) {
|
|
self.viewBackups();
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Delete Backup Db File Error:", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.downloadDeviceBackup = function (afilename) {
|
|
return $http.put(this.state.base + "/backup/download", {
|
|
filename: afilename
|
|
}).then(
|
|
function (response) {
|
|
self.state.backupContent = response.data;
|
|
var blob = new Blob([self.state.backupContent], {
|
|
type: 'text/plain'
|
|
});
|
|
var downloadLink = angular.element('<a></a>');
|
|
downloadLink.attr('href', window.URL.createObjectURL(blob));
|
|
downloadLink.attr('download', afilename);
|
|
downloadLink[0].click();
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Download Backup Db File Error:", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.uploadDeviceFile = function (filename, file) {
|
|
file.upload = Upload.http({
|
|
url: this.state.base + "/backup/upload/" + filename,
|
|
method: 'PUT',
|
|
headers: {
|
|
'Content-Type': file.type
|
|
},
|
|
data: file
|
|
});
|
|
|
|
file.upload.then(function (response) {
|
|
file.result = response.data;
|
|
self.viewBackups();
|
|
}, function (response) {
|
|
if (response.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else if (response.status > 0)
|
|
self.displayWarn('Upload Backup Db File Error:' + response.status + ': ' + response.data);
|
|
});
|
|
|
|
file.upload.progress(function (evt) {
|
|
file.progress = Math.min(100, parseInt(100.0 * evt.loaded / evt.total));
|
|
});
|
|
}
|
|
|
|
this.checkForBridge = function () {
|
|
return $http.get(this.state.bridgelocation + "/description.xml").then(
|
|
function (response) {
|
|
ngToast.dismiss(self.state.myToastMsg);
|
|
self.state.myToastMsg = null;
|
|
self.state.isInControl = false;
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
},
|
|
function (error) {
|
|
setTimeout(function () {
|
|
self.checkForBridge();
|
|
}, 2000);
|
|
}
|
|
);
|
|
|
|
};
|
|
|
|
this.stop = function () {
|
|
self.state.isInControl = true;
|
|
return $http.put(this.state.systemsbase + "/control/stop").then(
|
|
function (response) {
|
|
self.displayError("HABridge is now stopped. Restart must occur from the server.", null);
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayError("HABRidge Stop Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.reinit = function () {
|
|
self.state.isInControl = true;
|
|
return $http.put(this.state.systemsbase + "/control/reinit").then(
|
|
function (response) {
|
|
self.state.myToastMsg = ngToast.create({
|
|
className: "warning",
|
|
dismissButton: false,
|
|
dismissOnTimeout: false,
|
|
content: "HABridge is re-initializing, waiting for completion..."
|
|
});
|
|
setTimeout(function () {
|
|
self.checkForBridge();
|
|
}, 5000);
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("HABRidge Reinit Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.saveSettings = function () {
|
|
return $http.put(this.state.systemsbase + "/settings", this.state.settings).then(
|
|
function (response) {
|
|
self.reinit();
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Save Settings Error: ", error);
|
|
}
|
|
);
|
|
|
|
};
|
|
|
|
this.saveSettingsNoReinit = function () {
|
|
return $http.put(this.state.systemsbase + "/settings", this.state.settings).then(
|
|
function (response) {
|
|
self.displaySuccess("Save Settings completed.");
|
|
},
|
|
function (error) {
|
|
self.displayWarn("Save Settings Error: ", error);
|
|
}
|
|
);
|
|
|
|
};
|
|
|
|
this.backupSettings = function (afilename) {
|
|
return $http.put(this.state.systemsbase + "/backup/create", {
|
|
filename: afilename
|
|
}).then(
|
|
function (response) {
|
|
self.viewConfigs();
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Backup Settings Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.restoreSettings = function (afilename) {
|
|
return $http.post(this.state.systemsbase + "/backup/restore", {
|
|
filename: afilename
|
|
}).then(
|
|
function (response) {
|
|
self.state.settings = response.data;
|
|
self.viewConfigs();
|
|
self.viewDevices();
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Backup Settings Restore Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.deleteSettingsBackup = function (afilename) {
|
|
return $http.post(this.state.systemsbase + "/backup/delete", {
|
|
filename: afilename
|
|
}).then(
|
|
function (response) {
|
|
self.viewConfigs();
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Delete Backup Settings File Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.downloadConfigBackup = function (afilename) {
|
|
return $http.put(this.state.systemsbase + "/backup/download", {
|
|
filename: afilename
|
|
}).then(
|
|
function (response) {
|
|
self.state.backupContent = response.data;
|
|
var blob = new Blob([self.state.backupContent], {
|
|
type: 'text/plain'
|
|
});
|
|
var downloadLink = angular.element('<a></a>');
|
|
downloadLink.attr('href', window.URL.createObjectURL(blob));
|
|
downloadLink.attr('download', afilename);
|
|
downloadLink[0].click();
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Download Backup Config File Error:", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.uploadConfigFile = function (filename, file) {
|
|
file.upload = Upload.http({
|
|
url: this.state.systemsbase + "/backup/upload/" + filename,
|
|
method: 'PUT',
|
|
headers: {
|
|
'Content-Type': file.type
|
|
},
|
|
data: file
|
|
});
|
|
|
|
file.upload.then(function (response) {
|
|
file.result = response.data;
|
|
self.viewConfigs();
|
|
}, function (response) {
|
|
if (response.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else if (response.status > 0)
|
|
self.displayWarn('Upload Backup Config File Error:' + response.status + ': ' + response.data);
|
|
});
|
|
|
|
file.upload.progress(function (evt) {
|
|
file.progress = Math.min(100, parseInt(100.0 * evt.loaded / evt.total));
|
|
});
|
|
}
|
|
|
|
this.deleteDevice = function (id) {
|
|
return $http.delete(this.state.base + "/" + id).then(
|
|
function (response) {
|
|
self.viewDevices();
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Delete Device Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
this.editDevice = function (device) {
|
|
self.state.device = device;
|
|
self.state.olddevicename = device.name;
|
|
};
|
|
|
|
this.editNewDevice = function (device) {
|
|
self.state.device = device;
|
|
};
|
|
|
|
this.toXY = function (red, green, blue) {
|
|
var r = red / 255;
|
|
var g = green / 255;
|
|
var b = blue / 255;
|
|
|
|
//R
|
|
if ( r > 0.04045)
|
|
r = Math.pow(( ( r + 0.055 ) / 1.055 ), 2.4);
|
|
else
|
|
r /= 12.92;
|
|
|
|
//G
|
|
if ( g > 0.04045)
|
|
g = Math.pow(( ( g + 0.055 ) / 1.055 ), 2.4);
|
|
else
|
|
g /= 12.92;
|
|
|
|
//B
|
|
if ( b > 0.04045)
|
|
b = Math.pow(( ( b + 0.055 ) / 1.055 ), 2.4);
|
|
else
|
|
b /= 12.92;
|
|
|
|
r *= 100;
|
|
g *= 100;
|
|
b *= 100;
|
|
|
|
var x = 0.412453 * r + 0.35758 * g + 0.180423 * b;
|
|
var y = 0.212671 * r + 0.71516 * g + 0.072169 * b;
|
|
var z = 0.019334 * r + 0.119193 * g + 0.950227 * b;
|
|
|
|
var newX = x / (x + y + z);
|
|
var newY = y / (x + y + z);
|
|
var interBright = (y / 100) * 254;
|
|
var newBright = Math.round(interBright);
|
|
|
|
return [newX.toPrecision(6), newY.toPrecision(6), newBright];
|
|
};
|
|
|
|
this.testUrl = function (device, type, value, valueType) {
|
|
var msgDescription = "unknown";
|
|
self.getTestUser();
|
|
var testUrl = this.state.huebase + "/" + this.state.testuser + "/lights/" + device.id + "/state";
|
|
var addComma = false;
|
|
var testBody = "{";
|
|
if (type === "off") {
|
|
testBody = testBody + "\"on\":false";
|
|
addComma = true;
|
|
}
|
|
if (type === "on") {
|
|
testBody = testBody + "\"on\":true";
|
|
addComma = true;
|
|
}
|
|
if (valueType === "dim" && value) {
|
|
if (addComma)
|
|
testBody = testBody + ",";
|
|
testBody = testBody + "\"bri\":" + value;
|
|
addComma = true;
|
|
}
|
|
if (valueType === "color" && value) {
|
|
if (addComma)
|
|
testBody = testBody + ",";
|
|
testBody = testBody + "\"xy\": [" + value[0] + "," + value[1] + "],\"bri\":" + value[2];
|
|
}
|
|
testBody = testBody + "}";
|
|
if (testBody === "{}") {
|
|
self.displayWarn("No value available for test call...", null);
|
|
return;
|
|
}
|
|
|
|
$http.put(testUrl, testBody).then(
|
|
function (response) {
|
|
if (typeof (response.data[0].success) !== 'undefined') {
|
|
msgDescription = "success " + angular.toJson(response.data);
|
|
}
|
|
if (typeof (response.data[0].error) !== 'undefined') {
|
|
if (response.data[0].error.description.indexOf("unauthorized") > -1) {
|
|
self.displayWarn("Authorization error, please retry...", null);
|
|
} else {
|
|
msgDescription = "error " + angular.toJson(response.data[0].error);
|
|
self.displayErrorMessage("Request Error, Please look in your habridge log: ", msgDescription);
|
|
}
|
|
return;
|
|
}
|
|
|
|
self.displaySuccess("Request Executed: " + msgDescription);
|
|
},
|
|
function (error) {
|
|
if (error.status === 401)
|
|
$rootScope.$broadcast('securityReinit', 'done');
|
|
else
|
|
self.displayWarn("Request Error, Pleae look in your habridge log: ", error);
|
|
}
|
|
);
|
|
return;
|
|
};
|
|
|
|
this.formatUrlItem = function (currentItem) {
|
|
var formattedItem = "";
|
|
if (currentItem !== "") {
|
|
currentItem = self.formatCallItem(currentItem);
|
|
formattedItem = currentItem.substr(0, currentItem.length - 1) + ",{\"item\":";
|
|
} else
|
|
formattedItem = "[{\"item\":";
|
|
|
|
return formattedItem;
|
|
};
|
|
|
|
this.buildUrls = function (onpayload, dimpayload, offpayload, colorpayload, isObject, anId, deviceName, deviceTarget, deviceType, deviceMapType, count, delay) {
|
|
var currentOn = "";
|
|
var currentDim = "";
|
|
var currentOff = "";
|
|
var currentColor = "";
|
|
if (self.state.device !== undefined && self.state.device !== null) {
|
|
if (self.state.device.onUrl !== undefined && self.state.device.onUrl !== null && self.state.device.onUrl !== "")
|
|
currentOn = self.state.device.onUrl;
|
|
if (self.state.device.dimUrl !== undefined && self.state.device.dimUrl !== null && self.state.device.dimUrl !== "")
|
|
currentDim = self.state.device.dimUrl;
|
|
if (self.state.device.offUrl !== undefined && self.state.device.offUrl !== null && self.state.device.offUrl !== "")
|
|
currentOff = self.state.device.offUrl;
|
|
if (self.state.device.colorUrl !== undefined && self.state.device.colorUrl !== null && self.state.device.colorUrl !== "")
|
|
currentColor = self.state.device.colorUrl;
|
|
}
|
|
if (self.state.device !== undefined && self.state.device !== null && self.state.device.mapType !== undefined && self.state.device.mapType !== null && self.state.device.mapType !== "") {
|
|
self.state.device.mapId = self.state.device.mapId + "-" + anId;
|
|
if (dimpayload !== undefined && dimpayload !== null && dimpayload !== "") {
|
|
self.state.device.dimUrl = self.formatUrlItem(currentDim);
|
|
}
|
|
|
|
if (onpayload !== undefined && onpayload !== null && onpayload !== "") {
|
|
self.state.device.onUrl = self.formatUrlItem(currentOn);
|
|
}
|
|
|
|
if (offpayload !== undefined && offpayload !== null && offpayload !== "") {
|
|
self.state.device.offUrl = self.formatUrlItem(currentOff);
|
|
}
|
|
if (colorpayload !== undefined && colorpayload !== null && colorpayload !== "") {
|
|
self.state.device.colorUrl = self.formatUrlItem(currentColor);
|
|
}
|
|
} else if (self.state.device === undefined || self.state.device === null || self.state.device.mapType === undefined || self.state.device.mapType === null || self.state.device.mapType === "") {
|
|
this.clearDevice();
|
|
self.state.device.deviceType = deviceType;
|
|
self.state.device.name = deviceName;
|
|
self.state.device.targetDevice = deviceTarget;
|
|
self.state.device.mapType = deviceMapType;
|
|
self.state.device.mapId = anId;
|
|
if (dimpayload !== undefined && dimpayload !== null && dimpayload !== "")
|
|
self.state.device.dimUrl = "[{\"item\":";
|
|
if (onpayload !== undefined && onpayload !== null && onpayload !== "")
|
|
self.state.device.onUrl = "[{\"item\":";
|
|
if (offpayload !== undefined && offpayload !== null && offpayload !== "")
|
|
self.state.device.offUrl = "[{\"item\":";
|
|
if (colorpayload !== undefined && colorpayload !== null && colorpayload !== "")
|
|
self.state.device.colorUrl = "[{\"item\":";
|
|
}
|
|
|
|
if (isObject) {
|
|
if (dimpayload !== undefined && dimpayload !== null && dimpayload !== "")
|
|
self.state.device.dimUrl = self.state.device.dimUrl + dimpayload;
|
|
if (onpayload !== undefined && onpayload !== null && onpayload !== "")
|
|
self.state.device.onUrl = self.state.device.onUrl + onpayload;
|
|
if (offpayload !== undefined && offpayload !== null && offpayload !== "")
|
|
self.state.device.offUrl = self.state.device.offUrl + offpayload;
|
|
if (colorpayload !== undefined && colorpayload !== null && colorpayload !== "")
|
|
self.state.device.colorUrl = self.state.device.colorUrl + colorpayload;
|
|
|
|
} else {
|
|
if (dimpayload !== undefined && dimpayload !== null && dimpayload !== "")
|
|
self.state.device.dimUrl = self.state.device.dimUrl + "\"" + dimpayload + "\"";
|
|
if (onpayload !== undefined && onpayload !== null && onpayload !== "")
|
|
self.state.device.onUrl = self.state.device.onUrl + "\"" + onpayload + "\"";
|
|
if (offpayload !== undefined && offpayload !== null && offpayload !== "")
|
|
self.state.device.offUrl = self.state.device.offUrl + "\"" + offpayload + "\"";
|
|
if (colorpayload !== undefined && colorpayload !== null && colorpayload !== "")
|
|
self.state.device.colorUrl = self.state.device.colorUrl + "\"" + colorpayload + "\"";
|
|
}
|
|
|
|
if (count !== undefined && count !== null && count !== "") {
|
|
if (dimpayload !== undefined && dimpayload !== null && dimpayload !== "")
|
|
self.state.device.dimUrl = self.state.device.dimUrl + ",\"count\":\"" + count;
|
|
if (onpayload !== undefined && onpayload !== null && onpayload !== "")
|
|
self.state.device.onUrl = self.state.device.onUrl + ",\"count\":\"" + count;
|
|
if (offpayload !== undefined && offpayload !== null && offpayload !== "")
|
|
self.state.device.offUrl = self.state.device.offUrl + ",\"count\":\"" + count;
|
|
if (colorpayload !== undefined && colorpayload !== null && colorpayload !== "")
|
|
self.state.device.colorUrl = self.state.device.colorUrl + ",\"count\":\"" + count;
|
|
}
|
|
if (delay !== undefined && delay !== null && delay !== "") {
|
|
if (dimpayload !== undefined && dimpayload !== null && dimpayload !== "")
|
|
self.state.device.dimUrl = self.state.device.dimUrl + ",\"delay\":\"" + delay;
|
|
if (onpayload !== undefined && onpayload !== null && onpayload !== "")
|
|
self.state.device.onUrl = self.state.device.onUrl + ",\"delay\":\"" + delay;
|
|
if (offpayload !== undefined && offpayload !== null && offpayload !== "")
|
|
self.state.device.offUrl = self.state.device.offUrl + ",\"delay\":\"" + delay;
|
|
if (colorpayload !== undefined && colorpayload !== null && colorpayload !== "")
|
|
self.state.device.colorUrl = self.state.device.colorUrl + ",\"delay\":\"" + delay;
|
|
}
|
|
if (dimpayload !== undefined && dimpayload !== null && dimpayload !== "")
|
|
self.state.device.dimUrl = self.state.device.dimUrl + ",\"type\":\"" + deviceMapType + "\"}]";
|
|
if (onpayload !== undefined && onpayload !== null && onpayload !== "")
|
|
self.state.device.onUrl = self.state.device.onUrl + ",\"type\":\"" + deviceMapType + "\"}]";
|
|
if (offpayload !== undefined && offpayload !== null && offpayload !== "")
|
|
self.state.device.offUrl = self.state.device.offUrl + ",\"type\":\"" + deviceMapType + "\"}]";
|
|
if (colorpayload !== undefined && colorpayload !== null && colorpayload !== "")
|
|
self.state.device.colorUrl = self.state.device.colorUrl + ",\"type\":\"" + deviceMapType + "\"}]";
|
|
};
|
|
});
|
|
|
|
app.controller('SystemController', function ($scope, $location, bridgeService, ngDialog) {
|
|
bridgeService.viewConfigs();
|
|
bridgeService.loadBridgeSettings();
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.optionalbackupname = "";
|
|
$scope.bridge.isInControl = false;
|
|
$scope.visible = false;
|
|
$scope.imgUrl = "glyphicon glyphicon-plus";
|
|
$scope.newhassport = "8123";
|
|
$scope.newdomoticzport = "8080";
|
|
$scope.newopenhabport = "8080";
|
|
$scope.newfhemport = "8080";
|
|
$scope.addVeratoSettings = function (newveraname, newveraip) {
|
|
if ($scope.bridge.settings.veraaddress === undefined || $scope.bridge.settings.veraaddress === null) {
|
|
$scope.bridge.settings.veraaddress = {
|
|
devices: []
|
|
};
|
|
}
|
|
var newVera = {
|
|
name: newveraname,
|
|
ip: newveraip
|
|
};
|
|
$scope.bridge.settings.veraaddress.devices.push(newVera);
|
|
$scope.newveraname = null;
|
|
$scope.newveraip = null;
|
|
};
|
|
$scope.removeVeratoSettings = function (veraname, veraip) {
|
|
for (var i = $scope.bridge.settings.veraaddress.devices.length - 1; i >= 0; i--) {
|
|
if ($scope.bridge.settings.veraaddress.devices[i].name === veraname && $scope.bridge.settings.veraaddress.devices[i].ip === veraip) {
|
|
$scope.bridge.settings.veraaddress.devices.splice(i, 1);
|
|
}
|
|
}
|
|
};
|
|
$scope.addFibarotoSettings = function (newfibaroname, newfibaroip, newfibaroport, newfibarousername, newfibaropassword, filters) {
|
|
if ($scope.bridge.settings.fibaroaddress === undefined || $scope.bridge.settings.fibaroaddress === null) {
|
|
$scope.bridge.settings.fibaroaddress = {
|
|
devices: []
|
|
};
|
|
}
|
|
var stringFilter = angular.toJson(filters);
|
|
var newFibaro = {
|
|
name: newfibaroname,
|
|
ip: newfibaroip,
|
|
port: newfibaroport,
|
|
username: newfibarousername,
|
|
password: newfibaropassword,
|
|
extensions: filters
|
|
};
|
|
$scope.bridge.settings.fibaroaddress.devices.push(newFibaro);
|
|
$scope.newfibaroname = null;
|
|
$scope.newfibaroip = null;
|
|
$scope.newfibaroport = null;
|
|
$scope.newfibarousername = null;
|
|
$scope.newfibaropassword = null;
|
|
};
|
|
$scope.removeFibarotoSettings = function (fibaroname, fibaroip, fibaroport) {
|
|
for (var i = $scope.bridge.settings.fibaroaddress.devices.length - 1; i >= 0; i--) {
|
|
if ($scope.bridge.settings.fibaroaddress.devices[i].name === fibaroname && $scope.bridge.settings.fibaroaddress.devices[i].ip === fibaroip && $scope.bridge.settings.fibaroaddress.devices[i].port === fibaroport) {
|
|
$scope.bridge.settings.fibaroaddress.devices.splice(i, 1);
|
|
}
|
|
}
|
|
};
|
|
$scope.addHarmonytoSettings = function (newharmonyname, newharmonyip, newharmonywebhook) {
|
|
if ($scope.bridge.settings.harmonyaddress === undefined || $scope.bridge.settings.harmonyaddress === null) {
|
|
$scope.bridge.settings.harmonyaddress = {
|
|
devices: []
|
|
};
|
|
}
|
|
var newharmony = {
|
|
name: newharmonyname,
|
|
ip: newharmonyip,
|
|
webhook: newharmonywebhook
|
|
};
|
|
$scope.bridge.settings.harmonyaddress.devices.push(newharmony);
|
|
$scope.newharmonyname = null;
|
|
$scope.newharmonyip = null;
|
|
};
|
|
$scope.removeHarmonytoSettings = function (harmonyname, harmonyip) {
|
|
for (var i = $scope.bridge.settings.harmonyaddress.devices.length - 1; i >= 0; i--) {
|
|
if ($scope.bridge.settings.harmonyaddress.devices[i].name === harmonyname && $scope.bridge.settings.harmonyaddress.devices[i].ip === harmonyip) {
|
|
$scope.bridge.settings.harmonyaddress.devices.splice(i, 1);
|
|
}
|
|
}
|
|
};
|
|
$scope.addHuetoSettings = function (newhuename, newhueip) {
|
|
if ($scope.bridge.settings.hueaddress === undefined || $scope.bridge.settings.hueaddress === null) {
|
|
$scope.bridge.settings.hueaddress = {
|
|
devices: []
|
|
};
|
|
}
|
|
var newhue = {
|
|
name: newhuename,
|
|
ip: newhueip
|
|
};
|
|
$scope.bridge.settings.hueaddress.devices.push(newhue);
|
|
$scope.newhuename = null;
|
|
$scope.newhueip = null;
|
|
};
|
|
$scope.removeHuetoSettings = function (huename, hueip) {
|
|
for (var i = $scope.bridge.settings.hueaddress.devices.length - 1; i >= 0; i--) {
|
|
if ($scope.bridge.settings.hueaddress.devices[i].name === huename && $scope.bridge.settings.hueaddress.devices[i].ip === hueip) {
|
|
$scope.bridge.settings.hueaddress.devices.splice(i, 1);
|
|
}
|
|
}
|
|
};
|
|
$scope.addHaltoSettings = function (newhalname, newhalip, newhalsecure, newhaltoken) {
|
|
if ($scope.bridge.settings.haladdress === undefined || $scope.bridge.settings.haladdress === null) {
|
|
$scope.bridge.settings.haladdress = {
|
|
devices: []
|
|
};
|
|
}
|
|
var newhal = {
|
|
name: newhalname,
|
|
ip: newhalip,
|
|
secure: newhalsecure,
|
|
password: newhaltoken
|
|
};
|
|
$scope.bridge.settings.haladdress.devices.push(newhal);
|
|
$scope.newhalname = null;
|
|
$scope.newhalip = null;
|
|
};
|
|
$scope.removeHaltoSettings = function (halname, halip) {
|
|
for (var i = $scope.bridge.settings.haladdress.devices.length - 1; i >= 0; i--) {
|
|
if ($scope.bridge.settings.haladdress.devices[i].name === halname && $scope.bridge.settings.haladdress.devices[i].ip === halip) {
|
|
$scope.bridge.settings.haladdress.devices.splice(i, 1);
|
|
}
|
|
}
|
|
};
|
|
$scope.addMQTTtoSettings = function (newmqttname, newmqttip, newmqttusername, newmqttpassword) {
|
|
if ($scope.bridge.settings.mqttaddress === undefined || $scope.bridge.settings.mqttaddress === null) {
|
|
$scope.bridge.settings.mqttaddress = {
|
|
devices: []
|
|
};
|
|
}
|
|
var newmqtt = {
|
|
name: newmqttname,
|
|
ip: newmqttip,
|
|
username: newmqttusername,
|
|
password: newmqttpassword
|
|
};
|
|
$scope.bridge.settings.mqttaddress.devices.push(newmqtt);
|
|
$scope.newmqttname = null;
|
|
$scope.newmqttip = null;
|
|
$scope.newmqttusername = null;
|
|
$scope.newmqttpassword = null;
|
|
};
|
|
$scope.removeMQTTtoSettings = function (mqttname, mqttip) {
|
|
for (var i = $scope.bridge.settings.mqttaddress.devices.length - 1; i >= 0; i--) {
|
|
if ($scope.bridge.settings.mqttaddress.devices[i].name === mqttname && $scope.bridge.settings.mqttaddress.devices[i].ip === mqttip) {
|
|
$scope.bridge.settings.mqttaddress.devices.splice(i, 1);
|
|
}
|
|
}
|
|
};
|
|
$scope.addHasstoSettings = function (newhassname, newhassip, newhassport, newhasspassword, newhasssecure, newhassauth) {
|
|
if ($scope.bridge.settings.hassaddress === undefined || $scope.bridge.settings.hassaddress === null) {
|
|
$scope.bridge.settings.hassaddress = {
|
|
devices: []
|
|
};
|
|
}
|
|
var newhass = {
|
|
name: newhassname,
|
|
ip: newhassip,
|
|
port: newhassport,
|
|
password: newhasspassword,
|
|
secure: newhasssecure,
|
|
extensions: newhassauth
|
|
};
|
|
$scope.bridge.settings.hassaddress.devices.push(newhass);
|
|
$scope.newhassname = null;
|
|
$scope.newhassip = null;
|
|
$scope.newhassport = null;
|
|
$scope.newhasspassword = null;
|
|
$scope.newhassport = "8123";
|
|
};
|
|
$scope.removeHasstoSettings = function (hassname, hassip) {
|
|
for (var i = $scope.bridge.settings.hassaddress.devices.length - 1; i >= 0; i--) {
|
|
if ($scope.bridge.settings.hassaddress.devices[i].name === hassname && $scope.bridge.settings.hassaddress.devices[i].ip === hassip) {
|
|
$scope.bridge.settings.hassaddress.devices.splice(i, 1);
|
|
}
|
|
}
|
|
};
|
|
$scope.addHomeWizardtoSettings = function (newhomewizardname, newhomewizardip, newhomewizardusername, newhomewizardpassword) {
|
|
if ($scope.bridge.settings.homewizardaddress === undefined || $scope.bridge.settings.homewizardaddress === null) {
|
|
$scope.bridge.settings.homewizardaddress = {
|
|
devices: []
|
|
};
|
|
}
|
|
var newhomewizard = {
|
|
name: newhomewizardname,
|
|
ip: newhomewizardip,
|
|
username: newhomewizardusername,
|
|
password: newhomewizardpassword
|
|
};
|
|
$scope.bridge.settings.homewizardaddress.devices.push(newhomewizard);
|
|
$scope.newhomewizardname = null;
|
|
$scope.newhomewizardip = null;
|
|
$scope.newhomewizardusername = null;
|
|
$scope.newhomewizardpassword = null;
|
|
};
|
|
$scope.removeHomeWizardtoSettings = function (homewizardname, homewizardip) {
|
|
for (var i = $scope.bridge.settings.homewizardaddress.devices.length - 1; i >= 0; i--) {
|
|
if ($scope.bridge.settings.homewizardaddress.devices[i].name === homewizardname && $scope.bridge.settings.homewizardaddress.devices[i].ip === homewizardip) {
|
|
$scope.bridge.settings.homewizardaddress.devices.splice(i, 1);
|
|
}
|
|
}
|
|
};
|
|
$scope.addDomoticztoSettings = function (newdomoticzname, newdomoticzip, newdomoticzport, newdomoticzusername, newdomoticzpassword, newdomoticzsecure) {
|
|
if ($scope.bridge.settings.domoticzaddress === undefined || $scope.bridge.settings.domoticzaddress === null) {
|
|
$scope.bridge.settings.domoticzaddress = {
|
|
devices: []
|
|
};
|
|
}
|
|
var newdomoticz = {
|
|
name: newdomoticzname,
|
|
ip: newdomoticzip,
|
|
port: newdomoticzport,
|
|
username: newdomoticzusername,
|
|
password: newdomoticzpassword,
|
|
secure: newdomoticzsecure
|
|
};
|
|
$scope.bridge.settings.domoticzaddress.devices.push(newdomoticz);
|
|
$scope.newdomoticzname = null;
|
|
$scope.newdomoticzip = null;
|
|
$scope.newdomoticzport = "8080";
|
|
$scope.newdomoticzpassword = null;
|
|
};
|
|
$scope.removeDomoticztoSettings = function (domoticzname, domoticzip) {
|
|
for (var i = $scope.bridge.settings.domoticzaddress.devices.length - 1; i >= 0; i--) {
|
|
if ($scope.bridge.settings.domoticzaddress.devices[i].name === domoticzname && $scope.bridge.settings.domoticzaddress.devices[i].ip === domoticzip) {
|
|
$scope.bridge.settings.domoticzaddress.devices.splice(i, 1);
|
|
}
|
|
}
|
|
};
|
|
$scope.addSomfytoSettings = function (newsomfyname, newsomfyip, newsomfyusername, newsomfypassword) {
|
|
if ($scope.bridge.settings.somfyaddress == null) {
|
|
$scope.bridge.settings.somfyaddress = {
|
|
devices: []
|
|
};
|
|
}
|
|
var newSomfy = {
|
|
name: newsomfyname,
|
|
ip: newsomfyip,
|
|
username: newsomfyusername,
|
|
password: newsomfypassword
|
|
};
|
|
$scope.bridge.settings.somfyaddress.devices.push(newSomfy);
|
|
$scope.newsomfyname = null;
|
|
$scope.newsomfyip = null;
|
|
$scope.newsomfyusername = null;
|
|
$scope.newsomfypassword = null;
|
|
};
|
|
$scope.removeSomfytoSettings = function (somfyname, somfyip) {
|
|
for (var i = $scope.bridge.settings.somfyaddress.devices.length - 1; i >= 0; i--) {
|
|
if ($scope.bridge.settings.somfyaddress.devices[i].name === somfyname && $scope.bridge.settings.somfyaddress.devices[i].ip === somfyip) {
|
|
$scope.bridge.settings.somfyaddress.devices.splice(i, 1);
|
|
}
|
|
}
|
|
};
|
|
$scope.addOpenHABtoSettings = function (newopenhabname, newopenhabip, newopenhabport, newopenhabusername, newopenhabpassword, newopenhabsecure) {
|
|
if ($scope.bridge.settings.openhabaddress === undefined || $scope.bridge.settings.openhabaddress === null) {
|
|
$scope.bridge.settings.openhabaddress = {
|
|
devices: []
|
|
};
|
|
}
|
|
var newopenhab = {
|
|
name: newopenhabname,
|
|
ip: newopenhabip,
|
|
port: newopenhabport,
|
|
username: newopenhabusername,
|
|
password: newopenhabpassword,
|
|
secure: newopenhabsecure
|
|
};
|
|
$scope.bridge.settings.openhabaddress.devices.push(newopenhab);
|
|
$scope.newopenhabname = null;
|
|
$scope.newopenhabip = null;
|
|
$scope.newopenhabport = "8080";
|
|
$scope.newopenhabusername = null;
|
|
$scope.newopenhabpassword = null;
|
|
};
|
|
$scope.removeOpenHABtoSettings = function (openhabname, openhabip) {
|
|
for (var i = $scope.bridge.settings.openhabaddress.devices.length - 1; i >= 0; i--) {
|
|
if ($scope.bridge.settings.openhabaddress.devices[i].name === openhabname && $scope.bridge.settings.openhabaddress.devices[i].ip === openhabip) {
|
|
$scope.bridge.settings.openhabaddress.devices.splice(i, 1);
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.addMozIottoSettings = function (newmoziotname, newmoziotip, newmoziotport, newmoziotusername, newmoziotpassword, newmoziotwebhook, newmoziotsecure) {
|
|
if ($scope.bridge.settings.moziotaddress === undefined || $scope.bridge.settings.moziotaddress === null) {
|
|
$scope.bridge.settings.moziotaddress = {
|
|
devices: []
|
|
};
|
|
}
|
|
var newmoziot = {
|
|
name: newmoziotname,
|
|
ip: newmoziotip,
|
|
port: newmoziotport,
|
|
username: newmoziotusername,
|
|
password: newmoziotpassword,
|
|
webhook: newmoziotwebhook,
|
|
secure: newmoziotsecure
|
|
};
|
|
$scope.bridge.settings.moziotaddress.devices.push(newmoziot);
|
|
$scope.newmoziotname = null;
|
|
$scope.newmoziotip = null;
|
|
$scope.newmoziotport = "4443";
|
|
$scope.newmoziotusername = null;
|
|
$scope.newmoziotpassword = null;
|
|
$scope.newmoziotwebhook = null;
|
|
};
|
|
$scope.removeMozIottoSettings = function (moziotname, moziotip) {
|
|
for (var i = $scope.bridge.settings.moziotaddress.devices.length - 1; i >= 0; i--) {
|
|
if ($scope.bridge.settings.moziotaddress.devices[i].name === moziotname && $scope.bridge.settings.moziotaddress.devices[i].ip === moziotip) {
|
|
$scope.bridge.settings.moziotaddress.devices.splice(i, 1);
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.addFhemtoSettings = function (newfhemname, newfhemip, newfhemport, newfhemusername, newfhempassword, newfhemwebhook, newfhemsecure) {
|
|
if ($scope.bridge.settings.fhemaddress === undefined || $scope.bridge.settings.fhemaddress === null) {
|
|
$scope.bridge.settings.fhemaddress = {
|
|
devices: []
|
|
};
|
|
}
|
|
var newfhem = {
|
|
name: newfhemname,
|
|
ip: newfhemip,
|
|
port: newfhemport,
|
|
username: newfhemusername,
|
|
password: newfhempassword,
|
|
secure: newfhemsecure,
|
|
webhook: newfhemwebhook
|
|
};
|
|
$scope.bridge.settings.fhemaddress.devices.push(newfhem);
|
|
$scope.newfhemname = null;
|
|
$scope.newfhemip = null;
|
|
$scope.newfhemport = "8080";
|
|
$scope.newfhemusername = null;
|
|
$scope.newfhempassword = null;
|
|
$scope.newfhemwebhook = null;
|
|
};
|
|
$scope.removeFhemtoSettings = function (fhemname, fhemip) {
|
|
for (var i = $scope.bridge.settings.fhemaddress.devices.length - 1; i >= 0; i--) {
|
|
if ($scope.bridge.settings.fhemaddress.devices[i].name === fhemname && $scope.bridge.settings.fhemaddress.devices[i].ip === fhemip) {
|
|
$scope.bridge.settings.fhemaddress.devices.splice(i, 1);
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.addHomeGenietoSettings = function (newhomegeniename, newhomegenieip, newhomegenieport, newhomegenieusername, newhomegeniepassword, newhomegeniewebhook, newhomegeniesecure, newhomegenieothertypes) {
|
|
if ($scope.bridge.settings.homegenieaddress === undefined || $scope.bridge.settings.homegenieaddress === null) {
|
|
$scope.bridge.settings.homegenieaddress = {
|
|
devices: []
|
|
};
|
|
}
|
|
|
|
var othertypes = [];
|
|
var count = 0;
|
|
var theModuleTypes = [];
|
|
|
|
if(newhomegenieothertypes && newhomegenieothertypes.trim() && newhomegenieothertypes.length > 0) {
|
|
othertypes = newhomegenieothertypes.split(",");
|
|
if (othertypes.length > 0) {
|
|
for (var i = 0; i < othertypes.length; i++) {
|
|
var aType = othertypes[i].trim();
|
|
if (aType.length > 0) {
|
|
var moduleType = {
|
|
moduleType: aType
|
|
};
|
|
theModuleTypes.push(moduleType);
|
|
count++;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
var theExtension;
|
|
if (count == 0) {
|
|
theExtension = undefined;
|
|
} else {
|
|
theExtension = {
|
|
moduleTypes: theModuleTypes
|
|
}
|
|
|
|
}
|
|
|
|
var newhomegenie = {
|
|
name: newhomegeniename,
|
|
ip: newhomegenieip,
|
|
port: newhomegenieport,
|
|
username: newhomegenieusername,
|
|
password: newhomegeniepassword,
|
|
secure: newhomegeniesecure,
|
|
webhook: newhomegeniewebhook,
|
|
extensions: theExtension
|
|
};
|
|
$scope.bridge.settings.homegenieaddress.devices.push(newhomegenie);
|
|
$scope.newhomegeniename = null;
|
|
$scope.newhomegenieip = null;
|
|
$scope.newhomegenieport = null;
|
|
$scope.newhomegenieusername = null;
|
|
$scope.newhomegeniepassword = null;
|
|
$scope.newhomegeniewebhook = null;
|
|
$scope.newhomegenieextensions = null;
|
|
};
|
|
|
|
$scope.updateModuleTypes = function (theIndex, homegenieExtensions) {
|
|
var othertypes = [];
|
|
if(homegenieExtensions != undefined)
|
|
othertypes = homegenieExtensions.split(",");
|
|
var theModuleTypes = [];
|
|
var count = 0;
|
|
if (othertypes.length > 0) {
|
|
for (var x = 0; x < othertypes.length; x++) {
|
|
var aType = othertypes[x].trim();
|
|
if (aType.length > 0) {
|
|
var moduleType = {
|
|
moduleType: aType
|
|
};
|
|
theModuleTypes.push(moduleType);
|
|
count++;
|
|
}
|
|
}
|
|
}
|
|
var theExtension;
|
|
if (count == 0) {
|
|
theExtension = undefined;
|
|
} else {
|
|
theExtension = {
|
|
moduleTypes: theModuleTypes
|
|
}
|
|
|
|
}
|
|
$scope.bridge.settings.homegenieaddress.devices[theIndex].extensions = theExtension;
|
|
};
|
|
|
|
$scope.convertModuleTypes = function (theIndex) {
|
|
|
|
var displayExtension = "";
|
|
if ($scope.bridge.settings.homegenieaddress.devices[theIndex].extensions != undefined && $scope.bridge.settings.homegenieaddress.devices[theIndex].extensions.moduleTypes != undefined) {
|
|
for (var i = 0; i < $scope.bridge.settings.homegenieaddress.devices[theIndex].extensions.moduleTypes.length; i++) {
|
|
displayExtension = displayExtension + $scope.bridge.settings.homegenieaddress.devices[theIndex].extensions.moduleTypes[i].moduleType;
|
|
}
|
|
}
|
|
|
|
return displayExtension;
|
|
};
|
|
|
|
$scope.removeHomeGenietoSettings = function (homegeniename, homegenieip) {
|
|
for (var i = $scope.bridge.settings.homegenieaddress.devices.length - 1; i >= 0; i--) {
|
|
if ($scope.bridge.settings.homegenieaddress.devices[i].name === homegeniename && $scope.bridge.settings.homegenieaddress.devices[i].ip === homegenieip) {
|
|
$scope.bridge.settings.homegenieaddress.devices.splice(i, 1);
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.bridgeReinit = function () {
|
|
bridgeService.reinit();
|
|
};
|
|
$scope.bridgeStop = function () {
|
|
bridgeService.stop();
|
|
};
|
|
$scope.saveSettings = function () {
|
|
bridgeService.saveSettings();
|
|
};
|
|
$scope.goBridgeUrl = function (url) {
|
|
window.open(url, "_blank");
|
|
};
|
|
$scope.backupSettings = function (optionalbackupname) {
|
|
bridgeService.backupSettings(optionalbackupname);
|
|
};
|
|
$scope.restoreSettings = function (backupname) {
|
|
bridgeService.restoreSettings(backupname);
|
|
};
|
|
$scope.deleteSettingsBackup = function (backupname) {
|
|
bridgeService.deleteSettingsBackup(backupname);
|
|
};
|
|
|
|
$scope.downloadBackup = function (backupname) {
|
|
bridgeService.downloadConfigBackup(backupname);
|
|
};
|
|
|
|
$scope.uploadConfigFile = function (aFilename, aConfigFile) {
|
|
if (aConfigFile != null) {
|
|
bridgeService.uploadConfigFile(aFilename, aConfigFile);
|
|
}
|
|
};
|
|
|
|
$scope.toggle = function () {
|
|
$scope.visible = !$scope.visible;
|
|
if ($scope.visible)
|
|
$scope.imgUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.changeSeuritySettings = function () {
|
|
bridgeService.getSecurityInfo();
|
|
ngDialog.open({
|
|
template: 'views/securitydialog.html',
|
|
controller: 'SecurityDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
});
|
|
|
|
app.directive('autofocus', ['$timeout', function ($timeout) {
|
|
return {
|
|
restrict: 'A',
|
|
link: function ($scope, $element) {
|
|
$timeout(function () {
|
|
$element[0].focus();
|
|
});
|
|
}
|
|
};
|
|
}]);
|
|
|
|
app.directive('nuCheck', [function () {
|
|
return {
|
|
require: 'ngModel',
|
|
link: function (scope, elem, attrs, ctrl) {
|
|
var newUser = '#' + attrs.nuCheck;
|
|
elem.add(newUser).on('keyup', function () {
|
|
scope.$apply(function () {
|
|
if ($(newUser).val().length > 0) {
|
|
scope.addingUser = true;
|
|
scope.username = $(newUser).val();
|
|
if (scope.showPassword === false)
|
|
scope.showPassword = true;
|
|
} else {
|
|
scope.addingUser = false;
|
|
if (scope.loggedInUser !== undefined)
|
|
scope.username = scope.loggedInUser;
|
|
scope.showPassword = scope.isSecure;
|
|
}
|
|
});
|
|
});
|
|
}
|
|
};
|
|
}]);
|
|
|
|
app.directive('pwCheck', [function () {
|
|
return {
|
|
require: 'ngModel',
|
|
link: function (scope, elem, attrs, ctrl) {
|
|
var firstPassword = '#' + attrs.pwCheck;
|
|
elem.add(firstPassword).on('keyup', function () {
|
|
scope.$apply(function () {
|
|
var isMatched = false;
|
|
if (elem.val().length > 0 && $(firstPassword).val().length > 0)
|
|
isMatched = (elem.val() === $(firstPassword).val());
|
|
ctrl.$setValidity('pwmatch', isMatched);
|
|
scope.matched = isMatched;
|
|
});
|
|
});
|
|
}
|
|
};
|
|
}]);
|
|
|
|
app.controller('SecurityDialogCtrl', function ($scope, bridgeService, ngDialog) {
|
|
$scope.loggedInUser = bridgeService.state.loggedInUser;
|
|
if (bridgeService.state.loggedInUser !== undefined)
|
|
$scope.username = bridgeService.state.loggedInUser;
|
|
else
|
|
$scope.username = "";
|
|
$scope.secureHueApi = bridgeService.state.securityInfo.secureHueApi;
|
|
$scope.useLinkButton = bridgeService.state.securityInfo.useLinkButton;
|
|
$scope.execGarden = bridgeService.state.securityInfo.execGarden;
|
|
$scope.isSecure = bridgeService.state.securityInfo.isSecure;
|
|
$scope.useHttps = bridgeService.state.securityInfo.useHttps;
|
|
$scope.keyfilePath = bridgeService.state.securityInfo.keyfilePath;
|
|
$scope.keyfilePassword = bridgeService.state.securityInfo.keyfilePassword;
|
|
|
|
$scope.matched = false;
|
|
$scope.addingUser = false;
|
|
$scope.showPassword = $scope.isSecure;
|
|
$scope.firstTime = true;
|
|
|
|
$scope.setSecurityInfo = function () {
|
|
bridgeService.changeSecuritySettings($scope.useLinkButton, $scope.secureHueApi, $scope.execGarden, $scope.useHttps, $scope.keyfilePath, $scope.keyfilePassword);
|
|
};
|
|
|
|
$scope.changePassword = function (password, password2) {
|
|
bridgeService.changePassword(password, password2);
|
|
};
|
|
|
|
$scope.addUser = function (newUser, password, password2) {
|
|
bridgeService.addUser(newUser, password, password2);
|
|
$scope.addingUser = false;
|
|
if (bridgeService.staet.loggedInUser !== undefined)
|
|
$scope.username = bridgeService.state.loggedInUser;
|
|
else
|
|
$scope.username = "";
|
|
$scope.showPassword = $scope.isSecure;
|
|
};
|
|
|
|
$scope.delUser = function (newUser) {
|
|
bridgeService.delUser(newUser);
|
|
$scope.addingUser = false;
|
|
if (bridgeService.state.loggedInUser !== undefined)
|
|
$scope.username = bridgeService.state.loggedInUser;
|
|
else
|
|
$scope.username = "";
|
|
bridgeService.getHABridgeVersion();
|
|
$scope.showPassword = $scope.isSecure;
|
|
};
|
|
|
|
$scope.dismissDialog = function () {
|
|
ngDialog.close('ngdialog1');
|
|
};
|
|
|
|
$scope.setBlankPassword = function (theElementName) {
|
|
if ($scope.firstTime) {
|
|
var theElement = "#" + theElementName;
|
|
$(theElement).strength();
|
|
$scope.firstTime = false;
|
|
}
|
|
};
|
|
});
|
|
|
|
app.controller('ManageLinksDialogCtrl', function ($scope, bridgeService, ngDialog) {
|
|
bridgeService.getWhitelist();
|
|
$scope.whitelist = bridgeService.state.whitelist;
|
|
|
|
$scope.setWhitelist = function () {
|
|
bridgeService.setWhitelist($scope.whitelist);
|
|
ngDialog.close('ngdialog1');
|
|
};
|
|
|
|
$scope.delEntry = function (anEntry) {
|
|
for (var key in $scope.whitelist) {
|
|
if ($scope.whitelist.hasOwnProperty(key)) {
|
|
var theEntry = $scope.whitelist[key];
|
|
if (theEntry.name === anEntry) {
|
|
delete $scope.whitelist[key];
|
|
}
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.refresh = function () {
|
|
bridgeService.getWhitelist();
|
|
$scope.whitelist = bridgeService.state.whitelist;
|
|
};
|
|
|
|
$scope.delAll = function () {
|
|
$scope.whitelist = null;
|
|
};
|
|
|
|
$scope.dismissDialog = function () {
|
|
ngDialog.close('ngdialog1');
|
|
};
|
|
});
|
|
|
|
app.controller('LogsController', function ($scope, $location, bridgeService) {
|
|
bridgeService.viewLogs();
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.levels = ["INFO_INT", "WARN_INT", "DEBUG_INT", "TRACE_INT"];
|
|
$scope.updateComponents = [];
|
|
$scope.visible = false;
|
|
$scope.imgUrl = "glyphicon glyphicon-plus";
|
|
$scope.updateLogs = function () {
|
|
bridgeService.viewLogs();
|
|
};
|
|
$scope.toggle = function () {
|
|
$scope.visible = !$scope.visible;
|
|
if ($scope.visible) {
|
|
$scope.imgUrl = "glyphicon glyphicon-minus";
|
|
bridgeService.viewLoggerInfo();
|
|
} else
|
|
$scope.imgUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
$scope.addToUpdate = function (logInfo) {
|
|
var idx = $scope.updateComponents.indexOf(logInfo);
|
|
|
|
// is currently selected
|
|
if (idx > -1) {
|
|
$scope.updateComponents.splice(idx, 1);
|
|
}
|
|
|
|
// is newly selected
|
|
else {
|
|
$scope.updateComponents.push(logInfo);
|
|
}
|
|
};
|
|
|
|
$scope.updateLoggers = function () {
|
|
bridgeService.updateLogLevels($scope.updateComponents);
|
|
};
|
|
|
|
$scope.reloadLoggers = function () {
|
|
bridgeService.viewLoggerInfo();
|
|
};
|
|
});
|
|
|
|
app.directive('postrenderAction', postrenderAction);
|
|
/* @ngInject */
|
|
function postrenderAction($timeout) {
|
|
// ### Directive Interface
|
|
// Defines base properties for the directive.
|
|
var directive = {
|
|
restrict: 'A',
|
|
priority: 101,
|
|
link: link
|
|
};
|
|
return directive;
|
|
|
|
// ### Link Function
|
|
// Provides functionality for the directive during the DOM building/data binding stage.
|
|
function link(scope, element, attrs) {
|
|
$timeout(function () {
|
|
scope.$evalAsync(attrs.postrenderAction);
|
|
}, 0);
|
|
}
|
|
}
|
|
|
|
app.controller('ViewingController', function ($scope, $location, bridgeService, ngDialog, Upload) {
|
|
|
|
bridgeService.viewDevices();
|
|
bridgeService.viewBackups();
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.optionalbackupname = "";
|
|
$scope.bridge.backupContent = undefined;
|
|
$scope.bridge.isResumeSupported = Upload.isResumeSupported();
|
|
|
|
$scope.visible = false;
|
|
$scope.imgUrl = "glyphicon glyphicon-plus";
|
|
$scope.visibleBk = false;
|
|
$scope.imgBkUrl = "glyphicon glyphicon-plus";
|
|
$scope.comparatorUniqueId = bridgeService.compareUniqueId;
|
|
$scope.testUrl = function (device, type) {
|
|
var dialogNeeded = false;
|
|
if ((type === "on" && device.onUrl !== undefined && bridgeService.aContainsB(device.onUrl, "${intensity")) ||
|
|
(type === "off" && device.offUrl !== undefined && bridgeService.aContainsB(device.offUrl, "${intensity")) ||
|
|
(type === "dim" && device.dimUrl !== undefined)) {
|
|
$scope.bridge.device = device;
|
|
$scope.bridge.type = type;
|
|
ngDialog.open({
|
|
template: 'valueDialog',
|
|
controller: 'ValueDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
} else if ((type === "on" && device.onUrl !== undefined && bridgeService.aContainsB(device.onUrl, "${color")) ||
|
|
(type === "off" && device.offUrl !== undefined && bridgeService.aContainsB(device.offUrl, "${color")) ||
|
|
(type === "color" && device.colorUrl !== undefined)) {
|
|
$scope.bridge.device = device;
|
|
$scope.bridge.type = type;
|
|
ngDialog.open({
|
|
template: 'colorDialog',
|
|
controller: 'ColorDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
} else
|
|
bridgeService.testUrl(device, type, null, type);
|
|
};
|
|
$scope.deleteDevice = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'deleteDialog',
|
|
controller: 'DeleteDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
$scope.editDevice = function (device) {
|
|
bridgeService.editDevice(device);
|
|
$location.path('/editdevice');
|
|
};
|
|
$scope.setStartupAction = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'startupActionDialog',
|
|
controller: 'StartupActionDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
|
|
$scope.renumberDevices = function () {
|
|
bridgeService.renumberDevices();
|
|
};
|
|
$scope.pushLinkButton = function () {
|
|
bridgeService.pushLinkButton();
|
|
};
|
|
|
|
$scope.toggleLock = function (device) {
|
|
if (device.lockDeviceId) {
|
|
device.lockDeviceId = false;
|
|
} else {
|
|
device.lockDeviceId = true;
|
|
}
|
|
console.log("toggle lock device called: " + device.name);
|
|
bridgeService.addDevice(device).then(
|
|
function () {
|
|
bridgeService.state.queueDevId = device.id;
|
|
console.log("Device updated for Q Id <<" + bridgeService.state.queueDevId + ">>");
|
|
$location.path('/');
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Error updating lock id for device....", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
$scope.manageLinksButton = function () {
|
|
ngDialog.open({
|
|
template: 'views/managelinksdialog.html',
|
|
controller: 'ManageLinksDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
$scope.backupDeviceDb = function (optionalbackupname) {
|
|
bridgeService.backupDeviceDb(optionalbackupname);
|
|
};
|
|
$scope.restoreBackup = function (backupname) {
|
|
bridgeService.restoreBackup(backupname);
|
|
};
|
|
$scope.deleteBackup = function (backupname) {
|
|
bridgeService.deleteBackup(backupname);
|
|
};
|
|
$scope.downloadBackup = function (backupname) {
|
|
bridgeService.downloadDeviceBackup(backupname);
|
|
};
|
|
|
|
$scope.uploadDeviceFile = function (aFilename, aDeviceFile) {
|
|
$scope.formUpload = true;
|
|
if (aDeviceFile != null) {
|
|
bridgeService.uploadDeviceFile(aFilename, aDeviceFile);
|
|
}
|
|
};
|
|
|
|
$scope.toggle = function () {
|
|
$scope.visible = !$scope.visible;
|
|
if ($scope.visible)
|
|
$scope.imgUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
$scope.toggleBk = function () {
|
|
$scope.visibleBk = !$scope.visibleBk;
|
|
if ($scope.visibleBk)
|
|
$scope.imgBkUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgBkUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.goToRow = function () {
|
|
if (bridgeService.state.queueDevId !== null && bridgeService.state.queueDevId !== "") {
|
|
bridgeService.state.viewDevId = bridgeService.state.queueDevId;
|
|
$scope.$broadcast("rowSelected", bridgeService.state.viewDevId);
|
|
console.log("Go to Row selected Id <<" + bridgeService.state.viewDevId + ">>");
|
|
bridgeService.state.queueDevId = null;
|
|
}
|
|
};
|
|
});
|
|
|
|
app.controller('ValueDialogCtrl', function ($scope, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.valueType = "percentage";
|
|
$scope.slider = {
|
|
value: Math.round($scope.bridge.device.deviceState.bri / 2.55),
|
|
options: {
|
|
floor: 1,
|
|
ceil: 100,
|
|
showSelectionBar: true
|
|
}
|
|
};
|
|
$scope.changeScale = function () {
|
|
if ($scope.valueType === "raw") {
|
|
$scope.slider.options.ceil = 254;
|
|
$scope.slider.value = $scope.bridge.device.deviceState.bri;
|
|
} else {
|
|
$scope.slider.options.ceil = 100;
|
|
$scope.slider.value = Math.round($scope.bridge.device.deviceState.bri / 2.55);
|
|
}
|
|
};
|
|
$scope.setValue = function () {
|
|
ngDialog.close('ngdialog1');
|
|
var theValue = 1;
|
|
if ($scope.valueType === "percentage")
|
|
theValue = Math.round(($scope.slider.value * 0.01) * 255);
|
|
else
|
|
theValue = $scope.slider.value;
|
|
bridgeService.testUrl($scope.bridge.device, $scope.bridge.type, theValue, "dim");
|
|
$scope.bridge.device = null;
|
|
$scope.bridge.type = "";
|
|
};
|
|
});
|
|
|
|
app.controller('ColorDialogCtrl', function ($scope, bridgeService, ngDialog) {
|
|
$scope.rgbPicker = {
|
|
color: 'rgb(255,255,255)'
|
|
};
|
|
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.setValue = function () {
|
|
ngDialog.close('ngdialog1');
|
|
var next = $scope.rgbPicker.color.substr($scope.rgbPicker.color.indexOf('(') + 1);
|
|
var red = next.substr(0, next.indexOf(','));
|
|
next = next.substr(next.indexOf(',') + 1);
|
|
var green = next.substr(0, next.indexOf(','));
|
|
next = next.substr(next.indexOf(',') + 1);
|
|
var blue = next.substr(0, next.indexOf(')'));
|
|
var theValue = bridgeService.toXY(red, green, blue);
|
|
bridgeService.testUrl($scope.bridge.device, $scope.bridge.type, theValue, "color");
|
|
$scope.bridge.device = null;
|
|
$scope.bridge.type = "";
|
|
};
|
|
});
|
|
|
|
app.controller('DeleteDialogCtrl', function ($scope, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = $scope.bridge.device;
|
|
$scope.deleteDevice = function (device) {
|
|
ngDialog.close('ngdialog1');
|
|
bridgeService.deleteDevice(device.id);
|
|
bridgeService.viewDevices();
|
|
$scope.bridge.device = null;
|
|
$scope.bridge.type = "";
|
|
};
|
|
});
|
|
|
|
app.controller('StartupActionDialogCtrl', function ($scope, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = $scope.bridge.device;
|
|
$scope.setDim = false;
|
|
var components = [];
|
|
if ($scope.device.startupActions != undefined) {
|
|
components = $scope.device.startupActions.split(":");
|
|
if (components[1] != undefined && components[1].length > 0)
|
|
$scope.setDim = true;
|
|
} else {
|
|
components = "::".split(":");
|
|
}
|
|
|
|
$scope.slider = {
|
|
value: parseInt(components[1]),
|
|
options: {
|
|
floor: 1,
|
|
ceil: 254,
|
|
showSelectionBar: true
|
|
}
|
|
};
|
|
$scope.rgbPicker = {
|
|
color: components[2]
|
|
};
|
|
|
|
$scope.theState = components[0];
|
|
|
|
$scope.startupActionSave = function (device) {
|
|
console.log("Startup action set for device called: " + device.name);
|
|
ngDialog.close('ngdialog1');
|
|
var theValue = 1;
|
|
if ($scope.setDim) {
|
|
theValue = $scope.theState + ":" + $scope.slider.value + ":" + $scope.rgbPicker.color;
|
|
} else {
|
|
theValue = $scope.theState + "::" + $scope.rgbPicker.color;
|
|
}
|
|
if (theValue == "::")
|
|
theValue = "";
|
|
device.startupActions = theValue;
|
|
bridgeService.addDevice(device).then(
|
|
function () {
|
|
bridgeService.state.queueDevId = device.id;
|
|
console.log("Device updated for Q Id <<" + bridgeService.state.queueDevId + ">>");
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Error updating lock id for device....", error);
|
|
}
|
|
);
|
|
};
|
|
});
|
|
|
|
app.controller('VeraController', function ($scope, $location, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = bridgeService.state.device;
|
|
$scope.device_dim_control = "";
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
$scope.vera = {
|
|
base: "http://",
|
|
port: "3480",
|
|
id: ""
|
|
};
|
|
bridgeService.viewVeraDevices();
|
|
bridgeService.viewVeraScenes();
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
$scope.buttonsVisible = false;
|
|
$scope.comparatorUniqueId = bridgeService.compareUniqueId;
|
|
|
|
$scope.clearDevice = function () {
|
|
bridgeService.clearDevice();
|
|
$scope.device = bridgeService.state.device;
|
|
};
|
|
|
|
$scope.buildDeviceUrls = function (veradevice, dim_control, buildonly) {
|
|
if (dim_control.indexOf("byte") >= 0 || dim_control.indexOf("percent") >= 0 || dim_control.indexOf("math") >= 0) {
|
|
dimpayload = "http://" + veradevice.veraaddress + ":" + $scope.vera.port +
|
|
"/data_request?id=action&output_format=json&DeviceNum=" +
|
|
veradevice.id +
|
|
"&serviceId=urn:upnp-org:serviceId:Dimming1&action=SetLoadLevelTarget&newLoadlevelTarget=" +
|
|
dim_control;
|
|
} else
|
|
dimpayload = "http://" + veradevice.veraaddress + ":" + $scope.vera.port +
|
|
"/data_request?id=action&output_format=json&serviceId=urn:upnp-org:serviceId:SwitchPower1&action=SetTarget&newTargetValue=1&DeviceNum=" +
|
|
veradevice.id;
|
|
onpayload = "http://" + veradevice.veraaddress + ":" + $scope.vera.port +
|
|
"/data_request?id=action&output_format=json&serviceId=urn:upnp-org:serviceId:SwitchPower1&action=SetTarget&newTargetValue=1&DeviceNum=" +
|
|
veradevice.id;
|
|
offpayload = "http://" + veradevice.veraaddress + ":" + $scope.vera.port +
|
|
"/data_request?id=action&output_format=json&serviceId=urn:upnp-org:serviceId:SwitchPower1&action=SetTarget&newTargetValue=0&DeviceNum=" +
|
|
veradevice.id;
|
|
|
|
bridgeService.buildUrls(onpayload, dimpayload, offpayload, null, false, veradevice.id, veradevice.name, veradevice.veraname, "switch", "veraDevice", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.buildSceneUrls = function (verascene) {
|
|
onpayload = "http://" + verascene.veraaddress + ":" + $scope.vera.port +
|
|
"/data_request?id=action&output_format=json&serviceId=urn:micasaverde-com:serviceId:HomeAutomationGateway1&action=RunScene&SceneNum=" +
|
|
verascene.id;
|
|
offpayload = "http://" + verascene.veraaddress + ":" + $scope.vera.port +
|
|
"/data_request?id=action&output_format=json&serviceId=urn:micasaverde-com:serviceId:HomeAutomationGateway1&action=RunScene&SceneNum=" +
|
|
verascene.id;
|
|
|
|
bridgeService.buildUrls(onpayload, null, offpayload, null, false, verascene.id, verascene.name, verascene.veraname, "scene", "veraScene", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
};
|
|
|
|
$scope.bulkAddDevices = function (dim_control) {
|
|
var devicesList = [];
|
|
$scope.clearDevice();
|
|
for (var i = 0; i < $scope.bulk.devices.length; i++) {
|
|
for (var x = 0; x < bridgeService.state.veradevices.length; x++) {
|
|
if (bridgeService.state.veradevices[x].id === $scope.bulk.devices[i]) {
|
|
$scope.buildDeviceUrls(bridgeService.state.veradevices[x], dim_control, true);
|
|
devicesList[i] = {
|
|
name: $scope.device.name,
|
|
mapId: $scope.device.mapId,
|
|
mapType: $scope.device.mapType,
|
|
deviceType: $scope.device.deviceType,
|
|
targetDevice: $scope.device.targetDevice,
|
|
onUrl: $scope.device.onUrl,
|
|
dimUrl: $scope.device.dimUrl,
|
|
offUrl: $scope.device.offUrl,
|
|
colorUrl: $scope.device.colorUrl,
|
|
headers: $scope.device.headers,
|
|
httpVerb: $scope.device.httpVerb,
|
|
contentType: $scope.device.contentType,
|
|
contentBody: $scope.device.contentBody,
|
|
contentBodyDim: $scope.device.contentBodyDim,
|
|
contentBodyOff: $scope.device.contentBodyOff
|
|
};
|
|
$scope.clearDevice();
|
|
}
|
|
}
|
|
}
|
|
bridgeService.bulkAddDevice(devicesList).then(
|
|
function () {
|
|
$scope.clearDevice();
|
|
bridgeService.viewDevices();
|
|
bridgeService.viewVeraDevices();
|
|
bridgeService.viewVeraScenes();
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Error adding Vera devices in bulk.", error);
|
|
}
|
|
);
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
};
|
|
|
|
$scope.toggleSelection = function toggleSelection(deviceId) {
|
|
var idx = $scope.bulk.devices.indexOf(deviceId);
|
|
|
|
// is currently selected
|
|
if (idx > -1) {
|
|
$scope.bulk.devices.splice(idx, 1);
|
|
if ($scope.bulk.devices.length === 0 && $scope.selectAll)
|
|
$scope.selectAll = false;
|
|
}
|
|
|
|
// is newly selected
|
|
else {
|
|
$scope.bulk.devices.push(deviceId);
|
|
$scope.selectAll = true;
|
|
}
|
|
};
|
|
|
|
$scope.toggleSelectAll = function toggleSelectAll() {
|
|
if ($scope.selectAll) {
|
|
$scope.selectAll = false;
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
} else {
|
|
$scope.selectAll = true;
|
|
for (var x = 0; x < bridgeService.state.veradevices.length; x++) {
|
|
if ($scope.bulk.devices.indexOf(bridgeService.state.veradevices[x]) < 0)
|
|
$scope.bulk.devices.push(bridgeService.state.veradevices[x].id);
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.toggleButtons = function () {
|
|
$scope.buttonsVisible = !$scope.buttonsVisible;
|
|
if ($scope.buttonsVisible)
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.deleteDevice = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'deleteDialog',
|
|
controller: 'DeleteDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
|
|
$scope.editDevice = function (device) {
|
|
bridgeService.editDevice(device);
|
|
$location.path('/editdevice');
|
|
};
|
|
});
|
|
|
|
app.controller('FibaroController', function ($scope, $location, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = bridgeService.state.device;
|
|
$scope.device_dim_control = "";
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
$scope.fibaro = {
|
|
base: "http://",
|
|
port: "80",
|
|
id: ""
|
|
};
|
|
bridgeService.viewFibaroDevices();
|
|
bridgeService.viewFibaroScenes();
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
$scope.buttonsVisible = false;
|
|
$scope.comparatorUniqueId = bridgeService.compareUniqueId;
|
|
|
|
$scope.clearDevice = function () {
|
|
bridgeService.clearDevice();
|
|
$scope.device = bridgeService.state.device;
|
|
};
|
|
|
|
$scope.buildDeviceUrls = function (fibarodevice, dim_control, buildonly) {
|
|
var dimpayload = null;
|
|
if (dim_control.indexOf("byte") >= 0 || dim_control.indexOf("percent") >= 0 || dim_control.indexOf("math") >= 0)
|
|
dimpayload = "http://" + fibarodevice.fibaroaddress + ":" + fibarodevice.fibaroport + "/api/callAction?deviceID=" + fibarodevice.id + "&name=setValue&arg1=" + dim_control;
|
|
|
|
onpayload = "http://" + fibarodevice.fibaroaddress + ":" + fibarodevice.fibaroport + "/api/callAction?deviceID=" + fibarodevice.id + "&name=turnOn";
|
|
offpayload = "http://" + fibarodevice.fibaroaddress + ":" + fibarodevice.fibaroport + "/api/callAction?deviceID=" + fibarodevice.id + "&name=turnOff";
|
|
|
|
bridgeService.buildUrls(onpayload, dimpayload, offpayload, null, false, fibarodevice.id, fibarodevice.name, fibarodevice.fibaroname, "switch", "fibaroDevice", null, null);
|
|
bridgeService.state.device.headers = "[{\"name\":\"Authorization\",\"value\":\"" + fibarodevice.fibaroAuth + "\"}]";
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.buildSceneUrls = function (fibaroscene) {
|
|
var onpayload = null;
|
|
var offpayload = null;
|
|
onpayload = "http://" + fibaroscene.fibaroaddress + ":" + fibaroscene.fibaroport + "/api/sceneControl?id=" + fibaroscene.id + "&action=start";
|
|
offpayload = "http://" + fibaroscene.fibaroaddress + ":" + fibaroscene.fibaroport + "/api/sceneControl?id=" + fibaroscene.id + "&action=stop";
|
|
|
|
bridgeService.buildUrls(onpayload, null, offpayload, null, false, fibaroscene.id, fibaroscene.name, fibaroscene.fibaroname, "scene", "fibaroScene", null, null);
|
|
bridgeService.state.device.headers = "[{\"name\":\"Authorization\",\"value\":\"" + fibaroscene.fibaroAuth + "\"}]";
|
|
$scope.device = bridgeService.state.device;
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
};
|
|
|
|
$scope.bulkAddDevices = function (dim_control) {
|
|
var devicesList = [];
|
|
$scope.clearDevice();
|
|
for (var i = 0; i < $scope.bulk.devices.length; i++) {
|
|
for (var x = 0; x < bridgeService.state.fibarodevices.length; x++) {
|
|
if (bridgeService.state.fibarodevices[x].id === $scope.bulk.devices[i]) {
|
|
$scope.buildDeviceUrls(bridgeService.state.fibarodevices[x], dim_control, true);
|
|
devicesList[i] = {
|
|
name: $scope.device.name,
|
|
mapId: $scope.device.mapId,
|
|
mapType: $scope.device.mapType,
|
|
deviceType: $scope.device.deviceType,
|
|
targetDevice: $scope.device.targetDevice,
|
|
onUrl: $scope.device.onUrl,
|
|
dimUrl: $scope.device.dimUrl,
|
|
offUrl: $scope.device.offUrl,
|
|
headers: $scope.device.headers,
|
|
httpVerb: $scope.device.httpVerb,
|
|
contentType: $scope.device.contentType,
|
|
contentBody: $scope.device.contentBody,
|
|
contentBodyDim: $scope.device.contentBodyDim,
|
|
contentBodyOff: $scope.device.contentBodyOff
|
|
};
|
|
$scope.clearDevice();
|
|
}
|
|
}
|
|
}
|
|
bridgeService.bulkAddDevice(devicesList).then(
|
|
function () {
|
|
$scope.clearDevice();
|
|
bridgeService.viewDevices();
|
|
bridgeService.viewfibaroDevices();
|
|
bridgeService.viewfibaroScenes();
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Error adding fibaro devices in bulk.", error);
|
|
}
|
|
);
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
};
|
|
|
|
$scope.toggleSelection = function toggleSelection(deviceId) {
|
|
var idx = $scope.bulk.devices.indexOf(deviceId);
|
|
|
|
// is currently selected
|
|
if (idx > -1) {
|
|
$scope.bulk.devices.splice(idx, 1);
|
|
if ($scope.bulk.devices.length === 0 && $scope.selectAll)
|
|
$scope.selectAll = false;
|
|
}
|
|
|
|
// is newly selected
|
|
else {
|
|
$scope.bulk.devices.push(deviceId);
|
|
$scope.selectAll = true;
|
|
}
|
|
};
|
|
|
|
$scope.toggleSelectAll = function toggleSelectAll() {
|
|
if ($scope.selectAll) {
|
|
$scope.selectAll = false;
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
} else {
|
|
$scope.selectAll = true;
|
|
for (var x = 0; x < bridgeService.state.fibarodevices.length; x++) {
|
|
if ($scope.bulk.devices.indexOf(bridgeService.state.fibarodevices[x]) < 0)
|
|
$scope.bulk.devices.push(bridgeService.state.fibarodevices[x].id);
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.toggleButtons = function () {
|
|
$scope.buttonsVisible = !$scope.buttonsVisible;
|
|
if ($scope.buttonsVisible)
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.deleteDevice = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'deleteDialog',
|
|
controller: 'DeleteDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
|
|
$scope.editDevice = function (device) {
|
|
bridgeService.editDevice(device);
|
|
$location.path('/editdevice');
|
|
};
|
|
});
|
|
|
|
|
|
app.controller('HarmonyController', function ($scope, $location, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = bridgeService.state.device;
|
|
bridgeService.viewHarmonyActivities();
|
|
bridgeService.viewHarmonyDevices();
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
$scope.buttonsVisible = false;
|
|
$scope.comparatorNumber = bridgeService.compareHarmonyNumber;
|
|
$scope.comparatorLabel = bridgeService.compareHarmonyLabel;
|
|
$scope.comparatorHub = bridgeService.compareHarmonyHub;
|
|
|
|
$scope.clearDevice = function () {
|
|
bridgeService.clearDevice();
|
|
$scope.device = bridgeService.state.device;
|
|
};
|
|
|
|
$scope.buildActivityUrls = function (harmonyactivity) {
|
|
onpayload = "{\"name\":\"" + harmonyactivity.activity.id + "\",\"hub\":\"" + harmonyactivity.hub + "\"}";
|
|
offpayload = "{\"name\":\"-1\",\"hub\":\"" + harmonyactivity.hub + "\"}";
|
|
|
|
bridgeService.buildUrls(onpayload, null, offpayload, null, true, harmonyactivity.activity.id, harmonyactivity.activity.label, harmonyactivity.hub, "activity", "harmonyActivity", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
};
|
|
|
|
$scope.buildButtonUrls = function (harmonydevice, onbutton, offbutton, onpresstime, offpresstime) {
|
|
var actionOn = angular.fromJson(onbutton);
|
|
var actionOff = angular.fromJson(offbutton);
|
|
var postCmd = "\"}";
|
|
if (onpresstime !== undefined && onpresstime !== "0")
|
|
postCmd = "\",\"pressTime\":" + onpresstime + "}";
|
|
onpayload = "{\"device\":\"" + harmonydevice.device.id + "\",\"button\":\"" + actionOn.command + "\",\"hub\":\"" + harmonydevice.hub + postCmd;
|
|
if (offpresstime !== undefined && offpresstime !== "0")
|
|
postCmd = "\",\"pressTime\":" + offpresstime + "}";
|
|
else
|
|
postCmd = "\"}";
|
|
offpayload = "{\"device\":\"" + harmonydevice.device.id + "\",\"button\":\"" + actionOff.command + "\",\"hub\":\"" + harmonydevice.hub + postCmd;
|
|
|
|
bridgeService.buildUrls(onpayload, null, offpayload, null, true, actionOn.command, harmonydevice.device.label, harmonydevice.hub, "button", "harmonyButton", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
};
|
|
|
|
$scope.toggleButtons = function () {
|
|
$scope.buttonsVisible = !$scope.buttonsVisible;
|
|
if ($scope.buttonsVisible)
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.deleteDevice = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'deleteDialog',
|
|
controller: 'DeleteDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
|
|
$scope.editDevice = function (device) {
|
|
bridgeService.editDevice(device);
|
|
$location.path('/editdevice');
|
|
};
|
|
});
|
|
|
|
app.controller('NestController', function ($scope, $location, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = bridgeService.state.device;
|
|
bridgeService.viewNestItems();
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
$scope.buttonsVisible = false;
|
|
|
|
$scope.clearDevice = function () {
|
|
bridgeService.clearDevice();
|
|
$scope.device = bridgeService.state.device;
|
|
};
|
|
|
|
$scope.buildNestHomeUrls = function (nestitem) {
|
|
onpayload = "{\"name\":\"" + nestitem.id + "\",\"away\":false,\"control\":\"status\"}";
|
|
offpayload = "{\"name\":\"" + nestitem.id + "\",\"away\":true,\"control\":\"status\"}";
|
|
bridgeService.buildUrls(onpayload, null, offpayload, null, true, nestitem.id, nestitem.name, nestitem.name, "home", "nestHomeAway", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
};
|
|
|
|
$scope.buildNestTempUrls = function (nestitem) {
|
|
onpayload = "{\"name\":\"" + nestitem.id + "\",\"control\":\"temp\",\"temp\":\"${intensity.percent}\"}";
|
|
dimpayload = "{\"name\":\"" + nestitem.id + "\",\"control\":\"temp\",\"temp\":\"${intensity.percent}\"}";
|
|
offpayload = "{\"name\":\"" + nestitem.id + "\",\"control\":\"off\"}";
|
|
bridgeService.buildUrls(onpayload, dimpayload, offpayload, null, true, nestitem.id + "-SetTemp", nestitem.name.substr(0, nestitem.name.indexOf("(")) + " Temperature", nestitem.location, "thermo", "nestThermoSet", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
};
|
|
|
|
$scope.buildNestHeatUrls = function (nestitem) {
|
|
onpayload = "{\"name\":\"" + nestitem.id + "\",\"control\":\"heat\"}";
|
|
dimpayload = "{\"name\":\"" + nestitem.id + "\",\"control\":\"temp\",\"temp\":\"${intensity.percent}\"}";
|
|
offpayload = "{\"name\":\"" + nestitem.id + "\",\"control\":\"off\"}";
|
|
bridgeService.buildUrls(onpayload, dimpayload, offpayload, null, true, nestitem.id + "-SetHeat", nestitem.name.substr(0, nestitem.name.indexOf("(")) + " Heat", nestitem.location, "thermo", "nestThermoSet", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
};
|
|
|
|
$scope.buildNestCoolUrls = function (nestitem) {
|
|
onpayload = "{\"name\":\"" + nestitem.id + "\",\"control\":\"cool\"}";
|
|
dimpayload = "{\"name\":\"" + nestitem.id + "\",\"control\":\"temp\",\"temp\":\"${intensity.percent}\"}";
|
|
offpayload = "{\"name\":\"" + nestitem.id + "\",\"control\":\"off\"}";
|
|
bridgeService.buildUrls(onpayload, dimpayload, offpayload, null, true, nestitem.id + "-SetCool", nestitem.name.substr(0, nestitem.name.indexOf("(")) + " Cool", nestitem.location, "thermo", "nestThermoSet", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
};
|
|
|
|
$scope.buildNestRangeUrls = function (nestitem) {
|
|
onpayload = "{\"name\":\"" + nestitem.id + "\",\"control\":\"range\"}";
|
|
offpayload = "{\"name\":\"" + nestitem.id + "\",\"control\":\"off\"}";
|
|
bridgeService.buildUrls(onpayload, null, offpayload, null, true, nestitem.id + "-SetRange", nestitem.name.substr(0, nestitem.name.indexOf("(")) + " Range", nestitem.location, "thermo", "nestThermoSet", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
};
|
|
|
|
$scope.buildNestOffUrls = function (nestitem) {
|
|
onpayload = "{\"name\":\"" + nestitem.id + "\",\"control\":\"range\"}";
|
|
offpayload = "{\"name\":\"" + nestitem.id + "\",\"control\":\"off\"}";
|
|
bridgeService.buildUrls(onpayload, null, offpayload, null, true, nestitem.id + "-TurnOff", nestitem.name.substr(0, nestitem.name.indexOf("(")) + " Thermostat", nestitem.location, "thermo", "nestThermoSet", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
};
|
|
|
|
$scope.buildNestFanUrls = function (nestitem) {
|
|
onpayload = "{\"name\":\"" + nestitem.id + "\",\"control\":\"fan-on\"}";
|
|
offpayload = "{\"name\":\"" + nestitem.id + "\",\"control\":\"fan-auto\"}";
|
|
bridgeService.buildUrls(onpayload, null, offpayload, null, true, nestitem.id + "-SetFan", nestitem.name.substr(0, nestitem.name.indexOf("(")) + " Fan", nestitem.location, "thermo", "nestThermoSet", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
};
|
|
|
|
$scope.toggleButtons = function () {
|
|
$scope.buttonsVisible = !$scope.buttonsVisible;
|
|
if ($scope.buttonsVisible)
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.deleteDevice = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'deleteDialog',
|
|
controller: 'DeleteDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
|
|
$scope.editDevice = function (device) {
|
|
bridgeService.editDevice(device);
|
|
$location.path('/editdevice');
|
|
};
|
|
});
|
|
|
|
app.controller('HueController', function ($scope, $location, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = bridgeService.state.device;
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
bridgeService.viewHueDevices();
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
$scope.buttonsVisible = false;
|
|
|
|
$scope.clearDevice = function () {
|
|
bridgeService.clearDevice();
|
|
$scope.device = bridgeService.state.device;
|
|
};
|
|
|
|
$scope.buildDeviceUrls = function (huedevice, buildonly) {
|
|
onpayload = "{\"ipAddress\":\"" + huedevice.hueaddress + "\",\"deviceId\":\"" + huedevice.huedeviceid + "\",\"hueName\":\"" + huedevice.huename + "\"}";
|
|
offpayload = "{\"ipAddress\":\"" + huedevice.hueaddress + "\",\"deviceId\":\"" + huedevice.huedeviceid + "\",\"hueName\":\"" + huedevice.huename + "\"}";
|
|
bridgeService.buildUrls(onpayload, null, offpayload, null, true, huedevice.device.uniqueid, huedevice.device.name, huedevice.huename, "passthru", "hueDevice", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.bulkAddDevices = function () {
|
|
var devicesList = [];
|
|
$scope.clearDevice();
|
|
for (var i = 0; i < $scope.bulk.devices.length; i++) {
|
|
for (var x = 0; x < bridgeService.state.huedevices.length; x++) {
|
|
if (bridgeService.state.huedevices[x].device.uniqueid === $scope.bulk.devices[i]) {
|
|
$scope.buildDeviceUrls(bridgeService.state.huedevices[x], true);
|
|
devicesList[i] = {
|
|
name: $scope.device.name,
|
|
mapId: $scope.device.mapId,
|
|
mapType: $scope.device.mapType,
|
|
deviceType: $scope.device.deviceType,
|
|
targetDevice: $scope.device.targetDevice,
|
|
onUrl: $scope.device.onUrl,
|
|
dimUrl: $scope.device.dimUrl,
|
|
offUrl: $scope.device.offUrl,
|
|
colorUrl: $scope.device.colorUrl,
|
|
headers: $scope.device.headers,
|
|
httpVerb: $scope.device.httpVerb,
|
|
contentType: $scope.device.contentType,
|
|
contentBody: $scope.device.contentBody,
|
|
contentBodyDim: $scope.device.contentBodyDim,
|
|
contentBodyOff: $scope.device.contentBodyOff
|
|
};
|
|
$scope.clearDevice();
|
|
}
|
|
}
|
|
}
|
|
bridgeService.bulkAddDevice(devicesList).then(
|
|
function () {
|
|
$scope.clearDevice();
|
|
bridgeService.viewDevices();
|
|
bridgeService.viewHueDevices();
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Error adding Hue devices in bulk.", error);
|
|
}
|
|
);
|
|
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
};
|
|
|
|
$scope.toggleSelection = function toggleSelection(deviceId) {
|
|
var idx = $scope.bulk.devices.indexOf(deviceId);
|
|
|
|
// is currently selected
|
|
if (idx > -1) {
|
|
$scope.bulk.devices.splice(idx, 1);
|
|
if ($scope.bulk.devices.length === 0 && $scope.selectAll)
|
|
$scope.selectAll = false;
|
|
}
|
|
|
|
// is newly selected
|
|
else {
|
|
$scope.bulk.devices.push(deviceId);
|
|
$scope.selectAll = true;
|
|
}
|
|
};
|
|
|
|
$scope.toggleSelectAll = function toggleSelectAll() {
|
|
if ($scope.selectAll) {
|
|
$scope.selectAll = false;
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
} else {
|
|
$scope.selectAll = true;
|
|
for (var x = 0; x < bridgeService.state.huedevices.length; x++) {
|
|
if ($scope.bulk.devices.indexOf(bridgeService.state.huedevices[x]) < 0 && !bridgeService.findDeviceByMapId(bridgeService.state.huedevices[x].device.uniqueid, bridgeService.state.huedevices[x].huename, "hueDevice"))
|
|
$scope.bulk.devices.push(bridgeService.state.huedevices[x].device.uniqueid);
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.toggleButtons = function () {
|
|
$scope.buttonsVisible = !$scope.buttonsVisible;
|
|
if ($scope.buttonsVisible)
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.deleteDevice = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'deleteDialog',
|
|
controller: 'DeleteDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
|
|
$scope.editDevice = function (device) {
|
|
bridgeService.editDevice(device);
|
|
$location.path('/editdevice');
|
|
};
|
|
});
|
|
|
|
app.controller('HalController', function ($scope, $location, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = bridgeService.state.device;
|
|
$scope.device_dim_control = "";
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
bridgeService.viewHalDevices();
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
$scope.buttonsVisible = false;
|
|
|
|
$scope.clearDevice = function () {
|
|
bridgeService.clearDevice();
|
|
$scope.device = bridgeService.state.device;
|
|
};
|
|
|
|
$scope.buildDeviceUrls = function (haldevice, dim_control, buildonly) {
|
|
var preOnCmd = "";
|
|
var preDimCmd = "";
|
|
var preOffCmd = "";
|
|
var nameCmd = "";
|
|
var aDeviceType;
|
|
if (haldevice.haldevicetype === "Group") {
|
|
aDeviceType = "group";
|
|
preOnCmd = "/GroupService!GroupCmd=On";
|
|
preOffCmd = "/GroupService!GroupCmd=Off";
|
|
nameCmd = "!GroupName=";
|
|
} else if (haldevice.haldevicetype === "Macro") {
|
|
aDeviceType = "macro";
|
|
preOnCmd = "/MacroService!MacroCmd=Set!MacroName=";
|
|
preOffCmd = preOnCmd;
|
|
} else if (haldevice.haldevicetype === "Scene") {
|
|
aDeviceType = "scene";
|
|
preOnCmd = "/SceneService!SceneCmd=Set!SceneName=";
|
|
preOffCmd = preOnCmd;
|
|
} else {
|
|
aDeviceType = "switch";
|
|
preOnCmd = "/DeviceService!DeviceCmd=SetDevice!DeviceValue=On";
|
|
preDimCmd = "/DeviceService!DeviceCmd=SetDevice!DeviceValue=Dim!DevicePercent=";
|
|
preOffCmd = "/DeviceService!DeviceCmd=SetDevice!DeviceValue=Off";
|
|
nameCmd = "!DeviceName=";
|
|
}
|
|
if ((dim_control.indexOf("byte") >= 0 || dim_control.indexOf("percent") >= 0 || dim_control.indexOf("math") >= 0) && aDeviceType === "switch")
|
|
dimpayload = "http://" + haldevice.haladdress.ip +
|
|
preDimCmd +
|
|
dim_control +
|
|
nameCmd +
|
|
haldevice.haldevicename.replaceAll(" ", "%20");
|
|
else
|
|
dimpayload = "http://" + haldevice.haladdress.ip +
|
|
preOnCmd +
|
|
nameCmd +
|
|
haldevice.haldevicename.replaceAll(" ", "%20");
|
|
onpayload = "http://" + haldevice.haladdress.ip +
|
|
preOnCmd +
|
|
nameCmd +
|
|
haldevice.haldevicename.replaceAll(" ", "%20");
|
|
offpayload = "http://" + haldevice.haladdress.ip +
|
|
preOffCmd +
|
|
nameCmd +
|
|
haldevice.haldevicename.replaceAll(" ", "%20");
|
|
bridgeService.buildUrls(onpayload, dimpayload, offpayload, null, false, haldevice.haldevicename + "-" + haldevice.haladdress.name, haldevice.haldevicename, haldevice.haladdress.name, aDeviceType, "halDevice", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.buildButtonUrls = function (haldevice, onbutton, offbutton, buildonly) {
|
|
var actionOn = angular.fromJson(onbutton);
|
|
var actionOff = angular.fromJson(offbutton);
|
|
onpayload = "http://" + haldevice.haladdress.ip + "/IrService!IrCmd=Set!IrDevice=" + haldevice.haldevicename.replaceAll(" ", "%20") + "!IrButton=" + actionOn.DeviceName.replaceAll(" ", "%20");
|
|
offpayload = "http://" + haldevice.haladdress.ip + "/IrService!IrCmd=Set!IrDevice=" + haldevice.haldevicename.replaceAll(" ", "%20") + "!IrButton=" + actionOff.DeviceName.replaceAll(" ", "%20");
|
|
|
|
bridgeService.buildUrls(onpayload, null, offpayload, null, false, haldevice.haldevicename + "-" + haldevice.haladdress.name + "-" + actionOn.DeviceName, haldevice.haldevicename, haldevice.haladdress.name, "button", "halButton", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.buildHALHomeUrls = function (haldevice, buildonly) {
|
|
onpayload = "http://" + haldevice.haladdress.ip + "/ModeService!ModeCmd=Set!ModeName=Home";
|
|
offpayload = "http://" + haldevice.haladdress.ip + "/ModeService!ModeCmd=Set!ModeName=Away";
|
|
bridgeService.buildUrls(onpayload, null, offpayload, null, false, haldevice.haldevicename + "-" + haldevice.haladdress.name + "-HomeAway", haldevice.haldevicename, haldevice.haladdress.name, "home", "halHome", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.buildHALHeatUrls = function (haldevice, buildonly) {
|
|
onpayload = "http://" + haldevice.haladdress.ip +
|
|
"/HVACService!HVACCmd=Set!HVACName=" +
|
|
haldevice.haldevicename.replaceAll(" ", "%20") +
|
|
"!HVACMode=Heat";
|
|
dimpayload = "http://" + haldevice.haladdress.ip +
|
|
"/HVACService!HVACCmd=Set!HVACName=" +
|
|
haldevice.haldevicename.replaceAll(" ", "%20") +
|
|
"!HVACMode=Heat!HeatSpValue=${intensity.percent}";
|
|
offpayload = "http://" + haldevice.haladdress.ip +
|
|
"/HVACService!HVACCmd=Set!HVACName=" +
|
|
haldevice.haldevicename.replaceAll(" ", "%20") +
|
|
"!HVACMode=Off";
|
|
bridgeService.buildUrls(onpayload, dimpayload, offpayload, null, false, haldevice.haldevicename + "-" + haldevice.haladdress.name + "-SetHeat", haldevice.haldevicename + " Heat", haldevice.haladdress.name, "thermo", "halThermoSet", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.buildHALCoolUrls = function (haldevice, buildonly) {
|
|
onpayload = "http://" + haldevice.haladdress.ip +
|
|
"/HVACService!HVACCmd=Set!HVACName=" +
|
|
haldevice.haldevicename.replaceAll(" ", "%20") +
|
|
"!HVACMode=Cool";
|
|
dimpayload = "http://" + haldevice.haladdress.ip +
|
|
"/HVACService!HVACCmd=Set!HVACName=" +
|
|
haldevice.haldevicename.replaceAll(" ", "%20") +
|
|
"!HVACMode=Cool!CoolSpValue=${intensity.percent}";
|
|
offpayload = "http://" + haldevice.haladdress.ip +
|
|
"/HVACService!HVACCmd=Set!HVACName=" +
|
|
haldevice.haldevicename.replaceAll(" ", "%20") +
|
|
"!HVACMode=Off";
|
|
bridgeService.buildUrls(onpayload, dimpayload, offpayload, null, false, haldevice.haldevicename + "-" + haldevice.haladdress.name + "-SetCool", haldevice.haldevicename + " Cool", haldevice.haladdress.name, "thermo", "halThermoSet", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.buildHALAutoUrls = function (haldevice, buildonly) {
|
|
onpayload = "http://" + haldevice.haladdress.ip +
|
|
"/HVACService!HVACCmd=Set!HVACName=" +
|
|
haldevice.haldevicename.replaceAll(" ", "%20") +
|
|
"!HVACMode=Auto";
|
|
offpayload = "http://" + haldevice.haladdress.ip +
|
|
"/HVACService!HVACCmd=Set!HVACName=" +
|
|
haldevice.haldevicename.replaceAll(" ", "%20") +
|
|
"!HVACMode=Off";
|
|
bridgeService.buildUrls(onpayload, null, offpayload, null, false, haldevice.haldevicename + "-" + haldevice.haladdress.name + "-SetAuto", haldevice.haldevicename + " Auto", haldevice.haladdress.name, "thermo", "halThermoSet", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.buildHALOffUrls = function (haldevice, buildonly) {
|
|
onpayload = "http://" + haldevice.haladdress.ip +
|
|
"/HVACService!HVACCmd=Set!HVACName=" +
|
|
haldevice.haldevicename.replaceAll(" ", "%20") +
|
|
"!HVACMode=Auto";
|
|
offpayload = "http://" + haldevice.haladdress.ip +
|
|
"/HVACService!HVACCmd=Set!HVACName=" +
|
|
haldevice.haldevicename.replaceAll(" ", "%20") +
|
|
"!HVACMode=Off";
|
|
bridgeService.buildUrls(onpayload, null, offpayload, null, false, haldevice.haldevicename + "-" + haldevice.haladdress.name + "-TurnOff", haldevice.haldevicename + " Thermostat", haldevice.haladdress.name, "thermo", "halThermoSet", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.buildHALFanUrls = function (haldevice, buildonly) {
|
|
onpayload = "http://" + haldevice.haladdress.ip +
|
|
"/HVACService!HVACCmd=Set!HVACName=" +
|
|
haldevice.haldevicename.replaceAll(" ", "%20") +
|
|
"!FanMode=On";
|
|
offpayload = "http://" + haldevice.haladdress.ip +
|
|
"/HVACService!HVACCmd=Set!HVACName=" +
|
|
haldevice.haldevicename.replaceAll(" ", "%20") +
|
|
"!FanMode=Auto";
|
|
bridgeService.buildUrls(onpayload, null, offpayload, null, false, haldevice.haldevicename + "-" + haldevice.haladdress.name + "-SetFan", haldevice.haldevicename + " Fan", haldevice.haladdress.name, "thermo", "halThermoSet", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.bulkAddDevices = function (dim_control) {
|
|
var devicesList = [];
|
|
$scope.clearDevice();
|
|
for (var i = 0; i < $scope.bulk.devices.length; i++) {
|
|
for (var x = 0; x < bridgeService.state.haldevices.length; x++) {
|
|
if (bridgeService.state.haldevices[x].haldevicename === $scope.bulk.devices[i]) {
|
|
if (bridgeService.state.haldevices[x].haldevicetype === "HVAC")
|
|
$scope.buildHALAutoUrls(bridgeService.state.haldevices[x], true);
|
|
else if (bridgeService.state.haldevices[x].haldevicetype === "HOME")
|
|
$scope.buildHALHomeUrls(bridgeService.state.haldevices[x], true);
|
|
else
|
|
$scope.buildDeviceUrls(bridgeService.state.haldevices[x], dim_control, true);
|
|
devicesList[i] = {
|
|
name: $scope.device.name,
|
|
mapId: $scope.device.mapId,
|
|
mapType: $scope.device.mapType,
|
|
deviceType: $scope.device.deviceType,
|
|
targetDevice: $scope.device.targetDevice,
|
|
onUrl: $scope.device.onUrl,
|
|
dimUrl: $scope.device.dimUrl,
|
|
offUrl: $scope.device.offUrl,
|
|
colorUrl: $scope.device.colorUrl,
|
|
headers: $scope.device.headers,
|
|
httpVerb: $scope.device.httpVerb,
|
|
contentType: $scope.device.contentType,
|
|
contentBody: $scope.device.contentBody,
|
|
contentBodyDim: $scope.device.contentBodyDim,
|
|
contentBodyOff: $scope.device.contentBodyOff
|
|
};
|
|
$scope.clearDevice();
|
|
}
|
|
}
|
|
}
|
|
bridgeService.bulkAddDevice(devicesList).then(
|
|
function () {
|
|
$scope.clearDevice();
|
|
bridgeService.viewDevices();
|
|
bridgeService.viewHalDevices();
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Error adding HAL devices in bulk.", error);
|
|
}
|
|
);
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
};
|
|
|
|
$scope.toggleSelection = function toggleSelection(deviceId) {
|
|
var idx = $scope.bulk.devices.indexOf(deviceId);
|
|
|
|
// is currently selected
|
|
if (idx > -1) {
|
|
$scope.bulk.devices.splice(idx, 1);
|
|
if ($scope.bulk.devices.length === 0 && $scope.selectAll)
|
|
$scope.selectAll = false;
|
|
}
|
|
|
|
// is newly selected
|
|
else {
|
|
$scope.bulk.devices.push(deviceId);
|
|
$scope.selectAll = true;
|
|
}
|
|
};
|
|
|
|
$scope.toggleSelectAll = function toggleSelectAll() {
|
|
if ($scope.selectAll) {
|
|
$scope.selectAll = false;
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
} else {
|
|
$scope.selectAll = true;
|
|
for (var x = 0; x < bridgeService.state.haldevices.length; x++) {
|
|
if ($scope.bulk.devices.indexOf(bridgeService.state.haldevices[x]) < 0)
|
|
$scope.bulk.devices.push(bridgeService.state.haldevices[x].haldevicename);
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.toggleButtons = function () {
|
|
$scope.buttonsVisible = !$scope.buttonsVisible;
|
|
if ($scope.buttonsVisible)
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.deleteDevice = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'deleteDialog',
|
|
controller: 'DeleteDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
|
|
$scope.editDevice = function (device) {
|
|
bridgeService.editDevice(device);
|
|
$location.path('/editdevice');
|
|
};
|
|
});
|
|
|
|
app.controller('MQTTController', function ($scope, $location, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = bridgeService.state.device;
|
|
bridgeService.viewMQTTDevices();
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
$scope.buttonsVisible = false;
|
|
$scope.mqttretain = false;
|
|
$scope.mqttqos = 1;
|
|
|
|
$scope.clearDevice = function () {
|
|
bridgeService.clearDevice();
|
|
$scope.device = bridgeService.state.device;
|
|
};
|
|
|
|
$scope.buildMQTTPublish = function (mqttbroker, mqtttopic, mqttmessage, mqttqos, mqttretain) {
|
|
if (mqttretain === 'undefined')
|
|
mqttretain = false;
|
|
if (mqttqos === 'undefined')
|
|
mqttqos = 1;
|
|
onpayload = "{\"clientId\":\"" + mqttbroker.clientId + "\",\"topic\":\"" + mqtttopic + "\",\"message\":\"" + mqttmessage + "\",\"qos\":\"" + mqttqos + "\",\"retain\":\"" + mqttretain + "\"}";
|
|
offpayload = "{\"clientId\":\"" + mqttbroker.clientId + "\",\"topic\":\"" + mqtttopic + "\",\"message\":\"" + mqttmessage + "\",\"qos\":\"" + mqttqos + "\",\"retain\":\"" + mqttretain + "\"}";
|
|
|
|
bridgeService.buildUrls(onpayload, null, offpayload, null, true, mqttbroker.clientId + "-" + mqtttopic, mqttbroker.clientId + mqtttopic, mqttbroker.clientId, "mqtt", "mqttMessage", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
};
|
|
|
|
$scope.toggleButtons = function () {
|
|
$scope.buttonsVisible = !$scope.buttonsVisible;
|
|
if ($scope.buttonsVisible)
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.deleteDevice = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'deleteDialog',
|
|
controller: 'DeleteDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
|
|
$scope.editDevice = function (device) {
|
|
bridgeService.editDevice(device);
|
|
$location.path('/editdevice');
|
|
};
|
|
});
|
|
|
|
app.controller('HassController', function ($scope, $location, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = bridgeService.state.device;
|
|
$scope.device_dim_control = "";
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
bridgeService.viewHassDevices();
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
$scope.buttonsVisible = false;
|
|
|
|
$scope.clearDevice = function () {
|
|
bridgeService.clearDevice();
|
|
$scope.device = bridgeService.state.device;
|
|
};
|
|
|
|
$scope.buildDeviceUrls = function (hassdevice, dim_control, buildonly) {
|
|
onpayload = "{\"entityId\":\"" + hassdevice.deviceState.entity_id + "\",\"hassName\":\"" + hassdevice.hassname + "\",\"state\":\"on\"}";
|
|
if ((dim_control.indexOf("byte") >= 0 || dim_control.indexOf("percent") >= 0 || dim_control.indexOf("math") >= 0))
|
|
dimpayload = "{\"entityId\":\"" + hassdevice.deviceState.entity_id + "\",\"hassName\":\"" + hassdevice.hassname + "\",\"state\":\"on\",\"bri\":\"" + dim_control + "\"}";
|
|
else
|
|
dimpayload = "{\"entityId\":\"" + hassdevice.deviceState.entity_id + "\",\"hassName\":\"" + hassdevice.hassname + "\",\"state\":\"on\"}";
|
|
offpayload = "{\"entityId\":\"" + hassdevice.deviceState.entity_id + "\",\"hassName\":\"" + hassdevice.hassname + "\",\"state\":\"off\"}";
|
|
|
|
bridgeService.buildUrls(onpayload, dimpayload, offpayload, null, true, hassdevice.hassname + "-" + hassdevice.deviceState.entity_id, hassdevice.deviceState.entity_id, hassdevice.hassname, "switch", "hassDevice", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.bulkAddDevices = function (dim_control) {
|
|
var devicesList = [];
|
|
$scope.clearDevice();
|
|
for (var i = 0; i < $scope.bulk.devices.length; i++) {
|
|
for (var x = 0; x < bridgeService.state.hassdevices.length; x++) {
|
|
if (bridgeService.state.hassdevices[x].deviceState.entity_id === $scope.bulk.devices[i] && bridgeService.state.hassdevices[x].domain !== "sensor" && bridgeService.state.hassdevices[x].domain !== "sun") {
|
|
$scope.buildDeviceUrls(bridgeService.state.hassdevices[x], dim_control, true);
|
|
devicesList[i] = {
|
|
name: $scope.device.name,
|
|
mapId: $scope.device.mapId,
|
|
mapType: $scope.device.mapType,
|
|
deviceType: $scope.device.deviceType,
|
|
targetDevice: $scope.device.targetDevice,
|
|
onUrl: $scope.device.onUrl,
|
|
dimUrl: $scope.device.dimUrl,
|
|
offUrl: $scope.device.offUrl,
|
|
colorUrl: $scope.device.colorUrl,
|
|
headers: $scope.device.headers,
|
|
httpVerb: $scope.device.httpVerb,
|
|
contentType: $scope.device.contentType,
|
|
contentBody: $scope.device.contentBody,
|
|
contentBodyDim: $scope.device.contentBodyDim,
|
|
contentBodyOff: $scope.device.contentBodyOff
|
|
};
|
|
$scope.clearDevice();
|
|
}
|
|
}
|
|
}
|
|
bridgeService.bulkAddDevice(devicesList).then(
|
|
function () {
|
|
$scope.clearDevice();
|
|
bridgeService.viewDevices();
|
|
bridgeService.viewHassDevices();
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Error adding Hass devices in bulk.", error);
|
|
}
|
|
);
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
};
|
|
|
|
$scope.toggleSelection = function toggleSelection(deviceId) {
|
|
var idx = $scope.bulk.devices.indexOf(deviceId);
|
|
|
|
// is currently selected
|
|
if (idx > -1) {
|
|
$scope.bulk.devices.splice(idx, 1);
|
|
if ($scope.bulk.devices.length === 0 && $scope.selectAll)
|
|
$scope.selectAll = false;
|
|
}
|
|
|
|
// is newly selected
|
|
else {
|
|
$scope.bulk.devices.push(deviceId);
|
|
$scope.selectAll = true;
|
|
}
|
|
};
|
|
|
|
$scope.toggleSelectAll = function toggleSelectAll() {
|
|
if ($scope.selectAll) {
|
|
$scope.selectAll = false;
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
} else {
|
|
$scope.selectAll = true;
|
|
for (var x = 0; x < bridgeService.state.hassdevices.length; x++) {
|
|
if ($scope.bulk.devices.indexOf(bridgeService.state.hassdevices[x].deviceState.entity_id) < 0 && bridgeService.state.hassdevices[x].domain !== "sensor" && bridgeService.state.hassdevices[x].domain !== "sun")
|
|
$scope.bulk.devices.push(bridgeService.state.hassdevices[x].deviceState.entity_id);
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.toggleButtons = function () {
|
|
$scope.buttonsVisible = !$scope.buttonsVisible;
|
|
if ($scope.buttonsVisible)
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.deleteDevice = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'deleteDialog',
|
|
controller: 'DeleteDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
|
|
$scope.editDevice = function (device) {
|
|
bridgeService.editDevice(device);
|
|
$location.path('/editdevice');
|
|
};
|
|
});
|
|
|
|
app.controller('HomeWizardController', function ($scope, $location, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = bridgeService.state.device;
|
|
$scope.device_dim_control = "";
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
bridgeService.viewHomeWizardDevices();
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
$scope.buttonsVisible = false;
|
|
|
|
$scope.clearDevice = function () {
|
|
bridgeService.clearDevice();
|
|
$scope.device = bridgeService.state.device;
|
|
};
|
|
|
|
$scope.buildDeviceUrls = function (homewizarddevice, buildonly) {
|
|
|
|
dimpayload = "{\"deviceid\":\"" + homewizarddevice.id + "\",\"action\":\"on\"}";
|
|
onpayload = "{\"deviceid\":\"" + homewizarddevice.id + "\",\"action\":\"on\"}";
|
|
offpayload = "{\"deviceid\":\"" + homewizarddevice.id + "\",\"action\":\"off\"}";
|
|
|
|
bridgeService.buildUrls(onpayload, dimpayload, offpayload, null, true, homewizarddevice.id, homewizarddevice.name, homewizarddevice.gateway, "switch", "homewizardDevice", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.bulkAddDevices = function () {
|
|
var devicesList = [];
|
|
$scope.clearDevice();
|
|
for (var i = 0; i < $scope.bulk.devices.length; i++) {
|
|
for (var x = 0; x < bridgeService.state.homewizarddevices.length; x++) {
|
|
if (bridgeService.state.homewizarddevices[x].id === $scope.bulk.devices[i]) {
|
|
$scope.buildDeviceUrls(bridgeService.state.homewizarddevices[x], true);
|
|
devicesList[i] = {
|
|
name: $scope.device.name,
|
|
mapId: $scope.device.mapId,
|
|
mapType: $scope.device.mapType,
|
|
deviceType: $scope.device.deviceType,
|
|
targetDevice: $scope.device.targetDevice,
|
|
onUrl: $scope.device.onUrl,
|
|
dimUrl: $scope.device.dimUrl,
|
|
offUrl: $scope.device.offUrl,
|
|
colorUrl: $scope.device.colorUrl,
|
|
headers: $scope.device.headers,
|
|
httpVerb: $scope.device.httpVerb,
|
|
contentType: $scope.device.contentType,
|
|
contentBody: $scope.device.contentBody,
|
|
contentBodyDim: $scope.device.contentBodyDim,
|
|
contentBodyOff: $scope.device.contentBodyOff
|
|
};
|
|
$scope.clearDevice();
|
|
}
|
|
}
|
|
}
|
|
bridgeService.bulkAddDevice(devicesList).then(
|
|
function () {
|
|
$scope.clearDevice();
|
|
bridgeService.viewDevices();
|
|
bridgeService.viewHomeWizardDevices();
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Error adding HomeWizard devices in bulk.", error);
|
|
}
|
|
);
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
};
|
|
|
|
$scope.toggleSelection = function toggleSelection(deviceId) {
|
|
var idx = $scope.bulk.devices.indexOf(deviceId);
|
|
|
|
// is currently selected
|
|
if (idx > -1) {
|
|
$scope.bulk.devices.splice(idx, 1);
|
|
if ($scope.bulk.devices.length === 0 && $scope.selectAll)
|
|
$scope.selectAll = false;
|
|
}
|
|
|
|
// is newly selected
|
|
else {
|
|
$scope.bulk.devices.push(deviceId);
|
|
$scope.selectAll = true;
|
|
}
|
|
};
|
|
|
|
$scope.toggleSelectAll = function toggleSelectAll() {
|
|
if ($scope.selectAll) {
|
|
$scope.selectAll = false;
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
} else {
|
|
$scope.selectAll = true;
|
|
for (var x = 0; x < bridgeService.state.homewizarddevices.length; x++) {
|
|
if ($scope.bulk.devices.indexOf(bridgeService.state.homewizarddevices[x]) < 0)
|
|
$scope.bulk.devices.push(bridgeService.state.homewizarddevices[x].devicename);
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.toggleButtons = function () {
|
|
$scope.buttonsVisible = !$scope.buttonsVisible;
|
|
if ($scope.buttonsVisible)
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.deleteDevice = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'deleteDialog',
|
|
controller: 'DeleteDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
|
|
$scope.editDevice = function (device) {
|
|
bridgeService.editDevice(device);
|
|
$location.path('/editdevice');
|
|
};
|
|
});
|
|
|
|
app.controller('DomoticzController', function ($scope, $location, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = bridgeService.state.device;
|
|
$scope.device_dim_control = "";
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
bridgeService.viewDomoticzDevices();
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
$scope.buttonsVisible = false;
|
|
|
|
$scope.clearDevice = function () {
|
|
bridgeService.clearDevice();
|
|
$scope.device = bridgeService.state.device;
|
|
};
|
|
|
|
$scope.buildDeviceUrls = function (domoticzdevice, dim_control, buildonly) {
|
|
var preCmd = "";
|
|
var postOnCmd = "";
|
|
var postDimCmd = "";
|
|
var postOffCmd = "";
|
|
var nameCmd = "";
|
|
var aDeviceType;
|
|
var postCmd = "";
|
|
if (domoticzdevice.devicetype === "Scene" || domoticzdevice.devicetype === "Group") {
|
|
aDeviceType = "scene";
|
|
preCmd = "/json.htm?type=command¶m=switchscene&idx=";
|
|
postOnCmd = "&switchcmd=On";
|
|
postOffCmd = "&switchcmd=Off";
|
|
} else {
|
|
aDeviceType = "switch";
|
|
preCmd = "/json.htm?type=command¶m=switchlight&idx=";
|
|
postOnCmd = "&switchcmd=On";
|
|
postDimCmd = "&switchcmd=Set%20Level&level=";
|
|
postOffCmd = "&switchcmd=Off";
|
|
}
|
|
if ((dim_control.indexOf("byte") >= 0 || dim_control.indexOf("percent") >= 0 || dim_control.indexOf("math") >= 0) && aDeviceType === "switch")
|
|
dimpayload = "http://" + domoticzdevice.domoticzaddress +
|
|
preCmd +
|
|
domoticzdevice.idx +
|
|
postDimCmd +
|
|
dim_control;
|
|
else
|
|
dimpayload = null;
|
|
onpayload = "http://" + domoticzdevice.domoticzaddress +
|
|
preCmd +
|
|
domoticzdevice.idx +
|
|
postOnCmd;
|
|
offpayload = "http://" + domoticzdevice.domoticzaddress +
|
|
preCmd +
|
|
domoticzdevice.idx +
|
|
postOffCmd;
|
|
bridgeService.buildUrls(onpayload, dimpayload, offpayload, null, false, domoticzdevice.devicename + "-" + domoticzdevice.domoticzname, domoticzdevice.devicename, domoticzdevice.domoticzname, aDeviceType, "domoticzDevice", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.bulkAddDevices = function (dim_control) {
|
|
var devicesList = [];
|
|
$scope.clearDevice();
|
|
for (var i = 0; i < $scope.bulk.devices.length; i++) {
|
|
for (var x = 0; x < bridgeService.state.domoticzdevices.length; x++) {
|
|
if (bridgeService.state.domoticzdevices[x].devicename === $scope.bulk.devices[i]) {
|
|
$scope.buildDeviceUrls(bridgeService.state.domoticzdevices[x], dim_control, true);
|
|
devicesList[i] = {
|
|
name: $scope.device.name,
|
|
mapId: $scope.device.mapId,
|
|
mapType: $scope.device.mapType,
|
|
deviceType: $scope.device.deviceType,
|
|
targetDevice: $scope.device.targetDevice,
|
|
onUrl: $scope.device.onUrl,
|
|
dimUrl: $scope.device.dimUrl,
|
|
offUrl: $scope.device.offUrl,
|
|
colorUrl: $scope.device.colorUrl,
|
|
headers: $scope.device.headers,
|
|
httpVerb: $scope.device.httpVerb,
|
|
contentType: $scope.device.contentType,
|
|
contentBody: $scope.device.contentBody,
|
|
contentBodyDim: $scope.device.contentBodyDim,
|
|
contentBodyOff: $scope.device.contentBodyOff
|
|
};
|
|
$scope.clearDevice();
|
|
}
|
|
}
|
|
}
|
|
bridgeService.bulkAddDevice(devicesList).then(
|
|
function () {
|
|
$scope.clearDevice();
|
|
bridgeService.viewDevices();
|
|
bridgeService.viewDomoticzDevices();
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Error adding Domoticz devices in bulk.", error);
|
|
}
|
|
);
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
};
|
|
|
|
$scope.toggleSelection = function toggleSelection(deviceId) {
|
|
var idx = $scope.bulk.devices.indexOf(deviceId);
|
|
|
|
// is currently selected
|
|
if (idx > -1) {
|
|
$scope.bulk.devices.splice(idx, 1);
|
|
if ($scope.bulk.devices.length === 0 && $scope.selectAll)
|
|
$scope.selectAll = false;
|
|
}
|
|
|
|
// is newly selected
|
|
else {
|
|
$scope.bulk.devices.push(deviceId);
|
|
$scope.selectAll = true;
|
|
}
|
|
};
|
|
|
|
$scope.toggleSelectAll = function toggleSelectAll() {
|
|
if ($scope.selectAll) {
|
|
$scope.selectAll = false;
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
} else {
|
|
$scope.selectAll = true;
|
|
for (var x = 0; x < bridgeService.state.domoticzdevices.length; x++) {
|
|
if ($scope.bulk.devices.indexOf(bridgeService.state.domoticzdevices[x]) < 0)
|
|
$scope.bulk.devices.push(bridgeService.state.domoticzdevices[x].devicename);
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.toggleButtons = function () {
|
|
$scope.buttonsVisible = !$scope.buttonsVisible;
|
|
if ($scope.buttonsVisible)
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.deleteDevice = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'deleteDialog',
|
|
controller: 'DeleteDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
|
|
$scope.editDevice = function (device) {
|
|
bridgeService.editDevice(device);
|
|
$location.path('/editdevice');
|
|
};
|
|
});
|
|
|
|
app.controller('LifxController', function ($scope, $location, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = bridgeService.state.device;
|
|
$scope.device_dim_control = "";
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
bridgeService.viewLifxDevices();
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
$scope.buttonsVisible = false;
|
|
|
|
$scope.clearDevice = function () {
|
|
bridgeService.clearDevice();
|
|
$scope.device = bridgeService.state.device;
|
|
};
|
|
|
|
$scope.refreshDevices = function () {
|
|
bridgeService.refreshDevices("lifxDevice");
|
|
bridgeService.viewLifxDevices();
|
|
};
|
|
|
|
$scope.buildDeviceUrls = function (lifxdevice, dim_control, buildonly) {
|
|
dimpayload = angular.toJson(lifxdevice);
|
|
onpayload = angular.toJson(lifxdevice);
|
|
offpayload = angular.toJson(lifxdevice);
|
|
bridgeService.buildUrls(onpayload, dimpayload, offpayload, null, true, lifxdevice.name, lifxdevice.name, lifxdevice.name, "switch", "lifxDevice", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.bulkAddDevices = function (dim_control) {
|
|
var devicesList = [];
|
|
$scope.clearDevice();
|
|
for (var i = 0; i < $scope.bulk.devices.length; i++) {
|
|
for (var x = 0; x < bridgeService.state.lifxdevices.length; x++) {
|
|
if (bridgeService.state.lifxdevices[x].devicename === $scope.bulk.devices[i]) {
|
|
$scope.buildDeviceUrls(bridgeService.state.lifxdevices[x], dim_control, true);
|
|
devicesList[i] = {
|
|
name: $scope.device.name,
|
|
mapId: $scope.device.mapId,
|
|
mapType: $scope.device.mapType,
|
|
deviceType: $scope.device.deviceType,
|
|
targetDevice: $scope.device.targetDevice,
|
|
onUrl: $scope.device.onUrl,
|
|
dimUrl: $scope.device.dimUrl,
|
|
offUrl: $scope.device.offUrl,
|
|
colorUrl: $scope.device.colorUrl,
|
|
headers: $scope.device.headers,
|
|
httpVerb: $scope.device.httpVerb,
|
|
contentType: $scope.device.contentType,
|
|
contentBody: $scope.device.contentBody,
|
|
contentBodyDim: $scope.device.contentBodyDim,
|
|
contentBodyOff: $scope.device.contentBodyOff
|
|
};
|
|
$scope.clearDevice();
|
|
}
|
|
}
|
|
}
|
|
bridgeService.bulkAddDevice(devicesList).then(
|
|
function () {
|
|
$scope.clearDevice();
|
|
bridgeService.viewDevices();
|
|
bridgeService.viewLifxDevices();
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Error adding LIFX devices in bulk.", error);
|
|
}
|
|
);
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
};
|
|
|
|
$scope.toggleSelection = function toggleSelection(deviceId) {
|
|
var idx = $scope.bulk.devices.indexOf(deviceId);
|
|
|
|
// is currently selected
|
|
if (idx > -1) {
|
|
$scope.bulk.devices.splice(idx, 1);
|
|
if ($scope.bulk.devices.length === 0 && $scope.selectAll)
|
|
$scope.selectAll = false;
|
|
}
|
|
|
|
// is newly selected
|
|
else {
|
|
$scope.bulk.devices.push(deviceId);
|
|
$scope.selectAll = true;
|
|
}
|
|
};
|
|
|
|
$scope.toggleSelectAll = function toggleSelectAll() {
|
|
if ($scope.selectAll) {
|
|
$scope.selectAll = false;
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
} else {
|
|
$scope.selectAll = true;
|
|
for (var x = 0; x < bridgeService.state.lifxdevices.length; x++) {
|
|
if ($scope.bulk.devices.indexOf(bridgeService.state.lifxdevices[x]) < 0)
|
|
$scope.bulk.devices.push(bridgeService.state.lifxdevices[x].devicename);
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.toggleButtons = function () {
|
|
$scope.buttonsVisible = !$scope.buttonsVisible;
|
|
if ($scope.buttonsVisible)
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.deleteDevice = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'deleteDialog',
|
|
controller: 'DeleteDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
|
|
$scope.editDevice = function (device) {
|
|
bridgeService.editDevice(device);
|
|
$location.path('/editdevice');
|
|
};
|
|
});
|
|
|
|
app.controller('SomfyController', function ($scope, $location, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = bridgeService.state.device;
|
|
$scope.device_dim_control = "";
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
$scope.somfy = {
|
|
base: "http://",
|
|
port: "3480",
|
|
id: ""
|
|
};
|
|
bridgeService.viewDevices(); //Needs this if you're navigating to the 'somfy' page directly without going to the home page first..
|
|
bridgeService.viewSomfyDevices();
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
$scope.buttonsVisible = false;
|
|
$scope.comparatorUniqueId = bridgeService.compareUniqueId;
|
|
|
|
$scope.clearDevice = function () {
|
|
bridgeService.clearDevice();
|
|
$scope.device = bridgeService.state.device;
|
|
};
|
|
|
|
$scope.buildDeviceUrls = function (somfydevice, dim_control, buildonly) {
|
|
//TODO - support partial window opening - add back 'dim_control' second param in here, and in somfydevice.html
|
|
dimpayload = null;
|
|
onpayload = "{\"label\":\"Label that is ignored probably\",\"actions\":[{\"deviceURL\":\"" + somfydevice.deviceUrl + "\",\"commands\":[{\"name\":\"open\",\"parameters\":[]}]}]}";
|
|
offpayload = "{\"label\":\"Label that is ignored probably\",\"actions\":[{\"deviceURL\":\"" + somfydevice.deviceUrl + "\",\"commands\":[{\"name\":\"close\",\"parameters\":[]}]}]}";
|
|
|
|
bridgeService.buildUrls(onpayload, dimpayload, offpayload, null, true, somfydevice.id, somfydevice.name, somfydevice.somfyname, "switch", "somfyDevice", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
|
|
$scope.bulkAddDevices = function (dim_control) {
|
|
var devicesList = [];
|
|
$scope.clearDevice();
|
|
for (var i = 0; i < $scope.bulk.devices.length; i++) {
|
|
for (var x = 0; x < bridgeService.state.somfydevices.length; x++) {
|
|
if (bridgeService.state.somfydevices[x].id === $scope.bulk.devices[i]) {
|
|
$scope.buildDeviceUrls(bridgeService.state.somfydevices[x], dim_control, true);
|
|
devicesList[i] = {
|
|
name: $scope.device.name,
|
|
mapId: $scope.device.mapId,
|
|
mapType: $scope.device.mapType,
|
|
deviceType: $scope.device.deviceType,
|
|
targetDevice: $scope.device.targetDevice,
|
|
onUrl: $scope.device.onUrl,
|
|
dimUrl: $scope.device.dimUrl,
|
|
offUrl: $scope.device.offUrl,
|
|
colorUrl: $scope.device.colorUrl,
|
|
headers: $scope.device.headers,
|
|
httpVerb: $scope.device.httpVerb,
|
|
contentType: $scope.device.contentType,
|
|
contentBody: $scope.device.contentBody,
|
|
contentBodyDim: $scope.device.contentBodyDim,
|
|
contentBodyOff: $scope.device.contentBodyOff
|
|
};
|
|
$scope.clearDevice();
|
|
}
|
|
}
|
|
}
|
|
bridgeService.bulkAddDevice(devicesList).then(
|
|
function () {
|
|
$scope.clearDevice();
|
|
bridgeService.viewDevices();
|
|
bridgeService.viewSomfyDevices();
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Error adding Somfy devices in bulk.", error);
|
|
}
|
|
);
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
};
|
|
|
|
$scope.toggleSelection = function toggleSelection(deviceId) {
|
|
var idx = $scope.bulk.devices.indexOf(deviceId);
|
|
|
|
// is currently selected
|
|
if (idx > -1) {
|
|
$scope.bulk.devices.splice(idx, 1);
|
|
if ($scope.bulk.devices.length === 0 && $scope.selectAll)
|
|
$scope.selectAll = false;
|
|
}
|
|
|
|
// is newly selected
|
|
else {
|
|
$scope.bulk.devices.push(deviceId);
|
|
$scope.selectAll = true;
|
|
}
|
|
};
|
|
|
|
$scope.toggleSelectAll = function toggleSelectAll() {
|
|
if ($scope.selectAll) {
|
|
$scope.selectAll = false;
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
} else {
|
|
$scope.selectAll = true;
|
|
for (var x = 0; x < bridgeService.state.somfydevices.length; x++) {
|
|
if ($scope.bulk.devices.indexOf(bridgeService.state.somfydevices[x]) < 0 && !bridgeService.findDeviceByMapId(bridgeService.state.somfydevices[x].id, bridgeService.state.somfydevices[x].somfyname, "somfyDevice"))
|
|
$scope.bulk.devices.push(bridgeService.state.somfydevices[x].id);
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.toggleButtons = function () {
|
|
$scope.buttonsVisible = !$scope.buttonsVisible;
|
|
if ($scope.buttonsVisible)
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.deleteDevice = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'deleteDialog',
|
|
controller: 'DeleteDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
|
|
$scope.editDevice = function (device) {
|
|
bridgeService.editDevice(device);
|
|
$location.path('/editdevice');
|
|
};
|
|
});
|
|
|
|
app.controller('OpenHABController', function ($scope, $location, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = bridgeService.state.device;
|
|
$scope.device_dim_control = "";
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
bridgeService.viewOpenHABDevices();
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
$scope.buttonsVisible = false;
|
|
|
|
$scope.clearDevice = function () {
|
|
bridgeService.clearDevice();
|
|
$scope.device = bridgeService.state.device;
|
|
};
|
|
|
|
$scope.buildDeviceUrls = function (openhabdevice, dim_control, onaction, ondata, dimaction, dimdata, offaction, offdata, coloraction, colordata, buildonly) {
|
|
var preCmd = "/rest/items/" + openhabdevice.item.name;
|
|
if (openhabdevice.item.type !== 'String') {
|
|
if ((dim_control.indexOf("byte") >= 0 || dim_control.indexOf("percent") >= 0 || dim_control.indexOf("math") >= 0)) {
|
|
dimpayload = "{\"url\":\"http://" + openhabdevice.address + preCmd + "\",\"command\":\"" + dim_control + "\"}";
|
|
} else
|
|
dimpayload = null;
|
|
onpayload = "{\"url\":\"http://" + openhabdevice.address + preCmd + "\",\"command\":\"ON\"}";
|
|
offpayload = "{\"url\":\"http://" + openhabdevice.address + preCmd + "\",\"command\":\"OFF\"}";
|
|
colorpayload = null;
|
|
} else {
|
|
if (onaction === 'other')
|
|
onpayload = "{\"url\":\"http://" + openhabdevice.address + preCmd + "\",\"command\":\"" + ondata + "\"}";
|
|
else if (onaction !== undefined && onaction !== null && onaction !== '')
|
|
onpayload = "{\"url\":\"http://" + openhabdevice.address + preCmd + "\",\"command\":\"" + onaction + "\"}";
|
|
else
|
|
onpayload = null;
|
|
|
|
if (dimaction === 'other')
|
|
dimpayload = "{\"url\":\"http://" + openhabdevice.address + preCmd + "\",\"command\":\"" + dimdata + "\"}";
|
|
else if (dimaction !== undefined && dimaction !== null && dimaction !== '')
|
|
dimpayload = "{\"url\":\"http://" + openhabdevice.address + preCmd + "\",\"command\":\"" + dimaction + "\"}";
|
|
else
|
|
dimpayload = null;
|
|
|
|
if (offaction === 'other')
|
|
offpayload = "{\"url\":\"http://" + openhabdevice.address + preCmd + "\",\"command\":\"" + offdata + "\"}";
|
|
else if (offaction !== undefined && offaction !== null && offaction !== '')
|
|
offpayload = "{\"url\":\"http://" + openhabdevice.address + preCmd + "\",\"command\":\"" + offaction + "\"}";
|
|
else
|
|
offpayload = null;
|
|
|
|
if (coloraction === 'other')
|
|
colorpayload = "{\"url\":\"http://" + openhabdevice.address + preCmd + "\",\"command\":\"" + colordata + "\"}";
|
|
else if (coloraction !== undefined && coloraction !== null && coloraction !== '')
|
|
colorpayload = "{\"url\":\"http://" + openhabdevice.address + preCmd + "\",\"command\":\"" + coloraction + "\"}";
|
|
else
|
|
colorpayload = null;
|
|
}
|
|
bridgeService.buildUrls(onpayload, dimpayload, offpayload, colorpayload, true, openhabdevice.item.name + "-" + openhabdevice.name, openhabdevice.item.name, openhabdevice.name, "switch", "openhabDevice", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.bulkAddDevices = function (dim_control) {
|
|
var devicesList = [];
|
|
$scope.clearDevice();
|
|
for (var i = 0; i < $scope.bulk.devices.length; i++) {
|
|
for (var x = 0; x < bridgeService.state.openhabdevices.length; x++) {
|
|
if (bridgeService.state.openhabdevices[x].devicename === $scope.bulk.devices[i]) {
|
|
$scope.buildDeviceUrls(bridgeService.state.openhabdevices[x], dim_control, null, null, null, null, null, null, null, null, true);
|
|
devicesList[i] = {
|
|
name: $scope.device.name,
|
|
mapId: $scope.device.mapId,
|
|
mapType: $scope.device.mapType,
|
|
deviceType: $scope.device.deviceType,
|
|
targetDevice: $scope.device.targetDevice,
|
|
onUrl: $scope.device.onUrl,
|
|
dimUrl: $scope.device.dimUrl,
|
|
offUrl: $scope.device.offUrl,
|
|
colorUrl: $scope.device.colorUrl,
|
|
headers: $scope.device.headers,
|
|
httpVerb: $scope.device.httpVerb,
|
|
contentType: $scope.device.contentType,
|
|
contentBody: $scope.device.contentBody,
|
|
contentBodyDim: $scope.device.contentBodyDim,
|
|
contentBodyOff: $scope.device.contentBodyOff
|
|
};
|
|
$scope.clearDevice();
|
|
}
|
|
}
|
|
}
|
|
bridgeService.bulkAddDevice(devicesList).then(
|
|
function () {
|
|
$scope.clearDevice();
|
|
bridgeService.viewDevices();
|
|
bridgeService.viewOpenHABDevices();
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Error adding openhab devices in bulk.", error);
|
|
}
|
|
);
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
};
|
|
|
|
$scope.toggleSelection = function toggleSelection(deviceId) {
|
|
var idx = $scope.bulk.devices.indexOf(deviceId);
|
|
|
|
// is currently selected
|
|
if (idx > -1) {
|
|
$scope.bulk.devices.splice(idx, 1);
|
|
if ($scope.bulk.devices.length === 0 && $scope.selectAll)
|
|
$scope.selectAll = false;
|
|
}
|
|
|
|
// is newly selected
|
|
else {
|
|
$scope.bulk.devices.push(deviceId);
|
|
$scope.selectAll = true;
|
|
}
|
|
};
|
|
|
|
$scope.toggleSelectAll = function toggleSelectAll() {
|
|
if ($scope.selectAll) {
|
|
$scope.selectAll = false;
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
} else {
|
|
$scope.selectAll = true;
|
|
for (var x = 0; x < bridgeService.state.openhabdevices.length; x++) {
|
|
if ($scope.bulk.devices.indexOf(bridgeService.state.openhabdevices[x]) < 0)
|
|
$scope.bulk.devices.push(bridgeService.state.openhabdevices[x].devicename);
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.toggleButtons = function () {
|
|
$scope.buttonsVisible = !$scope.buttonsVisible;
|
|
if ($scope.buttonsVisible)
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.deleteDevice = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'deleteDialog',
|
|
controller: 'DeleteDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
|
|
$scope.editDevice = function (device) {
|
|
bridgeService.editDevice(device);
|
|
$location.path('/editdevice');
|
|
};
|
|
});
|
|
|
|
app.controller('MozIotController', function ($scope, $location, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = bridgeService.state.device;
|
|
$scope.device_dim_control = "";
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
bridgeService.viewMozIotDevices();
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
$scope.buttonsVisible = false;
|
|
|
|
$scope.clearDevice = function () {
|
|
bridgeService.clearDevice();
|
|
$scope.device = bridgeService.state.device;
|
|
};
|
|
|
|
$scope.buildDeviceUrls = function (moziotdevice, dim_control, coloraction, colordata, buildonly) {
|
|
var preCmd = moziotdevice.deviceDetail.href + "/properties/";
|
|
onpayload = null;
|
|
offpayload = null;
|
|
dimpayload = null;
|
|
colorpayload = null;
|
|
if (moziotdevice.deviceDetail.properties.on !== undefined) {
|
|
onpayload = "{\"url\":\"" + preCmd + "on\",\"command\":{\"on\":true}}";
|
|
offpayload = "{\"url\":\"" + preCmd + "on\",\"command\":{\"on\":false}}";
|
|
}
|
|
if (dim_control !== undefined && dim_control !== "") {
|
|
dimpayload = "{\"url\":\"" + preCmd + "level\",\"command\":{\"level\":\"" + dim_control + "\"}}";
|
|
}
|
|
if (coloraction === 'other')
|
|
colorpayload = "{\"url\":\"" + preCmd + "color\",\"command\":{\"color\":\"" + colordata + "\"}}";
|
|
else if (coloraction !== undefined && coloraction !== null && coloraction !== '')
|
|
colorpayload = "{\"url\":\"" + preCmd + "color\",\"command\":{\"color\":\"" + coloraction + "\"}}";
|
|
|
|
bridgeService.buildUrls(onpayload, dimpayload, offpayload, colorpayload, true, moziotdevice.deviceDetail.title + "-" + moziotdevice.deviceDetail.type, moziotdevice.deviceDetail.title, moziotdevice.gatewayName, "switch", "moziotDevice", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.bulkAddDevices = function (dim_control) {
|
|
var devicesList = [];
|
|
$scope.clearDevice();
|
|
for (var i = 0; i < $scope.bulk.devices.length; i++) {
|
|
for (var x = 0; x < bridgeService.state.moziotdevices.length; x++) {
|
|
if (bridgeService.state.moziotdevices[x].devicename === $scope.bulk.devices[i]) {
|
|
$scope.buildDeviceUrls(bridgeService.state.moziotdevices[x], dim_control, null, null, true);
|
|
devicesList[i] = {
|
|
name: $scope.device.name,
|
|
mapId: $scope.device.mapId,
|
|
mapType: $scope.device.mapType,
|
|
deviceType: $scope.device.deviceType,
|
|
targetDevice: $scope.device.targetDevice,
|
|
onUrl: $scope.device.onUrl,
|
|
dimUrl: $scope.device.dimUrl,
|
|
offUrl: $scope.device.offUrl,
|
|
colorUrl: $scope.device.colorUrl,
|
|
headers: $scope.device.headers,
|
|
httpVerb: $scope.device.httpVerb,
|
|
contentType: $scope.device.contentType,
|
|
contentBody: $scope.device.contentBody,
|
|
contentBodyDim: $scope.device.contentBodyDim,
|
|
contentBodyOff: $scope.device.contentBodyOff
|
|
};
|
|
$scope.clearDevice();
|
|
}
|
|
}
|
|
}
|
|
bridgeService.bulkAddDevice(devicesList).then(
|
|
function () {
|
|
$scope.clearDevice();
|
|
bridgeService.viewDevices();
|
|
bridgeService.viewMozIotDevices();
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Error adding Mozilla IOT devices in bulk.", error);
|
|
}
|
|
);
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
};
|
|
|
|
$scope.toggleSelection = function toggleSelection(deviceId) {
|
|
var idx = $scope.bulk.devices.indexOf(deviceId);
|
|
|
|
// is currently selected
|
|
if (idx > -1) {
|
|
$scope.bulk.devices.splice(idx, 1);
|
|
if ($scope.bulk.devices.length === 0 && $scope.selectAll)
|
|
$scope.selectAll = false;
|
|
}
|
|
|
|
// is newly selected
|
|
else {
|
|
$scope.bulk.devices.push(deviceId);
|
|
$scope.selectAll = true;
|
|
}
|
|
};
|
|
|
|
$scope.toggleSelectAll = function toggleSelectAll() {
|
|
if ($scope.selectAll) {
|
|
$scope.selectAll = false;
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
} else {
|
|
$scope.selectAll = true;
|
|
for (var x = 0; x < bridgeService.state.moziotdevices.length; x++) {
|
|
if ($scope.bulk.devices.indexOf(bridgeService.state.moziotdevices[x]) < 0)
|
|
$scope.bulk.devices.push(bridgeService.state.moziotdevices[x].devicename);
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.toggleButtons = function () {
|
|
$scope.buttonsVisible = !$scope.buttonsVisible;
|
|
if ($scope.buttonsVisible)
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.deleteDevice = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'deleteDialog',
|
|
controller: 'DeleteDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
|
|
$scope.editDevice = function (device) {
|
|
bridgeService.editDevice(device);
|
|
$location.path('/editdevice');
|
|
};
|
|
});
|
|
|
|
app.controller('FhemController', function ($scope, $location, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = bridgeService.state.device;
|
|
$scope.device_dim_control = "";
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
bridgeService.viewFhemDevices();
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
$scope.buttonsVisible = false;
|
|
|
|
$scope.clearDevice = function () {
|
|
bridgeService.clearDevice();
|
|
$scope.device = bridgeService.state.device;
|
|
};
|
|
|
|
$scope.buildDeviceUrls = function (fhemdevice, dim_control, buildonly) {
|
|
var preCmd = "/fhem?cmd=set%20" + fhemdevice.item.Name + "%20";
|
|
if (fhemdevice.item.PossibleSets.toLowerCase().indexOf("dim") >= 0) {
|
|
if ((dim_control.indexOf("byte") >= 0 || dim_control.indexOf("percent") >= 0 || dim_control.indexOf("math") >= 0)) {
|
|
dimpayload = "{\"url\":\"http://" + fhemdevice.address + preCmd + "\",\"command\":\"dim%20" + dim_control + "\"}";
|
|
} else
|
|
dimpayload = "{\"url\":\"http://" + fhemdevice.address + preCmd + "\",\"command\":\"dim%20${intensity.percent}\"}";
|
|
} else if (fhemdevice.item.PossibleSets.toLowerCase().indexOf("pct") >= 0) {
|
|
if ((dim_control.indexOf("byte") >= 0 || dim_control.indexOf("percent") >= 0 || dim_control.indexOf("math") >= 0)) {
|
|
dimpayload = "{\"url\":\"http://" + fhemdevice.address + preCmd + "\",\"command\":\"pct%20" + dim_control + "\"}";
|
|
} else
|
|
dimpayload = "{\"url\":\"http://" + fhemdevice.address + preCmd + "\",\"command\":\"pct%20${intensity.percent}\"}";
|
|
} else
|
|
dimpayload = null;
|
|
if (fhemdevice.item.PossibleSets.toLowerCase().indexOf("rgb") >= 0) {
|
|
colorpayload = "{\"url\":\"http://" + fhemdevice.address + preCmd + "\",\"command\":\"RGB%20${color.rgbx}\"}";
|
|
} else
|
|
colorpayload = null;
|
|
onpayload = "{\"url\":\"http://" + fhemdevice.address + preCmd + "\",\"command\":\"on\"}";
|
|
offpayload = "{\"url\":\"http://" + fhemdevice.address + preCmd + "\",\"command\":\"off\"}";
|
|
bridgeService.buildUrls(onpayload, dimpayload, offpayload, colorpayload, true, fhemdevice.item.Name + "-" + fhemdevice.name, fhemdevice.item.Name, fhemdevice.name, "switch", "fhemDevice", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.bulkAddDevices = function (dim_control) {
|
|
var devicesList = [];
|
|
$scope.clearDevice();
|
|
for (var i = 0; i < $scope.bulk.devices.length; i++) {
|
|
for (var x = 0; x < bridgeService.state.fhemdevices.length; x++) {
|
|
if (bridgeService.state.fhemdevices[x].item.Name === $scope.bulk.devices[i]) {
|
|
$scope.buildDeviceUrls(bridgeService.state.fhemdevices[x], dim_control, true);
|
|
devicesList[i] = {
|
|
name: $scope.device.name,
|
|
mapId: $scope.device.mapId,
|
|
mapType: $scope.device.mapType,
|
|
deviceType: $scope.device.deviceType,
|
|
targetDevice: $scope.device.targetDevice,
|
|
onUrl: $scope.device.onUrl,
|
|
dimUrl: $scope.device.dimUrl,
|
|
offUrl: $scope.device.offUrl,
|
|
colorUrl: $scope.device.colorUrl,
|
|
headers: $scope.device.headers,
|
|
httpVerb: $scope.device.httpVerb,
|
|
contentType: $scope.device.contentType,
|
|
contentBody: $scope.device.contentBody,
|
|
contentBodyDim: $scope.device.contentBodyDim,
|
|
contentBodyOff: $scope.device.contentBodyOff
|
|
};
|
|
$scope.clearDevice();
|
|
}
|
|
}
|
|
}
|
|
bridgeService.bulkAddDevice(devicesList).then(
|
|
function () {
|
|
$scope.clearDevice();
|
|
bridgeService.viewDevices();
|
|
bridgeService.viewFhemDevices();
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Error adding fhem devices in bulk.", error);
|
|
}
|
|
);
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
};
|
|
|
|
$scope.toggleSelection = function toggleSelection(deviceId) {
|
|
var idx = $scope.bulk.devices.indexOf(deviceId);
|
|
|
|
// is currently selected
|
|
if (idx > -1) {
|
|
$scope.bulk.devices.splice(idx, 1);
|
|
if ($scope.bulk.devices.length === 0 && $scope.selectAll)
|
|
$scope.selectAll = false;
|
|
}
|
|
|
|
// is newly selected
|
|
else {
|
|
$scope.bulk.devices.push(deviceId);
|
|
$scope.selectAll = true;
|
|
}
|
|
};
|
|
|
|
$scope.toggleSelectAll = function toggleSelectAll() {
|
|
if ($scope.selectAll) {
|
|
$scope.selectAll = false;
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
} else {
|
|
$scope.selectAll = true;
|
|
for (var x = 0; x < bridgeService.state.fhemdevices.length; x++) {
|
|
if ($scope.bulk.devices.indexOf(bridgeService.state.fhemdevices[x]) < 0)
|
|
$scope.bulk.devices.push(bridgeService.state.fhemdevices[x].item.Name);
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.toggleButtons = function () {
|
|
$scope.buttonsVisible = !$scope.buttonsVisible;
|
|
if ($scope.buttonsVisible)
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.deleteDevice = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'deleteDialog',
|
|
controller: 'DeleteDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
|
|
$scope.editDevice = function (device) {
|
|
bridgeService.editDevice(device);
|
|
$location.path('/editdevice');
|
|
};
|
|
});
|
|
|
|
app.controller('BroadlinkController', function ($scope, $location, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = bridgeService.state.device;
|
|
$scope.device_dim_control = "";
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
bridgeService.viewBroadlinkDevices();
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
$scope.buttonsVisible = false;
|
|
|
|
$scope.clearDevice = function () {
|
|
bridgeService.clearDevice();
|
|
$scope.device = bridgeService.state.device;
|
|
};
|
|
|
|
$scope.refreshDevices = function () {
|
|
bridgeService.refreshDevices("broadlinkDevice");
|
|
bridgeService.viewBroadlinkDevices();
|
|
};
|
|
|
|
$scope.buildDeviceUrls = function (broadlinkdevice, dim_control, ondata, dimdata, offdata, colordata, buildonly) {
|
|
var preCmd = "{\"id\":\"" + broadlinkdevice.id + "\",\"name\":\"" + broadlinkdevice.name + "\",\"type\":\"" + broadlinkdevice.type + "\",\"ipAddr\":\"" + broadlinkdevice.ipAddr + "\",\"macAddr\":\"" + broadlinkdevice.macAddr + "\",\"command\":\"";
|
|
if (broadlinkdevice.baseType === '0000' || broadlinkdevice.baseType === '2711') {
|
|
dimpayload = null;
|
|
colorpayload = null;
|
|
onpayload = preCmd + "on\"}";
|
|
offpayload = preCmd + "off\"}";
|
|
} else if (broadlinkdevice.baseType === '4EB5') {
|
|
dimpayload = null;
|
|
colorpayload = null;
|
|
onpayload = preCmd + "on\",\"data\":\"" + ondata + "\"}";
|
|
offpayload = preCmd + "off\",\"data\":\"" + offdata + "\"}";
|
|
} else {
|
|
if (ondata !== undefined && ondata !== null && ondata !== "")
|
|
onpayload = preCmd + "ircommand\",\"data\":\"" + ondata + "\"}";
|
|
else
|
|
onpayload = null;
|
|
if (dimdata !== undefined && dimdata !== null && dimdata !== "")
|
|
dimpayload = preCmd + "ircommand\",\"data\":\"" + dimdata + "\"}";
|
|
else
|
|
dimpayload = null;
|
|
if (offdata !== undefined && offdata !== null && offdata !== "")
|
|
offpayload = preCmd + "ircommand\",\"data\":\"" + offdata + "\"}";
|
|
else
|
|
offpayload = null;
|
|
if (colordata !== undefined && colordata !== null && colordata !== "")
|
|
colorpayload = preCmd + "ircommand\",\"data\":\"" + colordata + "\"}";
|
|
else
|
|
colorpayload = null;
|
|
}
|
|
bridgeService.buildUrls(onpayload, dimpayload, offpayload, colorpayload, true, broadlinkdevice.id, broadlinkdevice.name, broadlinkdevice.id, "switch", "broadlinkDevice", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.bulkAddDevices = function (dim_control) {
|
|
var devicesList = [];
|
|
$scope.clearDevice();
|
|
for (var i = 0; i < $scope.bulk.devices.length; i++) {
|
|
for (var x = 0; x < bridgeService.state.broadlinkdevices.length; x++) {
|
|
if (bridgeService.state.broadlinkdevices[x].devicename === $scope.bulk.devices[i]) {
|
|
$scope.buildDeviceUrls(bridgeService.state.broadlinkdevices[x], dim_control, null, null, null, null, true);
|
|
devicesList[i] = {
|
|
name: $scope.device.name,
|
|
mapId: $scope.device.mapId,
|
|
mapType: $scope.device.mapType,
|
|
deviceType: $scope.device.deviceType,
|
|
targetDevice: $scope.device.targetDevice,
|
|
onUrl: $scope.device.onUrl,
|
|
dimUrl: $scope.device.dimUrl,
|
|
offUrl: $scope.device.offUrl,
|
|
colorUrl: $scope.device.colorUrl,
|
|
headers: $scope.device.headers,
|
|
httpVerb: $scope.device.httpVerb,
|
|
contentType: $scope.device.contentType,
|
|
contentBody: $scope.device.contentBody,
|
|
contentBodyDim: $scope.device.contentBodyDim,
|
|
contentBodyOff: $scope.device.contentBodyOff
|
|
};
|
|
$scope.clearDevice();
|
|
}
|
|
}
|
|
}
|
|
bridgeService.bulkAddDevice(devicesList).then(
|
|
function () {
|
|
$scope.clearDevice();
|
|
bridgeService.viewDevices();
|
|
bridgeService.viewBroadlinkDevices();
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Error adding openhab devices in bulk.", error);
|
|
}
|
|
);
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
};
|
|
|
|
$scope.toggleSelection = function toggleSelection(deviceId) {
|
|
var idx = $scope.bulk.devices.indexOf(deviceId);
|
|
|
|
// is currently selected
|
|
if (idx > -1) {
|
|
$scope.bulk.devices.splice(idx, 1);
|
|
if ($scope.bulk.devices.length === 0 && $scope.selectAll)
|
|
$scope.selectAll = false;
|
|
}
|
|
|
|
// is newly selected
|
|
else {
|
|
$scope.bulk.devices.push(deviceId);
|
|
$scope.selectAll = true;
|
|
}
|
|
};
|
|
|
|
$scope.toggleSelectAll = function toggleSelectAll() {
|
|
if ($scope.selectAll) {
|
|
$scope.selectAll = false;
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
} else {
|
|
$scope.selectAll = true;
|
|
for (var x = 0; x < bridgeService.state.broadlinkdevices.length; x++) {
|
|
if ($scope.bulk.devices.indexOf(bridgeService.state.broadlinkdevices[x]) < 0)
|
|
$scope.bulk.devices.push(bridgeService.state.broadlinkdevices[x].devicename);
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.toggleButtons = function () {
|
|
$scope.buttonsVisible = !$scope.buttonsVisible;
|
|
if ($scope.buttonsVisible)
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.deleteDevice = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'deleteDialog',
|
|
controller: 'DeleteDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
|
|
$scope.editDevice = function (device) {
|
|
bridgeService.editDevice(device);
|
|
$location.path('/editdevice');
|
|
};
|
|
});
|
|
|
|
app.controller('HomeGenieController', function ($scope, $location, bridgeService, ngDialog) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = bridgeService.state.device;
|
|
$scope.device_dim_control = "";
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
bridgeService.viewHomeGenieDevices();
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
$scope.buttonsVisible = false;
|
|
|
|
$scope.clearDevice = function () {
|
|
bridgeService.clearDevice();
|
|
$scope.device = bridgeService.state.device;
|
|
};
|
|
|
|
$scope.buildDeviceUrls = function (homegeniedevice, dim_control, coloraction, colordata, buildonly) {
|
|
var preCmd = "{\"moduleType\":\"" + homegeniedevice.deviceDetail.Domain + "\",\"deviceId\":\"" + homegeniedevice.deviceDetail.Address + "\",\"command\":";
|
|
onpayload = null;
|
|
offpayload = null;
|
|
dimpayload = null;
|
|
colorpayload = null;
|
|
onpayload = preCmd + "{\"command\":\"Control.On\"}}";
|
|
offpayload = preCmd + "{\"command\":\"Control.Off\"}}";
|
|
if (dim_control !== undefined && dim_control !== "") {
|
|
dimpayload = preCmd + "{\"command\":\"Control.Level\",\"level\":\"" + dim_control + "\"}}";
|
|
}
|
|
// if (coloraction === 'other')
|
|
// colorpayload = "{\"url\":\"" + preCmd + "color\",\"command\":{\"color\":\"" + colordata + "\"}}";
|
|
// else if (coloraction !== undefined && coloraction !== null && coloraction !== '')
|
|
// colorpayload = "{\"url\":\"" + preCmd + "color\",\"command\":{\"color\":\"" + coloraction + "\"}}";
|
|
|
|
bridgeService.buildUrls(onpayload, dimpayload, offpayload, colorpayload, true, homegeniedevice.deviceDetail.Name + "-" + homegeniedevice.deviceDetail.DeviceType, homegeniedevice.deviceDetail.Name, homegeniedevice.gatewayName, "switch", "homegenieDevice", null, null);
|
|
$scope.device = bridgeService.state.device;
|
|
if (!buildonly) {
|
|
bridgeService.editNewDevice($scope.device);
|
|
$location.path('/editdevice');
|
|
}
|
|
};
|
|
|
|
$scope.bulkAddDevices = function (dim_control) {
|
|
var devicesList = [];
|
|
$scope.clearDevice();
|
|
for (var i = 0; i < $scope.bulk.devices.length; i++) {
|
|
for (var x = 0; x < bridgeService.state.homegeniedevices.length; x++) {
|
|
if (bridgeService.state.homegeniedevices[x].devicename === $scope.bulk.devices[i]) {
|
|
$scope.buildDeviceUrls(bridgeService.state.homegeniedevices[x], dim_control, null, null, true);
|
|
devicesList[i] = {
|
|
name: $scope.device.name,
|
|
mapId: $scope.device.mapId,
|
|
mapType: $scope.device.mapType,
|
|
deviceType: $scope.device.deviceType,
|
|
targetDevice: $scope.device.targetDevice,
|
|
onUrl: $scope.device.onUrl,
|
|
dimUrl: $scope.device.dimUrl,
|
|
offUrl: $scope.device.offUrl,
|
|
colorUrl: $scope.device.colorUrl,
|
|
headers: $scope.device.headers,
|
|
httpVerb: $scope.device.httpVerb,
|
|
contentType: $scope.device.contentType,
|
|
contentBody: $scope.device.contentBody,
|
|
contentBodyDim: $scope.device.contentBodyDim,
|
|
contentBodyOff: $scope.device.contentBodyOff
|
|
};
|
|
$scope.clearDevice();
|
|
}
|
|
}
|
|
}
|
|
bridgeService.bulkAddDevice(devicesList).then(
|
|
function () {
|
|
$scope.clearDevice();
|
|
bridgeService.viewDevices();
|
|
bridgeService.viewHomeGenieDevices();
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Error adding HomeGenie devices in bulk.", error);
|
|
}
|
|
);
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
$scope.selectAll = false;
|
|
};
|
|
|
|
$scope.toggleSelection = function toggleSelection(deviceId) {
|
|
var idx = $scope.bulk.devices.indexOf(deviceId);
|
|
|
|
// is currently selected
|
|
if (idx > -1) {
|
|
$scope.bulk.devices.splice(idx, 1);
|
|
if ($scope.bulk.devices.length === 0 && $scope.selectAll)
|
|
$scope.selectAll = false;
|
|
}
|
|
|
|
// is newly selected
|
|
else {
|
|
$scope.bulk.devices.push(deviceId);
|
|
$scope.selectAll = true;
|
|
}
|
|
};
|
|
|
|
$scope.toggleSelectAll = function toggleSelectAll() {
|
|
if ($scope.selectAll) {
|
|
$scope.selectAll = false;
|
|
$scope.bulk = {
|
|
devices: []
|
|
};
|
|
} else {
|
|
$scope.selectAll = true;
|
|
for (var x = 0; x < bridgeService.state.homegeniedevices.length; x++) {
|
|
if ($scope.bulk.devices.indexOf(bridgeService.state.homegeniedevices[x]) < 0)
|
|
$scope.bulk.devices.push(bridgeService.state.homegeniedevices[x].devicename);
|
|
}
|
|
}
|
|
};
|
|
|
|
$scope.toggleButtons = function () {
|
|
$scope.buttonsVisible = !$scope.buttonsVisible;
|
|
if ($scope.buttonsVisible)
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.deleteDevice = function (device) {
|
|
$scope.bridge.device = device;
|
|
ngDialog.open({
|
|
template: 'deleteDialog',
|
|
controller: 'DeleteDialogCtrl',
|
|
className: 'ngdialog-theme-default'
|
|
});
|
|
};
|
|
|
|
$scope.editDevice = function (device) {
|
|
bridgeService.editDevice(device);
|
|
$location.path('/editdevice');
|
|
};
|
|
});
|
|
|
|
app.controller('EditController', function ($scope, $location, bridgeService) {
|
|
$scope.bridge = bridgeService.state;
|
|
$scope.device = bridgeService.state.device;
|
|
$scope.onDevices = null;
|
|
$scope.dimDevices = null;
|
|
$scope.offDevices = null;
|
|
$scope.colorDevices = null;
|
|
$scope.showUrls = false;
|
|
$scope.onUrl = null;
|
|
$scope.dimUrl = null;
|
|
$scope.offUrl = null;
|
|
$scope.colorUrl = null;
|
|
if ($scope.device !== undefined && $scope.device.name !== undefined) {
|
|
if ($scope.bridge.device.onUrl !== undefined) {
|
|
$scope.onDevices = bridgeService.getCallObjects($scope.bridge.device.onUrl);
|
|
$scope.onUrl = $scope.bridge.device.onUrl.split("},").join("},\n");
|
|
}
|
|
if ($scope.bridge.device.dimUrl !== undefined) {
|
|
$scope.dimDevices = bridgeService.getCallObjects($scope.bridge.device.dimUrl);
|
|
$scope.dimUrl = $scope.bridge.device.dimUrl.split("},").join("},\n");
|
|
}
|
|
if ($scope.bridge.device.offUrl !== undefined) {
|
|
$scope.offDevices = bridgeService.getCallObjects($scope.bridge.device.offUrl);
|
|
$scope.offUrl = $scope.bridge.device.offUrl.split("},").join("},\n");
|
|
}
|
|
if ($scope.bridge.device.colorUrl !== undefined) {
|
|
$scope.colorDevices = bridgeService.getCallObjects($scope.bridge.device.colorUrl);
|
|
$scope.colorUrl = $scope.bridge.device.colorUrl.split("},").join("},\n");
|
|
}
|
|
}
|
|
|
|
$scope.newOnItem = {};
|
|
$scope.newDimItem = {};
|
|
$scope.newOffItem = {};
|
|
$scope.newColorItem = {};
|
|
$scope.mapTypeSelected = bridgeService.getMapType($scope.device.mapType);
|
|
$scope.device_dim_control = "";
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
$scope.buttonsVisible = false;
|
|
|
|
$scope.clearDevice = function () {
|
|
bridgeService.clearDevice();
|
|
$scope.onDevices = null;
|
|
$scope.dimDevices = null;
|
|
$scope.offDevices = null;
|
|
$scope.colorDevices = null;
|
|
$scope.showUrls = false;
|
|
$scope.onUrl = null;
|
|
$scope.dimUrl = null;
|
|
$scope.offUrl = null;
|
|
$scope.colorUrl = null;
|
|
$scope.newOnItem = {};
|
|
$scope.newDimItem = {};
|
|
$scope.newOffItem = {};
|
|
$scope.newColorItem = {};
|
|
$scope.device = bridgeService.state.device;
|
|
$scope.mapTypeSelected = null;
|
|
};
|
|
|
|
$scope.editDevice = function (copy) {
|
|
if ($scope.device.name === "" && $scope.device.onUrl === "") {
|
|
$scope.clearDevice();
|
|
bridgeService.displayWarn("Error adding/editing device. Name has not been given.", null);
|
|
return;
|
|
}
|
|
if (($scope.device.name === $scope.bridge.olddevicename) && copy) {
|
|
$scope.clearDevice();
|
|
bridgeService.displayWarn("Error adding device. Name has not been changed from original.", null);
|
|
return;
|
|
}
|
|
if (copy) {
|
|
$scope.device.id = null;
|
|
$scope.device.uniqueid = null;
|
|
if ($scope.bridge.olddevicename !== null && $scope.bridge.olddevicename !== "")
|
|
$scope.device.mapId = $scope.device.mapId + "-copy";
|
|
}
|
|
if ($scope.mapTypeSelected !== undefined && $scope.mapTypeSelected !== null)
|
|
$scope.device.mapType = $scope.mapTypeSelected[0];
|
|
else
|
|
$scope.device.mapType = null;
|
|
|
|
if ($scope.showUrls) {
|
|
$scope.device.onUrl = ($scope.onUrl == undefined || $scope.onUrl == null || $scope.onUrl == "") ? null : $scope.onUrl.replace(/\r?\n|\r/g, "");
|
|
$scope.device.dimUrl = ($scope.dimUrl == undefined || $scope.dimUrl == null || $scope.dimUrl == "") ? null : $scope.dimUrl.replace(/\r?\n|\r/g, "");
|
|
$scope.device.offUrl = ($scope.offUrl == undefined || $scope.offUrl == null || $scope.offUrl == "") ? null : $scope.offUrl.replace(/\r?\n|\r/g, "");
|
|
$scope.device.colorUrl = ($scope.colorUrl == undefined || $scope.colorUrl == null || $scope.colorUrl == "") ? null : $scope.colorUrl.replace(/\r?\n|\r/g, "");
|
|
} else {
|
|
if ($scope.onDevices !== null)
|
|
$scope.device.onUrl = angular.toJson(bridgeService.updateCallObjectsType($scope.onDevices));
|
|
if ($scope.dimDevices !== null)
|
|
$scope.device.dimUrl = angular.toJson(bridgeService.updateCallObjectsType($scope.dimDevices));
|
|
if ($scope.offDevices !== null)
|
|
$scope.device.offUrl = angular.toJson(bridgeService.updateCallObjectsType($scope.offDevices));
|
|
if ($scope.colorDevices !== null)
|
|
$scope.device.colorUrl = angular.toJson(bridgeService.updateCallObjectsType($scope.colorDevices));
|
|
}
|
|
|
|
|
|
bridgeService.addDevice($scope.device).then(
|
|
function () {
|
|
bridgeService.state.queueDevId = $scope.device.id;
|
|
console.log("Device updated for Q Id <<" + bridgeService.state.queueDevId + ">>");
|
|
$scope.clearDevice();
|
|
$location.path('/');
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Error adding/updating device....", error);
|
|
}
|
|
);
|
|
|
|
};
|
|
|
|
$scope.addItemOn = function (anItem) {
|
|
if (anItem.item === undefined || anItem.item === null || anItem.item === "")
|
|
return;
|
|
var newitem = {
|
|
item: anItem.item,
|
|
type: anItem.type,
|
|
delay: anItem.delay,
|
|
count: anItem.count,
|
|
filterIPs: anItem.filterIPs,
|
|
httpVerb: anItem.httpVerb,
|
|
httpBody: anItem.httpBody,
|
|
httpHeaders: anItem.httpHeaders,
|
|
contentType: anItem.contentType
|
|
};
|
|
if ($scope.onDevices === null)
|
|
$scope.onDevices = [];
|
|
$scope.onDevices.push(newitem);
|
|
$scope.newOnItem = {};
|
|
};
|
|
$scope.removeItemOn = function (anItem) {
|
|
for (var i = $scope.onDevices.length - 1; i >= 0; i--) {
|
|
if ($scope.onDevices[i] === anItem) {
|
|
$scope.onDevices.splice(i, 1);
|
|
}
|
|
}
|
|
$scope.newOnItem = {};
|
|
};
|
|
|
|
$scope.addItemDim = function (anItem) {
|
|
if (anItem.item === undefined || anItem.item === null || anItem.item === "")
|
|
return;
|
|
var newitem = {
|
|
item: anItem.item,
|
|
type: anItem.type,
|
|
delay: anItem.delay,
|
|
count: anItem.count,
|
|
filterIPs: anItem.filterIPs,
|
|
httpVerb: anItem.httpVerb,
|
|
httpBody: anItem.httpBody,
|
|
httpHeaders: anItem.httpHeaders,
|
|
contentType: anItem.contentType
|
|
};
|
|
if ($scope.dimDevices === null)
|
|
$scope.dimDevices = [];
|
|
$scope.dimDevices.push(newitem);
|
|
$scope.newDimItem = {};
|
|
};
|
|
$scope.removeItemDim = function (anItem) {
|
|
for (var i = $scope.dimDevices.length - 1; i >= 0; i--) {
|
|
if ($scope.dimDevices[i] === anItem) {
|
|
$scope.dimDevices.splice(i, 1);
|
|
}
|
|
}
|
|
$scope.newDimItem = {};
|
|
};
|
|
|
|
$scope.addItemOff = function (anItem) {
|
|
if (anItem.item === undefined || anItem.item === null || anItem.item === "")
|
|
return;
|
|
var newitem = {
|
|
item: anItem.item,
|
|
type: anItem.type,
|
|
delay: anItem.delay,
|
|
count: anItem.count,
|
|
filterIPs: anItem.filterIPs,
|
|
httpVerb: anItem.httpVerb,
|
|
httpBody: anItem.httpBody,
|
|
httpHeaders: anItem.httpHeaders,
|
|
contentType: anItem.contentType
|
|
};
|
|
if ($scope.offDevices === null)
|
|
$scope.offDevices = [];
|
|
$scope.offDevices.push(newitem);
|
|
$scope.newOffItem = {};
|
|
};
|
|
$scope.removeItemOff = function (anItem) {
|
|
for (var i = $scope.offDevices.length - 1; i >= 0; i--) {
|
|
if ($scope.offDevices[i] === anItem) {
|
|
$scope.offDevices.splice(i, 1);
|
|
}
|
|
}
|
|
$scope.newOffItem = {};
|
|
};
|
|
|
|
$scope.addItemColor = function (anItem) {
|
|
if (anItem.item === undefined || anItem.item === null || anItem.item === "")
|
|
return;
|
|
var newitem = {
|
|
item: anItem.item,
|
|
type: anItem.type,
|
|
delay: anItem.delay,
|
|
count: anItem.count,
|
|
filterIPs: anItem.filterIPs,
|
|
httpVerb: anItem.httpVerb,
|
|
httpBody: anItem.httpBody,
|
|
httpHeaders: anItem.httpHeaders,
|
|
contentType: anItem.contentType
|
|
};
|
|
if ($scope.colorDevices === null)
|
|
$scope.colorDevices = [];
|
|
$scope.colorDevices.push(newitem);
|
|
$scope.newColorItem = {};
|
|
};
|
|
$scope.removeItemColor = function (anItem) {
|
|
for (var i = $scope.colorDevices.length - 1; i >= 0; i--) {
|
|
if ($scope.colorDevices[i] === anItem) {
|
|
$scope.colorDevices.splice(i, 1);
|
|
}
|
|
}
|
|
$scope.newColorItem = {};
|
|
};
|
|
|
|
|
|
$scope.toggleButtons = function () {
|
|
$scope.buttonsVisible = !$scope.buttonsVisible;
|
|
if ($scope.buttonsVisible)
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-minus";
|
|
else
|
|
$scope.imgButtonsUrl = "glyphicon glyphicon-plus";
|
|
};
|
|
|
|
$scope.changeEditmode = function () {
|
|
// copy local changes over to other edit mode
|
|
if ($scope.showUrls) {
|
|
$scope.onDevices = ($scope.onUrl == undefined || $scope.onUrl == null || $scope.onUrl == "") ? null : bridgeService.getCallObjects($scope.onUrl.replace(/\r?\n|\r/g, ""));
|
|
$scope.dimDevices = ($scope.dimUrl == undefined || $scope.dimUrl == null || $scope.dimUrl == "") ? null : bridgeService.getCallObjects($scope.dimUrl.replace(/\r?\n|\r/g, ""));
|
|
$scope.offDevices = ($scope.offUrl == undefined || $scope.offUrl == null || $scope.offUrl == "") ? null : bridgeService.getCallObjects($scope.offUrl.replace(/\r?\n|\r/g, ""));
|
|
$scope.colorDevices = ($scope.colorUrl == undefined || $scope.colorUrl == null || $scope.colorUrl == "") ? null : bridgeService.getCallObjects($scope.colorUrl.replace(/\r?\n|\r/g, ""));
|
|
} else {
|
|
$scope.onUrl = ($scope.onDevices !== null) ? angular.toJson(bridgeService.updateCallObjectsType($scope.onDevices)).split("},").join("},\n") : null;
|
|
$scope.dimUrl = ($scope.dimDevices !== null) ? angular.toJson(bridgeService.updateCallObjectsType($scope.dimDevices)).split("},").join("},\n") : null;
|
|
$scope.offUrl = ($scope.offDevices !== null) ? angular.toJson(bridgeService.updateCallObjectsType($scope.offDevices)).split("},").join("},\n") : null;
|
|
$scope.colorUrl = ($scope.colorDevices !== null) ? angular.toJson(bridgeService.updateCallObjectsType($scope.colorDevices)).split("},").join("},\n") : null;
|
|
}
|
|
$scope.showUrls = !$scope.showUrls;
|
|
};
|
|
|
|
});
|
|
|
|
app.filter('configuredVeraDevices', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "veraDevice")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredVeraScenes', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "veraScene")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredFibaroDevices', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "fibaroDevice")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredFibaroScenes', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "fibaroScene")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredNestItems', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "nest")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredHueItems', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "hue")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredHalItems', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "hal")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredHarmonyActivities', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "harmonyActivity")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredHarmonyButtons', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "harmonyButton")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredMqttMsgs', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "mqtt")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredHassItems', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "hass")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredDomoticzItems', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "domoticz")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredLifxItems', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "lifx")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredSomfyDevices', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "somfyDevice")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredHomeWizardDevices', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "homewizardDevice")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredOpenHABItems', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "openhab")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredFhemItems', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "fhem")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredBroadlinkItems', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "broadlink")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredMozIotItems', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "moziot")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('configuredHomeGenieItems', function (bridgeService) {
|
|
return function (input) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
for (var i = 0; i < input.length; i++) {
|
|
if (bridgeService.deviceContainsType(input[i], "homegenie")) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.filter('filterDevicesByRequester', function () {
|
|
return function (input, search, mustContain, deviceType) {
|
|
var out = [];
|
|
if (input === undefined || input === null || input.length === undefined)
|
|
return out;
|
|
var pattern = new RegExp(search);
|
|
var patternType = new RegExp(deviceType);
|
|
for (var i = 0; i < input.length; i++) {
|
|
var pushRequester = false;
|
|
var pushType = false;
|
|
|
|
// Check filter by requester
|
|
if (!search || search.trim().length === 0) { // if search is empty and mustContain == true push only unfiltered devices
|
|
if (mustContain) {
|
|
if (!input[i].requesterAddress || input[i].requesterAddress.length === 0) {
|
|
pushRequester = true;
|
|
}
|
|
} else {
|
|
pushRequester = true;
|
|
}
|
|
} else {
|
|
if (pattern.test(input[i].requesterAddress) || !mustContain && (!input[i].requesterAddress || input[i].requesterAddress.length === 0)) {
|
|
pushRequester = true;
|
|
}
|
|
}
|
|
|
|
// Check filter by deviceType
|
|
if (deviceType) {
|
|
pushType = patternType.test(input[i].deviceType);
|
|
} else {
|
|
pushType = true;
|
|
}
|
|
|
|
if (pushRequester && pushType) {
|
|
out.push(input[i]);
|
|
}
|
|
}
|
|
return out;
|
|
};
|
|
});
|
|
|
|
app.controller('LoginController', function ($scope, $location, Auth, bridgeService) {
|
|
$scope.failed = false;
|
|
$scope.isSecure = bridgeService.isSecure();
|
|
$scope.loggedIn = Auth.isLoggedIn();
|
|
$scope.login = function (username, password) {
|
|
Auth.login(username, password)
|
|
.then(function () {
|
|
$location.path("/");
|
|
}, function () {
|
|
$scope.failed = true;
|
|
});
|
|
};
|
|
|
|
$scope.logout = function () {
|
|
Auth.logout();
|
|
$scope.isSecure = bridgeService.isSecure();
|
|
$scope.loggedIn = Auth.isLoggedIn();
|
|
if ($scope.isSecure)
|
|
$location.path("/login");
|
|
else
|
|
$location.path("/");
|
|
};
|
|
});
|
|
|
|
app.controller('VersionController', function ($scope, bridgeService) {
|
|
$scope.bridge = bridgeService.state;
|
|
});
|
|
|
|
app.directive('permission', ['Auth', function (Auth) {
|
|
return {
|
|
restrict: 'A',
|
|
scope: {
|
|
permission: '='
|
|
},
|
|
|
|
link: function (scope, elem, attrs) {
|
|
scope.$watch(Auth.isLoggedIn, function () {
|
|
if (Auth.userHasPermission(scope.permission)) {
|
|
elem.show();
|
|
} else {
|
|
elem.hide();
|
|
}
|
|
});
|
|
}
|
|
};
|
|
}]);
|
|
|
|
app.factory('Auth', function ($resource, $rootScope, $sessionStorage, $http, $base64, bridgeService) {
|
|
|
|
var auth = {};
|
|
|
|
/**
|
|
* Saves the current user in the root scope
|
|
* Call this in the app run() method
|
|
*/
|
|
auth.init = function () {
|
|
if (auth.isLoggedIn()) {
|
|
$rootScope.user = auth.currentUser();
|
|
}
|
|
};
|
|
|
|
auth.login = function (username, password) {
|
|
var newUserInfo = {};
|
|
newUserInfo = {
|
|
username: username,
|
|
password: password
|
|
};
|
|
var theEncodedPayload = $base64.encode(angular.toJson(newUserInfo));
|
|
return $http.post(bridgeService.state.systemsbase + "/login", theEncodedPayload).then(
|
|
function (response) {
|
|
var theResult = response.data;
|
|
$sessionStorage.user = theResult.user;
|
|
$rootScope.user = $sessionStorage.user;
|
|
bridgeService.state.loggedInUser = $sessionStorage.user.username;
|
|
bridgeService.getHABridgeVersion();
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Login Error: ", error);
|
|
});
|
|
};
|
|
|
|
|
|
auth.logout = function () {
|
|
delete $sessionStorage.user;
|
|
delete $rootScope.user;
|
|
delete bridgeService.state.loggedInUser;
|
|
// Logout on server side to destroy current session (fire and forget it)
|
|
$http.put(bridgeService.state.systemsbase + "/logout").then(
|
|
function (response) {
|
|
// nothing more to do
|
|
},
|
|
function (error) {
|
|
bridgeService.displayWarn("Logout Error: ", error);
|
|
}
|
|
);
|
|
};
|
|
|
|
|
|
auth.checkPermissionForView = function (view) {
|
|
if (!view.requiresAuthentication) {
|
|
return true;
|
|
}
|
|
|
|
return userHasPermissionForView(view);
|
|
};
|
|
|
|
|
|
var userHasPermissionForView = function (view) {
|
|
if (!auth.isLoggedIn()) {
|
|
return false;
|
|
}
|
|
|
|
if (!view.permissions || !view.permissions.length) {
|
|
return true;
|
|
}
|
|
|
|
return auth.userHasPermission(view.permissions);
|
|
};
|
|
|
|
|
|
auth.userHasPermission = function (permissions) {
|
|
if (!bridgeService.isSecure())
|
|
return true;
|
|
if (!auth.isLoggedIn()) {
|
|
return false;
|
|
}
|
|
|
|
var found = false;
|
|
angular.forEach(permissions, function (permission, index) {
|
|
if ($sessionStorage.user.user_permissions.indexOf(permission) >= 0) {
|
|
found = true;
|
|
return;
|
|
}
|
|
});
|
|
|
|
return found;
|
|
};
|
|
|
|
|
|
auth.currentUser = function () {
|
|
if (!bridgeService.isSecure())
|
|
return "nouser";
|
|
return $sessionStorage.user;
|
|
};
|
|
|
|
|
|
auth.isLoggedIn = function () {
|
|
if (!bridgeService.isSecure())
|
|
return true;
|
|
return $sessionStorage.user != null;
|
|
};
|
|
|
|
|
|
return auth;
|
|
}); |