From 1d2e5f1d0b31df34fe5a0c6f66dc938b9a16ed19 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lorenz=20H=C3=BCbschle-Schneider?= Date: Mon, 28 Apr 2014 13:40:27 +0100 Subject: [PATCH 1/2] Better countWatchers The old one missed a few, two on the input and the one in the title. This version also doesn't use jQuery From: http://stackoverflow.com/a/18539624 by StackOverflow user "plantian" --- js/glowingbear.js | 30 ++++++++++++++---------------- 1 file changed, 14 insertions(+), 16 deletions(-) diff --git a/js/glowingbear.js b/js/glowingbear.js index 84bfbdc..d4d83b9 100644 --- a/js/glowingbear.js +++ b/js/glowingbear.js @@ -491,24 +491,22 @@ function($rootScope, weechat.controller('WeechatCtrl', ['$rootScope', '$scope', '$store', '$timeout', '$log', 'models', 'connection', function ($rootScope, $scope, $store, $timeout, $log, models, connection) { + // From: http://stackoverflow.com/a/18539624 by StackOverflow user "plantian" $rootScope.countWatchers = function () { - var root = $(document.getElementsByTagName('body')); - var watchers = []; - - var f = function (element) { - if (element.data().hasOwnProperty('$scope')) { - angular.forEach(element.data().$scope.$$watchers, function (watcher) { - watchers.push(watcher); - }); + var q = [$rootScope], watchers = 0, scope; + while (q.length > 0) { + scope = q.pop(); + if (scope.$$watchers) { + watchers += scope.$$watchers.length; } - - angular.forEach(element.children(), function (childElement) { - f($(childElement)); - }); - }; - - f(root); - console.log(watchers.length); + if (scope.$$childHead) { + q.push(scope.$$childHead); + } + if (scope.$$nextSibling) { + q.push(scope.$$nextSibling); + } + } + console.log(watchers); }; From d363121556c5f0cd5f70c52575f2b599055a91f0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lorenz=20H=C3=BCbschle-Schneider?= Date: Mon, 28 Apr 2014 13:52:21 +0100 Subject: [PATCH 2/2] Remove unnecessary uses of jQuery and dead code Native code is faster anyways ;) --- js/glowingbear.js | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/js/glowingbear.js b/js/glowingbear.js index d4d83b9..5594461 100644 --- a/js/glowingbear.js +++ b/js/glowingbear.js @@ -703,7 +703,7 @@ weechat.controller('WeechatCtrl', ['$rootScope', '$scope', '$store', '$timeout', $scope.search = ''; if (!$rootScope.isMobileUi()) { - $('#sendMessage').focus(); + document.getElementById('sendMessage').focus(); } }); @@ -1215,10 +1215,7 @@ weechat.directive('inputBar', function() { * Returns the input element */ $scope.getInputNode = function() { - return $element.find('#'+$scope.inputId)[0]; - }; - $scope.getForm = function() { - return $element.find('form')[0]; + return document.querySelector('textarea#' + $scope.inputId); }; $scope.completeNick = function() {