From 00ca67e4befffed00ecee81bd1ce903fe01f542a Mon Sep 17 00:00:00 2001 From: Vojta Jina Date: Sat, 30 Oct 2010 20:57:13 +0200 Subject: Issue #51: Update extensionMap() If user override existing extension, angular properties ($) will be preserved. This piece of logic could be refactored into separate method: Something like we have extend(), addMissingProperties() - I can't find a name for this method... Closes #51 --- src/Angular.js | 7 +++++++ test/AngularSpec.js | 20 ++++++++++++++++++++ 2 files changed, 27 insertions(+) diff --git a/src/Angular.js b/src/Angular.js index dbd662ce..16b31d4b 100644 --- a/src/Angular.js +++ b/src/Angular.js @@ -281,11 +281,18 @@ function inherit(parent, extra) { function noop() {} function identity($) {return $;} function valueFn(value) {return function(){ return value; };} + function extensionMap(angular, name, transform) { var extPoint; return angular[name] || (extPoint = angular[name] = function (name, fn, prop){ name = (transform || identity)(name); if (isDefined(fn)) { + if (isDefined(extPoint[name])) { + foreach(extPoint[name], function(property, key) { + if (key.charAt(0) == '$' && isUndefined(fn[key])) + fn[key] = property; + }); + } extPoint[name] = extend(fn, prop || {}); } return extPoint[name]; diff --git a/test/AngularSpec.js b/test/AngularSpec.js index bab7df18..d5005151 100644 --- a/test/AngularSpec.js +++ b/test/AngularSpec.js @@ -280,3 +280,23 @@ describe('angularJsConfig', function() { ie_compat_id: 'ng-ie-compat'}); }); }); + +describe('extensionMap', function() { + it('should preserve $ properties on override', function() { + var extension = extensionMap({}, 'fake'); + extension('first', {$one: true, $two: true}); + var result = extension('first', {$one: false, $three: true}); + + expect(result.$one).toBeFalsy(); + expect(result.$two).toBeTruthy(); + expect(result.$three).toBeTruthy(); + }); + + it('should not preserve non-angular properties', function() { + var extension = extensionMap({}, 'fake'); + extension('first', {two: true}); + var result = extension('first', {$one: false, $three: true}); + + expect(result.two).not.toBeDefined(); + }); +}); -- cgit v1.2.3