diff options
Diffstat (limited to 'framework/src/onos/web/gui/src/main/webapp/app/directives.js')
-rw-r--r-- | framework/src/onos/web/gui/src/main/webapp/app/directives.js | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/framework/src/onos/web/gui/src/main/webapp/app/directives.js b/framework/src/onos/web/gui/src/main/webapp/app/directives.js new file mode 100644 index 00000000..0b4f4957 --- /dev/null +++ b/framework/src/onos/web/gui/src/main/webapp/app/directives.js @@ -0,0 +1,72 @@ +/* + * Copyright 2015 Open Networking Laboratory + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* + ONOS GUI -- General Purpose Angular directives defined here. + */ + +(function () { + 'use strict'; + + angular.module('onosApp') + + // Create a resize directive, that we can apply to elements + // so that they can respond to window resize events. + .directive('resize', ['$window', 'FnService', function ($window, fs) { + return { + scope: { + offsetHeight: '@', + offsetWidth: '@', + notifier: '&' + }, + link: function (scope, element) { + var elem = d3.select(element[0]); + scope.$watchCollection(function () { + return { + h: $window.innerHeight, + w: $window.innerWidth + }; + }, function () { + var offH = scope.offsetHeight || 0, + offW = scope.offsetWidth || 0, + wsz = fs.windowSize(offH, offW); + + elem.style({ + height: wsz.height + 'px', + width: wsz.width + 'px' + }); + + if (fs.isF(scope.notifier)) { + scope.notifier(); + } + }); + + angular.element($window).bind('resize', function () { + scope.$apply(); + }); + } + }; + }]) + + .directive('ngRepeatComplete', [function () { + return function (scope) { + if (scope.$last) { + scope.$emit('ngRepeatComplete'); + scope.$broadcast('ngRepeatComplete'); + } + }; + }]); +}()); |