2010-01-12 00:15:12 +00:00
|
|
|
var angularGlobal = {
|
2010-01-10 16:58:57 +00:00
|
|
|
'typeOf':function(obj){
|
2010-08-18 23:23:12 +00:00
|
|
|
if (obj === _null) return $null;
|
2010-01-06 00:36:58 +00:00
|
|
|
var type = typeof obj;
|
2010-08-18 23:23:12 +00:00
|
|
|
if (type == $object) {
|
|
|
|
|
if (obj instanceof Array) return $array;
|
2010-11-07 06:50:04 +00:00
|
|
|
if (isDate(obj)) return $date;
|
2010-08-18 23:23:12 +00:00
|
|
|
if (obj.nodeType == 1) return $element;
|
2010-01-06 00:36:58 +00:00
|
|
|
}
|
|
|
|
|
return type;
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
2010-03-30 03:25:42 +00:00
|
|
|
var angularCollection = {
|
2010-07-20 23:55:32 +00:00
|
|
|
'copy': copy,
|
2010-07-19 19:29:24 +00:00
|
|
|
'size': size,
|
|
|
|
|
'equals': equals
|
2010-03-30 03:25:42 +00:00
|
|
|
};
|
2010-04-09 23:20:15 +00:00
|
|
|
var angularObject = {
|
|
|
|
|
'extend': extend
|
|
|
|
|
};
|
2010-11-22 18:23:45 +00:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @workInProgress
|
|
|
|
|
* @ngdoc overview
|
|
|
|
|
* @name angular.Array
|
|
|
|
|
*
|
|
|
|
|
* @description
|
|
|
|
|
* Utility functions for manipulation with JavaScript Array objects.
|
|
|
|
|
*
|
|
|
|
|
* These functions are exposed in two ways:
|
|
|
|
|
*
|
|
|
|
|
* - **in angular expressions**: the functions are bound to the Array objects and augment the Array
|
|
|
|
|
* type as array methods. The names of these methods are prefixed with `$` character to minimize
|
|
|
|
|
* naming collisions. To call a method, invoke `myArrayObject.$foo(params)`.
|
|
|
|
|
*
|
|
|
|
|
* - **in JavaScript code**: the functions don't augment the Array type and must be invoked as
|
|
|
|
|
* functions of `angular.Array` as `angular.Array.foo(myArrayObject, params)`.
|
|
|
|
|
*
|
|
|
|
|
*/
|
2010-01-12 00:15:12 +00:00
|
|
|
var angularArray = {
|
2010-11-22 18:26:47 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @workInProgress
|
|
|
|
|
* @ngdoc function
|
|
|
|
|
* @name angular.Array.indexOf
|
|
|
|
|
* @function
|
|
|
|
|
*/
|
2010-03-30 03:25:42 +00:00
|
|
|
'indexOf': indexOf,
|
2010-01-10 16:58:57 +00:00
|
|
|
'sum':function(array, expression) {
|
|
|
|
|
var fn = angular['Function']['compile'](expression);
|
2010-01-06 00:36:58 +00:00
|
|
|
var sum = 0;
|
|
|
|
|
for (var i = 0; i < array.length; i++) {
|
|
|
|
|
var value = 1 * fn(array[i]);
|
|
|
|
|
if (!isNaN(value)){
|
|
|
|
|
sum += value;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return sum;
|
|
|
|
|
},
|
2010-11-22 18:26:47 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @workInProgress
|
|
|
|
|
* @ngdoc function
|
|
|
|
|
* @name angular.Array.remove
|
|
|
|
|
* @function
|
|
|
|
|
*/
|
2010-01-10 16:58:57 +00:00
|
|
|
'remove':function(array, value) {
|
2010-03-30 03:25:42 +00:00
|
|
|
var index = indexOf(array, value);
|
2010-01-06 00:36:58 +00:00
|
|
|
if (index >=0)
|
|
|
|
|
array.splice(index, 1);
|
|
|
|
|
return value;
|
|
|
|
|
},
|
2010-11-22 18:26:47 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @workInProgress
|
|
|
|
|
* @ngdoc function
|
|
|
|
|
* @name angular.Array.filter
|
|
|
|
|
* @function
|
|
|
|
|
*/
|
2010-01-10 16:58:57 +00:00
|
|
|
'filter':function(array, expression) {
|
2010-01-06 00:36:58 +00:00
|
|
|
var predicates = [];
|
|
|
|
|
predicates.check = function(value) {
|
|
|
|
|
for (var j = 0; j < predicates.length; j++) {
|
|
|
|
|
if(!predicates[j](value)) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return true;
|
|
|
|
|
};
|
|
|
|
|
var search = function(obj, text){
|
|
|
|
|
if (text.charAt(0) === '!') {
|
|
|
|
|
return !search(obj, text.substr(1));
|
|
|
|
|
}
|
|
|
|
|
switch (typeof obj) {
|
|
|
|
|
case "boolean":
|
|
|
|
|
case "number":
|
|
|
|
|
case "string":
|
|
|
|
|
return ('' + obj).toLowerCase().indexOf(text) > -1;
|
|
|
|
|
case "object":
|
|
|
|
|
for ( var objKey in obj) {
|
|
|
|
|
if (objKey.charAt(0) !== '$' && search(obj[objKey], text)) {
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
case "array":
|
|
|
|
|
for ( var i = 0; i < obj.length; i++) {
|
|
|
|
|
if (search(obj[i], text)) {
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
default:
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
switch (typeof expression) {
|
|
|
|
|
case "boolean":
|
|
|
|
|
case "number":
|
|
|
|
|
case "string":
|
|
|
|
|
expression = {$:expression};
|
|
|
|
|
case "object":
|
|
|
|
|
for (var key in expression) {
|
|
|
|
|
if (key == '$') {
|
|
|
|
|
(function(){
|
|
|
|
|
var text = (''+expression[key]).toLowerCase();
|
|
|
|
|
if (!text) return;
|
|
|
|
|
predicates.push(function(value) {
|
|
|
|
|
return search(value, text);
|
|
|
|
|
});
|
|
|
|
|
})();
|
|
|
|
|
} else {
|
|
|
|
|
(function(){
|
|
|
|
|
var path = key;
|
|
|
|
|
var text = (''+expression[key]).toLowerCase();
|
|
|
|
|
if (!text) return;
|
|
|
|
|
predicates.push(function(value) {
|
|
|
|
|
return search(getter(value, path), text);
|
|
|
|
|
});
|
|
|
|
|
})();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
break;
|
2010-08-18 23:23:12 +00:00
|
|
|
case $function:
|
2010-01-06 00:36:58 +00:00
|
|
|
predicates.push(expression);
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
return array;
|
|
|
|
|
}
|
|
|
|
|
var filtered = [];
|
|
|
|
|
for ( var j = 0; j < array.length; j++) {
|
|
|
|
|
var value = array[j];
|
|
|
|
|
if (predicates.check(value)) {
|
|
|
|
|
filtered.push(value);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return filtered;
|
|
|
|
|
},
|
2010-11-22 18:26:47 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @workInProgress
|
|
|
|
|
* @ngdoc function
|
|
|
|
|
* @name angular.Array.add
|
|
|
|
|
* @function
|
2010-11-23 19:05:28 +00:00
|
|
|
*
|
|
|
|
|
* @description
|
|
|
|
|
* `add` is a function similar to JavaScript's `Array#push` method, in that it appends a new
|
|
|
|
|
* element to an array, but it differs in that the value being added is optional and defaults to
|
|
|
|
|
* an emty object.
|
|
|
|
|
*
|
|
|
|
|
* Note: this function is used to augment the Array type in angular expressions. See
|
|
|
|
|
* {@link angular.Array} for more info.
|
|
|
|
|
*
|
|
|
|
|
* @param {Array} array The array expand.
|
|
|
|
|
* @param {*=} [value={}] The value to be added.
|
|
|
|
|
* @returns {Array} The expanded array.
|
|
|
|
|
*
|
|
|
|
|
* @exampleDescription
|
|
|
|
|
* This example shows how an initially empty array can be filled with objects created from user
|
|
|
|
|
* input via the `$add` method.
|
|
|
|
|
*
|
|
|
|
|
* @example
|
|
|
|
|
[<a href="" ng:click="people.$add()">add empty</a>]
|
|
|
|
|
[<a href="" ng:click="people.$add({name:'John', sex:'male'})">add 'John'</a>]
|
|
|
|
|
[<a href="" ng:click="people.$add({name:'Mary', sex:'female'})">add 'Mary'</a>]
|
|
|
|
|
|
|
|
|
|
<ul ng:init="people=[]">
|
|
|
|
|
<li ng:repeat="person in people">
|
|
|
|
|
<input name="person.name">
|
|
|
|
|
<select name="person.sex">
|
|
|
|
|
<option value="">--chose one--</option>
|
|
|
|
|
<option>male</option>
|
|
|
|
|
<option>female</option>
|
|
|
|
|
</select>
|
|
|
|
|
[<a href="" ng:click="people.$remove(person)">X</a>]
|
|
|
|
|
</li>
|
|
|
|
|
</ul>
|
|
|
|
|
<pre>people = {{people}}</pre>
|
|
|
|
|
|
|
|
|
|
@scenario
|
|
|
|
|
beforeEach(function() {
|
|
|
|
|
expect(binding('people')).toBe('people = []');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('should create an empty record when "add empty" is clicked', function() {
|
|
|
|
|
element('.doc-example a:contains("add empty")').click();
|
|
|
|
|
expect(binding('people')).toBe('people = [{\n "name":"",\n "sex":null}]');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('should create a "John" record when "add \'John\'" is clicked', function() {
|
|
|
|
|
element('.doc-example a:contains("add \'John\'")').click();
|
|
|
|
|
expect(binding('people')).toBe('people = [{\n "name":"John",\n "sex":"male"}]');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('should create a "Mary" record when "add \'Mary\'" is clicked', function() {
|
|
|
|
|
element('.doc-example a:contains("add \'Mary\'")').click();
|
|
|
|
|
expect(binding('people')).toBe('people = [{\n "name":"Mary",\n "sex":"female"}]');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('should delete a record when "X" is clicked', function() {
|
|
|
|
|
element('.doc-example a:contains("add empty")').click();
|
|
|
|
|
element('.doc-example li a:contains("X"):first').click();
|
|
|
|
|
expect(binding('people')).toBe('people = []');
|
|
|
|
|
});
|
2010-11-22 18:26:47 +00:00
|
|
|
*/
|
2010-01-10 16:58:57 +00:00
|
|
|
'add':function(array, value) {
|
2010-03-30 03:25:42 +00:00
|
|
|
array.push(isUndefined(value)? {} : value);
|
2010-01-06 00:36:58 +00:00
|
|
|
return array;
|
|
|
|
|
},
|
2010-11-22 18:26:47 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @workInProgress
|
|
|
|
|
* @ngdoc function
|
|
|
|
|
* @name angular.Array.count
|
|
|
|
|
* @function
|
2010-11-23 22:10:10 +00:00
|
|
|
*
|
|
|
|
|
* @description
|
|
|
|
|
* Determines the number of elements in an array. Optionally it will count only those elements
|
|
|
|
|
* for which the `condition` evaluets to `true`.
|
|
|
|
|
*
|
|
|
|
|
* Note: this function is used to augment the Array type in angular expressions. See
|
|
|
|
|
* {@link angular.Array} for more info.
|
|
|
|
|
*
|
|
|
|
|
* @param {Array} array The array to count elements in.
|
|
|
|
|
* @param {(Function()|string)=} condition A function to be evaluated or angular expression to be
|
|
|
|
|
* compiled and evaluated. The element that is currently being iterated over, is exposed to
|
|
|
|
|
* the `condition` as `this`.
|
|
|
|
|
* @returns {number} Number of elements in the array (for which the condition evaluates to true).
|
|
|
|
|
*
|
|
|
|
|
* @example
|
|
|
|
|
<pre ng:init="items = [{name:'knife', points:1},
|
|
|
|
|
{name:'fork', points:3},
|
|
|
|
|
{name:'spoon', points:1}]"></pre>
|
|
|
|
|
<ul>
|
|
|
|
|
<li ng:repeat="item in items">
|
|
|
|
|
{{item.name}}: points=
|
|
|
|
|
<input type="text" name="item.points"/> <!-- id="item{{$index}} -->
|
|
|
|
|
</li>
|
|
|
|
|
</ul>
|
|
|
|
|
<p>Number of items which have one point: <em>{{ items.$count('points==1') }}</em></p>
|
|
|
|
|
<p>Number of items which have more than one point: <em>{{items.$count('points>1')}}</em></p>
|
|
|
|
|
|
|
|
|
|
@scenario
|
|
|
|
|
it('should calculate counts', function() {
|
|
|
|
|
expect(binding('items.$count(\'points==1\')')).toEqual(2);
|
|
|
|
|
expect(binding('items.$count(\'points>1\')')).toEqual(1);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('should recalculate when updated', function() {
|
|
|
|
|
using('.doc-example li:first-child').input('item.points').enter('23');
|
|
|
|
|
expect(binding('items.$count(\'points==1\')')).toEqual(1);
|
|
|
|
|
expect(binding('items.$count(\'points>1\')')).toEqual(2);
|
|
|
|
|
});
|
2010-11-22 18:26:47 +00:00
|
|
|
*/
|
2010-01-10 16:58:57 +00:00
|
|
|
'count':function(array, condition) {
|
2010-01-06 00:36:58 +00:00
|
|
|
if (!condition) return array.length;
|
2010-03-30 03:25:42 +00:00
|
|
|
var fn = angular['Function']['compile'](condition), count = 0;
|
|
|
|
|
foreach(array, function(value){
|
|
|
|
|
if (fn(value)) {
|
|
|
|
|
count ++;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
return count;
|
2010-01-06 00:36:58 +00:00
|
|
|
},
|
2010-11-22 18:26:47 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @workInProgress
|
|
|
|
|
* @ngdoc function
|
|
|
|
|
* @name angular.Array.orderBy
|
|
|
|
|
* @function
|
|
|
|
|
*/
|
2010-01-10 16:58:57 +00:00
|
|
|
'orderBy':function(array, expression, descend) {
|
2010-09-26 17:43:39 +00:00
|
|
|
expression = isArray(expression) ? expression: [expression];
|
|
|
|
|
expression = map(expression, function($){
|
|
|
|
|
var descending = false, get = $ || identity;
|
|
|
|
|
if (isString($)) {
|
|
|
|
|
if (($.charAt(0) == '+' || $.charAt(0) == '-')) {
|
|
|
|
|
descending = $.charAt(0) == '-';
|
|
|
|
|
$ = $.substring(1);
|
|
|
|
|
}
|
|
|
|
|
get = expressionCompile($).fnSelf;
|
|
|
|
|
}
|
|
|
|
|
return reverse(function(a,b){
|
|
|
|
|
return compare(get(a),get(b));
|
|
|
|
|
}, descending);
|
|
|
|
|
});
|
|
|
|
|
var arrayCopy = [];
|
|
|
|
|
for ( var i = 0; i < array.length; i++) { arrayCopy.push(array[i]); }
|
|
|
|
|
return arrayCopy.sort(reverse(comparator, descend));
|
|
|
|
|
|
|
|
|
|
function comparator(o1, o2){
|
|
|
|
|
for ( var i = 0; i < expression.length; i++) {
|
|
|
|
|
var comp = expression[i](o1, o2);
|
|
|
|
|
if (comp !== 0) return comp;
|
|
|
|
|
}
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
2010-01-06 00:36:58 +00:00
|
|
|
function reverse(comp, descending) {
|
2010-03-26 23:27:18 +00:00
|
|
|
return toBoolean(descending) ?
|
2010-01-06 00:36:58 +00:00
|
|
|
function(a,b){return comp(b,a);} : comp;
|
|
|
|
|
}
|
|
|
|
|
function compare(v1, v2){
|
|
|
|
|
var t1 = typeof v1;
|
|
|
|
|
var t2 = typeof v2;
|
|
|
|
|
if (t1 == t2) {
|
|
|
|
|
if (t1 == "string") v1 = v1.toLowerCase();
|
|
|
|
|
if (t1 == "string") v2 = v2.toLowerCase();
|
|
|
|
|
if (v1 === v2) return 0;
|
|
|
|
|
return v1 < v2 ? -1 : 1;
|
|
|
|
|
} else {
|
|
|
|
|
return t1 < t2 ? -1 : 1;
|
|
|
|
|
}
|
|
|
|
|
}
|
2010-11-22 18:23:45 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @workInProgress
|
|
|
|
|
* @ngdoc function
|
|
|
|
|
* @name angular.Array.limitTo
|
|
|
|
|
* @function
|
|
|
|
|
*
|
|
|
|
|
* @description
|
|
|
|
|
* Creates a new array containing only the first, or last `limit` number of elements of the
|
|
|
|
|
* source `array`.
|
|
|
|
|
*
|
|
|
|
|
* @param {Array} array Source array to be limited.
|
|
|
|
|
* @param {string|Number} limit The length of the returned array. If the number is positive, the
|
|
|
|
|
* first `limit` items from the source array will be copied, if the number is negative, the
|
|
|
|
|
* last `limit` items will be copied.
|
|
|
|
|
* @returns {Array} New array of length `limit`.
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
limitTo: function(array, limit) {
|
|
|
|
|
limit = parseInt(limit, 10);
|
|
|
|
|
var out = [],
|
|
|
|
|
i, n;
|
|
|
|
|
|
|
|
|
|
if (limit > 0) {
|
|
|
|
|
i = 0;
|
|
|
|
|
n = limit;
|
|
|
|
|
} else {
|
|
|
|
|
i = array.length + limit;
|
|
|
|
|
n = array.length;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (; i<n; i++) {
|
|
|
|
|
out.push(array[i]);
|
|
|
|
|
}
|
2010-09-26 17:43:39 +00:00
|
|
|
|
2010-11-22 18:23:45 +00:00
|
|
|
return out;
|
2010-01-06 00:36:58 +00:00
|
|
|
}
|
|
|
|
|
};
|
2010-01-12 00:15:12 +00:00
|
|
|
|
2010-11-08 18:51:28 +00:00
|
|
|
var R_ISO8061_STR = /^(\d{4})-(\d\d)-(\d\d)(?:T(\d\d)(?:\:(\d\d)(?:\:(\d\d)(?:\.(\d{3}))?)?)?Z)?$/
|
|
|
|
|
|
2010-01-12 00:15:12 +00:00
|
|
|
var angularString = {
|
2010-01-10 16:58:57 +00:00
|
|
|
'quote':function(string) {
|
2010-01-06 00:36:58 +00:00
|
|
|
return '"' + string.replace(/\\/g, '\\\\').
|
|
|
|
|
replace(/"/g, '\\"').
|
|
|
|
|
replace(/\n/g, '\\n').
|
|
|
|
|
replace(/\f/g, '\\f').
|
|
|
|
|
replace(/\r/g, '\\r').
|
|
|
|
|
replace(/\t/g, '\\t').
|
|
|
|
|
replace(/\v/g, '\\v') +
|
|
|
|
|
'"';
|
|
|
|
|
},
|
2010-01-10 16:58:57 +00:00
|
|
|
'quoteUnicode':function(string) {
|
|
|
|
|
var str = angular['String']['quote'](string);
|
2010-01-06 00:36:58 +00:00
|
|
|
var chars = [];
|
|
|
|
|
for ( var i = 0; i < str.length; i++) {
|
|
|
|
|
var ch = str.charCodeAt(i);
|
|
|
|
|
if (ch < 128) {
|
|
|
|
|
chars.push(str.charAt(i));
|
|
|
|
|
} else {
|
|
|
|
|
var encode = "000" + ch.toString(16);
|
|
|
|
|
chars.push("\\u" + encode.substring(encode.length - 4));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return chars.join('');
|
|
|
|
|
},
|
2010-10-26 05:17:51 +00:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Tries to convert input to date and if successful returns the date, otherwise returns the input.
|
|
|
|
|
* @param {string} string
|
|
|
|
|
* @return {(Date|string)}
|
|
|
|
|
*/
|
2010-01-10 16:58:57 +00:00
|
|
|
'toDate':function(string){
|
2010-10-26 21:25:01 +00:00
|
|
|
var match;
|
2010-11-08 18:51:28 +00:00
|
|
|
if (isString(string) && (match = string.match(R_ISO8061_STR))){
|
2010-10-26 21:25:01 +00:00
|
|
|
var date = new Date(0);
|
|
|
|
|
date.setUTCFullYear(match[1], match[2] - 1, match[3]);
|
2010-11-08 18:51:28 +00:00
|
|
|
date.setUTCHours(match[4]||0, match[5]||0, match[6]||0, match[7]||0);
|
2010-10-26 21:25:01 +00:00
|
|
|
return date;
|
|
|
|
|
}
|
|
|
|
|
return string;
|
2010-01-06 00:36:58 +00:00
|
|
|
}
|
|
|
|
|
};
|
2010-01-12 00:15:12 +00:00
|
|
|
|
|
|
|
|
var angularDate = {
|
2010-01-10 16:58:57 +00:00
|
|
|
'toString':function(date){
|
2010-11-08 17:52:09 +00:00
|
|
|
return !date ?
|
|
|
|
|
date :
|
|
|
|
|
date.toISOString ?
|
|
|
|
|
date.toISOString() :
|
|
|
|
|
padNumber(date.getUTCFullYear(), 4) + '-' +
|
|
|
|
|
padNumber(date.getUTCMonth() + 1, 2) + '-' +
|
|
|
|
|
padNumber(date.getUTCDate(), 2) + 'T' +
|
|
|
|
|
padNumber(date.getUTCHours(), 2) + ':' +
|
|
|
|
|
padNumber(date.getUTCMinutes(), 2) + ':' +
|
|
|
|
|
padNumber(date.getUTCSeconds(), 2) + '.' +
|
|
|
|
|
padNumber(date.getUTCMilliseconds(), 3) + 'Z';
|
2010-01-06 00:36:58 +00:00
|
|
|
}
|
|
|
|
|
};
|
2010-01-12 00:15:12 +00:00
|
|
|
|
|
|
|
|
var angularFunction = {
|
2010-01-10 16:58:57 +00:00
|
|
|
'compile':function(expression) {
|
2010-03-30 03:25:42 +00:00
|
|
|
if (isFunction(expression)){
|
2010-01-06 00:36:58 +00:00
|
|
|
return expression;
|
|
|
|
|
} else if (expression){
|
2010-05-30 23:45:35 +00:00
|
|
|
return expressionCompile(expression).fnSelf;
|
2010-01-06 00:36:58 +00:00
|
|
|
} else {
|
2010-03-30 03:25:42 +00:00
|
|
|
return identity;
|
2010-01-06 00:36:58 +00:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
2010-08-18 23:23:12 +00:00
|
|
|
function defineApi(dst, chain){
|
2010-01-12 00:15:12 +00:00
|
|
|
angular[dst] = angular[dst] || {};
|
|
|
|
|
foreach(chain, function(parent){
|
|
|
|
|
extend(angular[dst], parent);
|
|
|
|
|
});
|
|
|
|
|
}
|
2010-08-18 23:23:12 +00:00
|
|
|
defineApi('Global', [angularGlobal]);
|
|
|
|
|
defineApi('Collection', [angularGlobal, angularCollection]);
|
|
|
|
|
defineApi('Array', [angularGlobal, angularCollection, angularArray]);
|
|
|
|
|
defineApi('Object', [angularGlobal, angularCollection, angularObject]);
|
|
|
|
|
defineApi('String', [angularGlobal, angularString]);
|
|
|
|
|
defineApi('Date', [angularGlobal, angularDate]);
|
2010-01-26 07:49:52 +00:00
|
|
|
//IE bug
|
|
|
|
|
angular['Date']['toString'] = angularDate['toString'];
|
2010-08-18 23:23:12 +00:00
|
|
|
defineApi('Function', [angularGlobal, angularCollection, angularFunction]);
|