| /* |
| * Licensed to the Apache Software Foundation (ASF) under one or more |
| * contributor license agreements. See the NOTICE file distributed with |
| * this work for additional information regarding copyright ownership. |
| * The ASF licenses this file to You 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. |
| */ |
| |
| /* global define, module, require, exports */ |
| |
| (function (root, factory) { |
| if (typeof define === 'function' && define.amd) { |
| define(['angular'], function (angular) { |
| return (nf.ng.Bridge = factory(angular)); |
| }); |
| } else if (typeof exports === 'object' && typeof module === 'object') { |
| module.exports = (nf.ng.Bridge = factory(require('angular'))); |
| } else { |
| nf.ng.Bridge = factory(root.angular); |
| } |
| }(this, function (angular) { |
| 'use strict'; |
| |
| function AngularBridge() { |
| this.rootScope; |
| this.injector; |
| }; |
| AngularBridge.prototype = { |
| constructor: AngularBridge, |
| |
| /** |
| * Inspects the root scope of the bridged angular application to look up |
| * objects (to be provided as the `this` context) and invoke methods. |
| * |
| * @param {string} thisArg The value of `this` provided for the call to `fun`. |
| * Note that this may not be the actual value seen |
| * by the method: if the method is a function in |
| * non-strict mode code, null and undefined will be |
| * replaced with the global object, and primitive |
| * values will be boxed. |
| * @param {string} fun The function to call. |
| * @param [, arg1[, arg2[, ...]]] Arguments for the `fun` |
| * @returns {*} The value of the `fun` if `fun` returns a value. |
| * |
| */ |
| call: function (thisArg, fun) { |
| var objArray = thisArg.split("."); |
| var obj = this.rootScope; |
| angular.forEach(objArray, function (value) { |
| obj = obj[value]; |
| }); |
| var funArray = fun.split("."); |
| fun = this.rootScope; |
| angular.forEach(funArray, function (value) { |
| fun = fun[value]; |
| }); |
| |
| var args = Array.prototype.slice.call(arguments, 2); |
| var result = fun.apply(obj, args); |
| |
| if (result) { |
| return result; |
| } |
| }, |
| |
| /** |
| * Inspects the root scope of the bridged angular application to look up |
| * and return object. |
| * |
| * @param {string} name The (dot notation) name of the object to lookup. |
| * @returns {Object|*} |
| */ |
| get: function (name) { |
| var objArray = name.split("."); |
| var obj = this.rootScope; |
| angular.forEach(objArray, function (value) { |
| obj = obj[value]; |
| }); |
| |
| return obj; |
| }, |
| |
| digest: function () { |
| this.rootScope.$digest(); |
| } |
| }; |
| |
| return new AngularBridge(); |
| })); |