GUAC-963: Use $evalAsync() for changes to $scope that may occur synchronously.

This commit is contained in:
Michael Jumper
2014-12-28 22:19:50 -08:00
parent 1758085032
commit 3b81525eff
2 changed files with 6 additions and 6 deletions

View File

@@ -243,7 +243,7 @@ angular.module('client').factory('ManagedClient', ['$rootScope', '$injector',
// Update connection state as tunnel state changes
tunnel.onstatechange = function tunnelStateChanged(state) {
$rootScope.$apply(function updateTunnelState() {
$rootScope.$evalAsync(function updateTunnelState() {
switch (state) {
@@ -269,7 +269,7 @@ angular.module('client').factory('ManagedClient', ['$rootScope', '$injector',
// Update connection state as client state changes
client.onstatechange = function clientStateChanged(clientState) {
$rootScope.$apply(function updateClientState() {
$rootScope.$evalAsync(function updateClientState() {
switch (clientState) {

View File

@@ -23,7 +23,7 @@
/**
* A directive which allows elements to be manually focused / blurred.
*/
angular.module('element').directive('guacFocus', ['$timeout', '$parse', function guacFocus($timeout, $parse) {
angular.module('element').directive('guacFocus', ['$parse', function guacFocus($parse) {
return {
restrict: 'A',
@@ -47,7 +47,7 @@ angular.module('element').directive('guacFocus', ['$timeout', '$parse', function
// Set/unset focus depending on value of guacFocus
$scope.$watch(guacFocus, function updateFocus(value) {
$timeout(function updateFocusAsync() {
$scope.$evalAsync(function updateFocusAsync() {
if (value)
element.focus();
else
@@ -57,14 +57,14 @@ angular.module('element').directive('guacFocus', ['$timeout', '$parse', function
// Set focus flag when focus is received
element.addEventListener('focus', function focusReceived() {
$scope.$apply(function setGuacFocus() {
$scope.$evalAsync(function setGuacFocusAsync() {
guacFocus.assign($scope, true);
});
});
// Unset focus flag when focus is lost
element.addEventListener('blur', function focusLost() {
$scope.$apply(function unsetGuacFocus() {
$scope.$evalAsync(function unsetGuacFocusAsync() {
guacFocus.assign($scope, false);
});
});