128 lines
4.1 KiB
JavaScript
128 lines
4.1 KiB
JavaScript
'use strict';
|
|
|
|
angular.module('Application').controller('MainController', ['$scope', '$route', '$interval', 'Client', function ($scope, $route, $interval, Client) {
|
|
$scope.initialized = false;
|
|
$scope.user = Client.getUserInfo();
|
|
$scope.installedApps = Client.getInstalledApps();
|
|
$scope.config = {};
|
|
|
|
$scope.update = {
|
|
busy: false,
|
|
error: {},
|
|
password: ''
|
|
};
|
|
|
|
$scope.isActive = function (url) {
|
|
if (!$route.current) return false;
|
|
return $route.current.$$route.originalPath.indexOf(url) === 0;
|
|
};
|
|
|
|
$scope.logout = function (event) {
|
|
event.stopPropagation();
|
|
$scope.initialized = false;
|
|
Client.logout();
|
|
};
|
|
|
|
$scope.setup = function () {
|
|
window.location.href = '/error.html?errorCode=1';
|
|
};
|
|
|
|
$scope.error = function (error) {
|
|
console.error(error);
|
|
window.location.href = '/error.html';
|
|
};
|
|
|
|
$scope.showUpdateModal = function (form) {
|
|
$scope.update.error.password = null;
|
|
$scope.update.password = '';
|
|
|
|
form.$setPristine();
|
|
form.$setUntouched();
|
|
|
|
$('#updateModal').modal('show');
|
|
};
|
|
|
|
$scope.doUpdate = function () {
|
|
$scope.update.error.password = null;
|
|
|
|
$scope.update.busy = true;
|
|
Client.update($scope.update.password, function (error) {
|
|
if (error) {
|
|
if (error.statusCode === 403) {
|
|
$scope.update.error.password = 'Incorrect password';
|
|
$scope.update.password = '';
|
|
$('#inputUpdatePassword').focus();
|
|
} else {
|
|
console.error('Unable to update.', error);
|
|
}
|
|
$scope.update.busy = false;
|
|
return;
|
|
}
|
|
|
|
window.location.href = '/update.html';
|
|
});
|
|
};
|
|
|
|
Client.isServerFirstTime(function (error, isFirstTime) {
|
|
if (error) return $scope.error(error);
|
|
if (isFirstTime) return $scope.setup();
|
|
|
|
Client.refreshConfig(function (error) {
|
|
if (error) return $scope.error(error);
|
|
|
|
// check version and force reload if needed
|
|
if (!localStorage.version) {
|
|
localStorage.version = Client.getConfig().version;
|
|
} else if (localStorage.version !== Client.getConfig().version) {
|
|
localStorage.version = Client.getConfig().version;
|
|
window.location.reload(true);
|
|
}
|
|
|
|
Client.refreshUserInfo(function (error, result) {
|
|
if (error) return $scope.error(error);
|
|
|
|
Client.refreshInstalledApps(function (error) {
|
|
if (error) return $scope.error(error);
|
|
|
|
// kick off installed apps and config polling
|
|
var refreshAppsTimer = $interval(Client.refreshInstalledApps.bind(Client), 2000);
|
|
var refreshConfigTimer = $interval(Client.refreshConfig.bind(Client), 5000);
|
|
var refreshUserInfoTimer = $interval(Client.refreshUserInfo.bind(Client), 5000);
|
|
|
|
$scope.$on('$destroy', function () {
|
|
$interval.cancel(refreshAppsTimer);
|
|
$interval.cancel(refreshConfigTimer);
|
|
$interval.cancel(refreshUserInfoTimer);
|
|
});
|
|
|
|
// now mark the Client to be ready
|
|
Client.setReady();
|
|
|
|
$scope.config = Client.getConfig();
|
|
|
|
$scope.initialized = true;
|
|
});
|
|
});
|
|
});
|
|
});
|
|
|
|
// wait till the view has loaded until showing a modal dialog
|
|
Client.onConfig(function (config) {
|
|
// check if we are actually updating
|
|
if (config.progress.update && config.progress.update.percent !== -1) {
|
|
window.location.href = '/update.html';
|
|
}
|
|
|
|
if (config.cloudronName) {
|
|
document.title = config.cloudronName;
|
|
}
|
|
});
|
|
|
|
// setup all the dialog focus handling
|
|
['updateModal'].forEach(function (id) {
|
|
$('#' + id).on('shown.bs.modal', function () {
|
|
$(this).find("[autofocus]:first").focus();
|
|
});
|
|
});
|
|
}]);
|