rails-angularjs 1.3.14 → 1.3.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/README.md +2 -2
- data/lib/rails-angularjs/version.rb +2 -2
- data/vendor/assets/javascripts/angular-animate.js +1 -1
- data/vendor/assets/javascripts/angular-animate.min.js +1 -1
- data/vendor/assets/javascripts/angular-animate.min.js.map +8 -0
- data/vendor/assets/javascripts/angular-aria.js +19 -4
- data/vendor/assets/javascripts/angular-aria.min.js +8 -7
- data/vendor/assets/javascripts/angular-aria.min.js.map +8 -0
- data/vendor/assets/javascripts/angular-cookies.js +1 -1
- data/vendor/assets/javascripts/angular-cookies.min.js +1 -1
- data/vendor/assets/javascripts/angular-cookies.min.js.map +8 -0
- data/vendor/assets/javascripts/angular-loader.js +2 -2
- data/vendor/assets/javascripts/angular-loader.min.js +2 -2
- data/vendor/assets/javascripts/angular-loader.min.js.map +8 -0
- data/vendor/assets/javascripts/angular-messages.js +4 -3
- data/vendor/assets/javascripts/angular-messages.min.js +1 -1
- data/vendor/assets/javascripts/angular-messages.min.js.map +8 -0
- data/vendor/assets/javascripts/angular-mocks.js +73 -1
- data/vendor/assets/javascripts/angular-resource.js +1 -1
- data/vendor/assets/javascripts/angular-resource.min.js +1 -1
- data/vendor/assets/javascripts/angular-resource.min.js.map +8 -0
- data/vendor/assets/javascripts/angular-route.js +1 -1
- data/vendor/assets/javascripts/angular-route.min.js +1 -1
- data/vendor/assets/javascripts/angular-route.min.js.map +8 -0
- data/vendor/assets/javascripts/angular-sanitize.js +12 -1
- data/vendor/assets/javascripts/angular-sanitize.min.js +1 -1
- data/vendor/assets/javascripts/angular-sanitize.min.js.map +8 -0
- data/vendor/assets/javascripts/angular-scenario.js +177 -49
- data/vendor/assets/javascripts/angular-touch.js +1 -1
- data/vendor/assets/javascripts/angular-touch.min.js +1 -1
- data/vendor/assets/javascripts/angular-touch.min.js.map +8 -0
- data/vendor/assets/javascripts/angular.js +177 -49
- data/vendor/assets/javascripts/angular.min.js +242 -241
- data/vendor/assets/javascripts/angular.min.js.map +8 -0
- data/vendor/assets/javascripts/unstable/angular-animate.js +1 -1
- data/vendor/assets/javascripts/unstable/angular-animate.min.js +1 -1
- data/vendor/assets/javascripts/unstable/angular-animate.min.js.map +8 -0
- data/vendor/assets/javascripts/unstable/angular-aria.js +19 -4
- data/vendor/assets/javascripts/unstable/angular-aria.min.js +8 -7
- data/vendor/assets/javascripts/unstable/angular-aria.min.js.map +8 -0
- data/vendor/assets/javascripts/unstable/angular-cookies.js +254 -140
- data/vendor/assets/javascripts/unstable/angular-cookies.min.js +4 -3
- data/vendor/assets/javascripts/unstable/angular-cookies.min.js.map +8 -0
- data/vendor/assets/javascripts/unstable/angular-loader.js +2 -2
- data/vendor/assets/javascripts/unstable/angular-loader.min.js +2 -2
- data/vendor/assets/javascripts/unstable/angular-loader.min.js.map +8 -0
- data/vendor/assets/javascripts/unstable/angular-messages.js +47 -24
- data/vendor/assets/javascripts/unstable/angular-messages.min.js +6 -7
- data/vendor/assets/javascripts/unstable/angular-messages.min.js.map +8 -0
- data/vendor/assets/javascripts/unstable/angular-mocks.js +80 -30
- data/vendor/assets/javascripts/unstable/angular-resource.js +1 -1
- data/vendor/assets/javascripts/unstable/angular-resource.min.js +1 -1
- data/vendor/assets/javascripts/unstable/angular-resource.min.js.map +8 -0
- data/vendor/assets/javascripts/unstable/angular-route.js +1 -1
- data/vendor/assets/javascripts/unstable/angular-route.min.js +1 -1
- data/vendor/assets/javascripts/unstable/angular-route.min.js.map +8 -0
- data/vendor/assets/javascripts/unstable/angular-sanitize.js +31 -20
- data/vendor/assets/javascripts/unstable/angular-sanitize.min.js +3 -3
- data/vendor/assets/javascripts/unstable/angular-sanitize.min.js.map +8 -0
- data/vendor/assets/javascripts/unstable/angular-scenario.js +378 -230
- data/vendor/assets/javascripts/unstable/angular-touch.js +1 -1
- data/vendor/assets/javascripts/unstable/angular-touch.min.js +1 -1
- data/vendor/assets/javascripts/unstable/angular-touch.min.js.map +8 -0
- data/vendor/assets/javascripts/unstable/angular.js +377 -229
- data/vendor/assets/javascripts/unstable/angular.min.js +278 -277
- data/vendor/assets/javascripts/unstable/angular.min.js.map +8 -0
- metadata +25 -5
@@ -1,5 +1,5 @@
|
|
1
1
|
/**
|
2
|
-
* @license AngularJS v1.4.0-beta.
|
2
|
+
* @license AngularJS v1.4.0-beta.6
|
3
3
|
* (c) 2010-2015 Google, Inc. http://angularjs.org
|
4
4
|
* License: MIT
|
5
5
|
*/
|
@@ -57,7 +57,7 @@ function minErr(module, ErrorConstructor) {
|
|
57
57
|
return match;
|
58
58
|
});
|
59
59
|
|
60
|
-
message += '\nhttp://errors.angularjs.org/1.4.0-beta.
|
60
|
+
message += '\nhttp://errors.angularjs.org/1.4.0-beta.6/' +
|
61
61
|
(module ? module + '/' : '') + code;
|
62
62
|
|
63
63
|
for (i = SKIP_INDEXES, paramPrefix = '?'; i < templateArgs.length; i++, paramPrefix = '&') {
|
@@ -98,6 +98,7 @@ function minErr(module, ErrorConstructor) {
|
|
98
98
|
extend: true,
|
99
99
|
toInt: true,
|
100
100
|
inherit: true,
|
101
|
+
merge: true,
|
101
102
|
noop: true,
|
102
103
|
identity: true,
|
103
104
|
valueFn: true,
|
@@ -134,6 +135,8 @@ function minErr(module, ErrorConstructor) {
|
|
134
135
|
toJsonReplacer: true,
|
135
136
|
toJson: true,
|
136
137
|
fromJson: true,
|
138
|
+
convertTimezoneToLocal: true,
|
139
|
+
timezoneToOffset: true,
|
137
140
|
startingTag: true,
|
138
141
|
tryDecodeURIComponent: true,
|
139
142
|
parseKeyValue: true,
|
@@ -154,6 +157,7 @@ function minErr(module, ErrorConstructor) {
|
|
154
157
|
createMap: true,
|
155
158
|
|
156
159
|
NODE_TYPE_ELEMENT: true,
|
160
|
+
NODE_TYPE_ATTRIBUTE: true,
|
157
161
|
NODE_TYPE_TEXT: true,
|
158
162
|
NODE_TYPE_COMMENT: true,
|
159
163
|
NODE_TYPE_DOCUMENT: true,
|
@@ -387,6 +391,31 @@ function setHashKey(obj, h) {
|
|
387
391
|
}
|
388
392
|
}
|
389
393
|
|
394
|
+
|
395
|
+
function baseExtend(dst, objs, deep) {
|
396
|
+
var h = dst.$$hashKey;
|
397
|
+
|
398
|
+
for (var i = 0, ii = objs.length; i < ii; ++i) {
|
399
|
+
var obj = objs[i];
|
400
|
+
if (!isObject(obj) && !isFunction(obj)) continue;
|
401
|
+
var keys = Object.keys(obj);
|
402
|
+
for (var j = 0, jj = keys.length; j < jj; j++) {
|
403
|
+
var key = keys[j];
|
404
|
+
var src = obj[key];
|
405
|
+
|
406
|
+
if (deep && isObject(src)) {
|
407
|
+
if (!isObject(dst[key])) dst[key] = isArray(src) ? [] : {};
|
408
|
+
baseExtend(dst[key], [src], true);
|
409
|
+
} else {
|
410
|
+
dst[key] = src;
|
411
|
+
}
|
412
|
+
}
|
413
|
+
}
|
414
|
+
|
415
|
+
setHashKey(dst, h);
|
416
|
+
return dst;
|
417
|
+
}
|
418
|
+
|
390
419
|
/**
|
391
420
|
* @ngdoc function
|
392
421
|
* @name angular.extend
|
@@ -397,30 +426,43 @@ function setHashKey(obj, h) {
|
|
397
426
|
* Extends the destination object `dst` by copying own enumerable properties from the `src` object(s)
|
398
427
|
* to `dst`. You can specify multiple `src` objects. If you want to preserve original objects, you can do so
|
399
428
|
* by passing an empty object as the target: `var object = angular.extend({}, object1, object2)`.
|
400
|
-
*
|
429
|
+
*
|
430
|
+
* **Note:** Keep in mind that `angular.extend` does not support recursive merge (deep copy). Use
|
431
|
+
* {@link angular.merge} for this.
|
401
432
|
*
|
402
433
|
* @param {Object} dst Destination object.
|
403
434
|
* @param {...Object} src Source object(s).
|
404
435
|
* @returns {Object} Reference to `dst`.
|
405
436
|
*/
|
406
437
|
function extend(dst) {
|
407
|
-
|
438
|
+
return baseExtend(dst, slice.call(arguments, 1), false);
|
439
|
+
}
|
408
440
|
|
409
|
-
for (var i = 1, ii = arguments.length; i < ii; i++) {
|
410
|
-
var obj = arguments[i];
|
411
|
-
if (obj) {
|
412
|
-
var keys = Object.keys(obj);
|
413
|
-
for (var j = 0, jj = keys.length; j < jj; j++) {
|
414
|
-
var key = keys[j];
|
415
|
-
dst[key] = obj[key];
|
416
|
-
}
|
417
|
-
}
|
418
|
-
}
|
419
441
|
|
420
|
-
|
421
|
-
|
442
|
+
/**
|
443
|
+
* @ngdoc function
|
444
|
+
* @name angular.merge
|
445
|
+
* @module ng
|
446
|
+
* @kind function
|
447
|
+
*
|
448
|
+
* @description
|
449
|
+
* Deeply extends the destination object `dst` by copying own enumerable properties from the `src` object(s)
|
450
|
+
* to `dst`. You can specify multiple `src` objects. If you want to preserve original objects, you can do so
|
451
|
+
* by passing an empty object as the target: `var object = angular.merge({}, object1, object2)`.
|
452
|
+
*
|
453
|
+
* Unlike {@link angular.extend extend()}, `merge()` recursively descends into object properties of source
|
454
|
+
* objects, performing a deep copy.
|
455
|
+
*
|
456
|
+
* @param {Object} dst Destination object.
|
457
|
+
* @param {...Object} src Source object(s).
|
458
|
+
* @returns {Object} Reference to `dst`.
|
459
|
+
*/
|
460
|
+
function merge(dst) {
|
461
|
+
return baseExtend(dst, slice.call(arguments, 1), true);
|
422
462
|
}
|
423
463
|
|
464
|
+
|
465
|
+
|
424
466
|
function toInt(str) {
|
425
467
|
return parseInt(str, 10);
|
426
468
|
}
|
@@ -547,6 +589,12 @@ function isString(value) {return typeof value === 'string';}
|
|
547
589
|
* @description
|
548
590
|
* Determines if a reference is a `Number`.
|
549
591
|
*
|
592
|
+
* This includes the "special" numbers `NaN`, `+Infinity` and `-Infinity`.
|
593
|
+
*
|
594
|
+
* If you wish to exclude these then you can use the native
|
595
|
+
* [`isFinite'](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/isFinite)
|
596
|
+
* method.
|
597
|
+
*
|
550
598
|
* @param {*} value Reference to check.
|
551
599
|
* @returns {boolean} True if `value` is a `Number`.
|
552
600
|
*/
|
@@ -929,10 +977,11 @@ function equals(o1, o2) {
|
|
929
977
|
} else if (isDate(o1)) {
|
930
978
|
if (!isDate(o2)) return false;
|
931
979
|
return equals(o1.getTime(), o2.getTime());
|
932
|
-
} else if (isRegExp(o1)
|
933
|
-
return o1.toString() == o2.toString();
|
980
|
+
} else if (isRegExp(o1)) {
|
981
|
+
return isRegExp(o2) ? o1.toString() == o2.toString() : false;
|
934
982
|
} else {
|
935
|
-
if (isScope(o1) || isScope(o2) || isWindow(o1) || isWindow(o2) ||
|
983
|
+
if (isScope(o1) || isScope(o2) || isWindow(o1) || isWindow(o2) ||
|
984
|
+
isArray(o2) || isDate(o2) || isRegExp(o2)) return false;
|
936
985
|
keySet = {};
|
937
986
|
for (key in o1) {
|
938
987
|
if (key.charAt(0) === '$' || isFunction(o1[key])) continue;
|
@@ -1012,18 +1061,15 @@ var csp = function() {
|
|
1012
1061
|
var jq = function() {
|
1013
1062
|
if (isDefined(jq.name_)) return jq.name_;
|
1014
1063
|
var el;
|
1015
|
-
var i, ii = ngAttrPrefixes.length;
|
1064
|
+
var i, ii = ngAttrPrefixes.length, prefix, name;
|
1016
1065
|
for (i = 0; i < ii; ++i) {
|
1017
|
-
|
1066
|
+
prefix = ngAttrPrefixes[i];
|
1067
|
+
if (el = document.querySelector('[' + prefix.replace(':', '\\:') + 'jq]')) {
|
1068
|
+
name = el.getAttribute(prefix + 'jq');
|
1018
1069
|
break;
|
1019
1070
|
}
|
1020
1071
|
}
|
1021
1072
|
|
1022
|
-
var name;
|
1023
|
-
if (el) {
|
1024
|
-
name = getNgAttribute(el, "jq");
|
1025
|
-
}
|
1026
|
-
|
1027
1073
|
return (jq.name_ = name);
|
1028
1074
|
};
|
1029
1075
|
|
@@ -1136,6 +1182,26 @@ function fromJson(json) {
|
|
1136
1182
|
}
|
1137
1183
|
|
1138
1184
|
|
1185
|
+
function timezoneToOffset(timezone, fallback) {
|
1186
|
+
var requestedTimezoneOffset = Date.parse('Jan 01, 1970 00:00:00 ' + timezone) / 60000;
|
1187
|
+
return isNaN(requestedTimezoneOffset) ? fallback : requestedTimezoneOffset;
|
1188
|
+
}
|
1189
|
+
|
1190
|
+
|
1191
|
+
function addDateMinutes(date, minutes) {
|
1192
|
+
date = new Date(date.getTime());
|
1193
|
+
date.setMinutes(date.getMinutes() + minutes);
|
1194
|
+
return date;
|
1195
|
+
}
|
1196
|
+
|
1197
|
+
|
1198
|
+
function convertTimezoneToLocal(date, timezone, reverse) {
|
1199
|
+
reverse = reverse ? -1 : 1;
|
1200
|
+
var timezoneOffset = timezoneToOffset(timezone, date.getTimezoneOffset());
|
1201
|
+
return addDateMinutes(date, reverse * (timezoneOffset - date.getTimezoneOffset()));
|
1202
|
+
}
|
1203
|
+
|
1204
|
+
|
1139
1205
|
/**
|
1140
1206
|
* @returns {string} Returns the string representation of the element.
|
1141
1207
|
*/
|
@@ -1264,10 +1330,9 @@ var ngAttrPrefixes = ['ng-', 'data-ng-', 'ng:', 'x-ng-'];
|
|
1264
1330
|
|
1265
1331
|
function getNgAttribute(element, ngAttr) {
|
1266
1332
|
var attr, i, ii = ngAttrPrefixes.length;
|
1267
|
-
element = jqLite(element);
|
1268
1333
|
for (i = 0; i < ii; ++i) {
|
1269
1334
|
attr = ngAttrPrefixes[i] + ngAttr;
|
1270
|
-
if (isString(attr = element.
|
1335
|
+
if (isString(attr = element.getAttribute(attr))) {
|
1271
1336
|
return attr;
|
1272
1337
|
}
|
1273
1338
|
}
|
@@ -1742,6 +1807,7 @@ function createMap() {
|
|
1742
1807
|
}
|
1743
1808
|
|
1744
1809
|
var NODE_TYPE_ELEMENT = 1;
|
1810
|
+
var NODE_TYPE_ATTRIBUTE = 2;
|
1745
1811
|
var NODE_TYPE_TEXT = 3;
|
1746
1812
|
var NODE_TYPE_COMMENT = 8;
|
1747
1813
|
var NODE_TYPE_DOCUMENT = 9;
|
@@ -2157,6 +2223,7 @@ function toDebugString(obj) {
|
|
2157
2223
|
$FilterProvider,
|
2158
2224
|
$InterpolateProvider,
|
2159
2225
|
$IntervalProvider,
|
2226
|
+
$$HashMapProvider,
|
2160
2227
|
$HttpProvider,
|
2161
2228
|
$HttpBackendProvider,
|
2162
2229
|
$LocationProvider,
|
@@ -2176,7 +2243,8 @@ function toDebugString(obj) {
|
|
2176
2243
|
$$RAFProvider,
|
2177
2244
|
$$AsyncCallbackProvider,
|
2178
2245
|
$WindowProvider,
|
2179
|
-
$$jqLiteProvider
|
2246
|
+
$$jqLiteProvider,
|
2247
|
+
$$CookieReaderProvider
|
2180
2248
|
*/
|
2181
2249
|
|
2182
2250
|
|
@@ -2195,11 +2263,11 @@ function toDebugString(obj) {
|
|
2195
2263
|
* - `codeName` – `{string}` – Code name of the release, such as "jiggling-armfat".
|
2196
2264
|
*/
|
2197
2265
|
var version = {
|
2198
|
-
full: '1.4.0-beta.
|
2266
|
+
full: '1.4.0-beta.6', // all of these placeholder strings will be replaced by grunt's
|
2199
2267
|
major: 1, // package task
|
2200
2268
|
minor: 4,
|
2201
2269
|
dot: 0,
|
2202
|
-
codeName: '
|
2270
|
+
codeName: 'cookie-liberation'
|
2203
2271
|
};
|
2204
2272
|
|
2205
2273
|
|
@@ -2208,6 +2276,7 @@ function publishExternalAPI(angular) {
|
|
2208
2276
|
'bootstrap': bootstrap,
|
2209
2277
|
'copy': copy,
|
2210
2278
|
'extend': extend,
|
2279
|
+
'merge': merge,
|
2211
2280
|
'equals': equals,
|
2212
2281
|
'element': jqLite,
|
2213
2282
|
'forEach': forEach,
|
@@ -2330,12 +2399,25 @@ function publishExternalAPI(angular) {
|
|
2330
2399
|
$window: $WindowProvider,
|
2331
2400
|
$$rAF: $$RAFProvider,
|
2332
2401
|
$$asyncCallback: $$AsyncCallbackProvider,
|
2333
|
-
$$jqLite: $$jqLiteProvider
|
2402
|
+
$$jqLite: $$jqLiteProvider,
|
2403
|
+
$$HashMap: $$HashMapProvider,
|
2404
|
+
$$cookieReader: $$CookieReaderProvider
|
2334
2405
|
});
|
2335
2406
|
}
|
2336
2407
|
]);
|
2337
2408
|
}
|
2338
2409
|
|
2410
|
+
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
2411
|
+
* Any commits to this file should be reviewed with security in mind. *
|
2412
|
+
* Changes to this file can potentially create security vulnerabilities. *
|
2413
|
+
* An approval from 2 Core members with history of modifying *
|
2414
|
+
* this file is required. *
|
2415
|
+
* *
|
2416
|
+
* Does the change somehow allow for arbitrary javascript to be executed? *
|
2417
|
+
* Or allows for someone to change the prototype of built-in objects? *
|
2418
|
+
* Or gives undesired access to variables likes document or window? *
|
2419
|
+
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
2420
|
+
|
2339
2421
|
/* global JQLitePrototype: true,
|
2340
2422
|
addEventListenerFn: true,
|
2341
2423
|
removeEventListenerFn: true,
|
@@ -2923,6 +3005,10 @@ forEach({
|
|
2923
3005
|
},
|
2924
3006
|
|
2925
3007
|
attr: function(element, name, value) {
|
3008
|
+
var nodeType = element.nodeType;
|
3009
|
+
if (nodeType === NODE_TYPE_TEXT || nodeType === NODE_TYPE_ATTRIBUTE || nodeType === NODE_TYPE_COMMENT) {
|
3010
|
+
return;
|
3011
|
+
}
|
2926
3012
|
var lowercasedName = lowercase(name);
|
2927
3013
|
if (BOOLEAN_ATTR[lowercasedName]) {
|
2928
3014
|
if (isDefined(value)) {
|
@@ -3435,6 +3521,12 @@ HashMap.prototype = {
|
|
3435
3521
|
}
|
3436
3522
|
};
|
3437
3523
|
|
3524
|
+
var $$HashMapProvider = [function() {
|
3525
|
+
this.$get = [function() {
|
3526
|
+
return HashMap;
|
3527
|
+
}];
|
3528
|
+
}];
|
3529
|
+
|
3438
3530
|
/**
|
3439
3531
|
* @ngdoc function
|
3440
3532
|
* @module ng
|
@@ -4760,6 +4852,7 @@ var $AnimateProvider = ['$provide', function($provide) {
|
|
4760
4852
|
* @return {Promise} the animation callback promise
|
4761
4853
|
*/
|
4762
4854
|
leave: function(element, options) {
|
4855
|
+
applyStyles(element, options);
|
4763
4856
|
element.remove();
|
4764
4857
|
return asyncPromise();
|
4765
4858
|
},
|
@@ -5004,11 +5097,6 @@ function Browser(window, document, $log, $sniffer) {
|
|
5004
5097
|
* @param {function()} callback Function that will be called when no outstanding request
|
5005
5098
|
*/
|
5006
5099
|
self.notifyWhenNoOutstandingRequests = function(callback) {
|
5007
|
-
// force browser to execute all pollFns - this is needed so that cookies and other pollers fire
|
5008
|
-
// at some deterministic time in respect to the test runner's actions. Leaving things up to the
|
5009
|
-
// regular poller would result in flaky tests.
|
5010
|
-
forEach(pollFns, function(pollFn) { pollFn(); });
|
5011
|
-
|
5012
5100
|
if (outstandingRequestCount === 0) {
|
5013
5101
|
callback();
|
5014
5102
|
} else {
|
@@ -5016,44 +5104,6 @@ function Browser(window, document, $log, $sniffer) {
|
|
5016
5104
|
}
|
5017
5105
|
};
|
5018
5106
|
|
5019
|
-
//////////////////////////////////////////////////////////////
|
5020
|
-
// Poll Watcher API
|
5021
|
-
//////////////////////////////////////////////////////////////
|
5022
|
-
var pollFns = [],
|
5023
|
-
pollTimeout;
|
5024
|
-
|
5025
|
-
/**
|
5026
|
-
* @name $browser#addPollFn
|
5027
|
-
*
|
5028
|
-
* @param {function()} fn Poll function to add
|
5029
|
-
*
|
5030
|
-
* @description
|
5031
|
-
* Adds a function to the list of functions that poller periodically executes,
|
5032
|
-
* and starts polling if not started yet.
|
5033
|
-
*
|
5034
|
-
* @returns {function()} the added function
|
5035
|
-
*/
|
5036
|
-
self.addPollFn = function(fn) {
|
5037
|
-
if (isUndefined(pollTimeout)) startPoller(100, setTimeout);
|
5038
|
-
pollFns.push(fn);
|
5039
|
-
return fn;
|
5040
|
-
};
|
5041
|
-
|
5042
|
-
/**
|
5043
|
-
* @param {number} interval How often should browser call poll functions (ms)
|
5044
|
-
* @param {function()} setTimeout Reference to a real or fake `setTimeout` function.
|
5045
|
-
*
|
5046
|
-
* @description
|
5047
|
-
* Configures the poller to run in the specified intervals, using the specified
|
5048
|
-
* setTimeout fn and kicks it off.
|
5049
|
-
*/
|
5050
|
-
function startPoller(interval, setTimeout) {
|
5051
|
-
(function check() {
|
5052
|
-
forEach(pollFns, function(pollFn) { pollFn(); });
|
5053
|
-
pollTimeout = setTimeout(check, interval);
|
5054
|
-
})();
|
5055
|
-
}
|
5056
|
-
|
5057
5107
|
//////////////////////////////////////////////////////////////
|
5058
5108
|
// URL API
|
5059
5109
|
//////////////////////////////////////////////////////////////
|
@@ -5164,11 +5214,19 @@ function Browser(window, document, $log, $sniffer) {
|
|
5164
5214
|
fireUrlChange();
|
5165
5215
|
}
|
5166
5216
|
|
5217
|
+
function getCurrentState() {
|
5218
|
+
try {
|
5219
|
+
return history.state;
|
5220
|
+
} catch (e) {
|
5221
|
+
// MSIE can reportedly throw when there is no state (UNCONFIRMED).
|
5222
|
+
}
|
5223
|
+
}
|
5224
|
+
|
5167
5225
|
// This variable should be used *only* inside the cacheState function.
|
5168
5226
|
var lastCachedState = null;
|
5169
5227
|
function cacheState() {
|
5170
5228
|
// This should be the only place in $browser where `history.state` is read.
|
5171
|
-
cachedState =
|
5229
|
+
cachedState = getCurrentState();
|
5172
5230
|
cachedState = isUndefined(cachedState) ? null : cachedState;
|
5173
5231
|
|
5174
5232
|
// Prevent callbacks fo fire twice if both hashchange & popstate were fired.
|
@@ -5255,89 +5313,6 @@ function Browser(window, document, $log, $sniffer) {
|
|
5255
5313
|
return href ? href.replace(/^(https?\:)?\/\/[^\/]*/, '') : '';
|
5256
5314
|
};
|
5257
5315
|
|
5258
|
-
//////////////////////////////////////////////////////////////
|
5259
|
-
// Cookies API
|
5260
|
-
//////////////////////////////////////////////////////////////
|
5261
|
-
var lastCookies = {};
|
5262
|
-
var lastCookieString = '';
|
5263
|
-
var cookiePath = self.baseHref();
|
5264
|
-
|
5265
|
-
function safeDecodeURIComponent(str) {
|
5266
|
-
try {
|
5267
|
-
return decodeURIComponent(str);
|
5268
|
-
} catch (e) {
|
5269
|
-
return str;
|
5270
|
-
}
|
5271
|
-
}
|
5272
|
-
|
5273
|
-
/**
|
5274
|
-
* @name $browser#cookies
|
5275
|
-
*
|
5276
|
-
* @param {string=} name Cookie name
|
5277
|
-
* @param {string=} value Cookie value
|
5278
|
-
*
|
5279
|
-
* @description
|
5280
|
-
* The cookies method provides a 'private' low level access to browser cookies.
|
5281
|
-
* It is not meant to be used directly, use the $cookie service instead.
|
5282
|
-
*
|
5283
|
-
* The return values vary depending on the arguments that the method was called with as follows:
|
5284
|
-
*
|
5285
|
-
* - cookies() -> hash of all cookies, this is NOT a copy of the internal state, so do not modify
|
5286
|
-
* it
|
5287
|
-
* - cookies(name, value) -> set name to value, if value is undefined delete the cookie
|
5288
|
-
* - cookies(name) -> the same as (name, undefined) == DELETES (no one calls it right now that
|
5289
|
-
* way)
|
5290
|
-
*
|
5291
|
-
* @returns {Object} Hash of all cookies (if called without any parameter)
|
5292
|
-
*/
|
5293
|
-
self.cookies = function(name, value) {
|
5294
|
-
var cookieLength, cookieArray, cookie, i, index;
|
5295
|
-
|
5296
|
-
if (name) {
|
5297
|
-
if (value === undefined) {
|
5298
|
-
rawDocument.cookie = encodeURIComponent(name) + "=;path=" + cookiePath +
|
5299
|
-
";expires=Thu, 01 Jan 1970 00:00:00 GMT";
|
5300
|
-
} else {
|
5301
|
-
if (isString(value)) {
|
5302
|
-
cookieLength = (rawDocument.cookie = encodeURIComponent(name) + '=' + encodeURIComponent(value) +
|
5303
|
-
';path=' + cookiePath).length + 1;
|
5304
|
-
|
5305
|
-
// per http://www.ietf.org/rfc/rfc2109.txt browser must allow at minimum:
|
5306
|
-
// - 300 cookies
|
5307
|
-
// - 20 cookies per unique domain
|
5308
|
-
// - 4096 bytes per cookie
|
5309
|
-
if (cookieLength > 4096) {
|
5310
|
-
$log.warn("Cookie '" + name +
|
5311
|
-
"' possibly not set or overflowed because it was too large (" +
|
5312
|
-
cookieLength + " > 4096 bytes)!");
|
5313
|
-
}
|
5314
|
-
}
|
5315
|
-
}
|
5316
|
-
} else {
|
5317
|
-
if (rawDocument.cookie !== lastCookieString) {
|
5318
|
-
lastCookieString = rawDocument.cookie;
|
5319
|
-
cookieArray = lastCookieString.split("; ");
|
5320
|
-
lastCookies = {};
|
5321
|
-
|
5322
|
-
for (i = 0; i < cookieArray.length; i++) {
|
5323
|
-
cookie = cookieArray[i];
|
5324
|
-
index = cookie.indexOf('=');
|
5325
|
-
if (index > 0) { //ignore nameless cookies
|
5326
|
-
name = safeDecodeURIComponent(cookie.substring(0, index));
|
5327
|
-
// the first value that is seen for a cookie is the most
|
5328
|
-
// specific one. values for the same cookie name that
|
5329
|
-
// follow are for less specific paths.
|
5330
|
-
if (lastCookies[name] === undefined) {
|
5331
|
-
lastCookies[name] = safeDecodeURIComponent(cookie.substring(index + 1));
|
5332
|
-
}
|
5333
|
-
}
|
5334
|
-
}
|
5335
|
-
}
|
5336
|
-
return lastCookies;
|
5337
|
-
}
|
5338
|
-
};
|
5339
|
-
|
5340
|
-
|
5341
5316
|
/**
|
5342
5317
|
* @name $browser#defer
|
5343
5318
|
* @param {function()} fn A function, who's execution should be deferred.
|
@@ -5765,7 +5740,7 @@ function $CacheFactoryProvider() {
|
|
5765
5740
|
* the document, but it must be a descendent of the {@link ng.$rootElement $rootElement} (IE,
|
5766
5741
|
* element with ng-app attribute), otherwise the template will be ignored.
|
5767
5742
|
*
|
5768
|
-
* Adding via the
|
5743
|
+
* Adding via the `$templateCache` service:
|
5769
5744
|
*
|
5770
5745
|
* ```js
|
5771
5746
|
* var myApp = angular.module('myApp', []);
|
@@ -5793,6 +5768,17 @@ function $TemplateCacheProvider() {
|
|
5793
5768
|
}];
|
5794
5769
|
}
|
5795
5770
|
|
5771
|
+
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
5772
|
+
* Any commits to this file should be reviewed with security in mind. *
|
5773
|
+
* Changes to this file can potentially create security vulnerabilities. *
|
5774
|
+
* An approval from 2 Core members with history of modifying *
|
5775
|
+
* this file is required. *
|
5776
|
+
* *
|
5777
|
+
* Does the change somehow allow for arbitrary javascript to be executed? *
|
5778
|
+
* Or allows for someone to change the prototype of built-in objects? *
|
5779
|
+
* Or gives undesired access to variables likes document or window? *
|
5780
|
+
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
5781
|
+
|
5796
5782
|
/* ! VARIABLE/FUNCTION NAMING CONVENTIONS THAT APPLY TO THIS FILE!
|
5797
5783
|
*
|
5798
5784
|
* DOM-related variables:
|
@@ -6004,7 +5990,8 @@ function $TemplateCacheProvider() {
|
|
6004
5990
|
* Require another directive and inject its controller as the fourth argument to the linking function. The
|
6005
5991
|
* `require` takes a string name (or array of strings) of the directive(s) to pass in. If an array is used, the
|
6006
5992
|
* injected argument will be an array in corresponding order. If no such directive can be
|
6007
|
-
* found, or if the directive does not have a controller, then an error is raised
|
5993
|
+
* found, or if the directive does not have a controller, then an error is raised (unless no link function
|
5994
|
+
* is specified, in which case error checking is skipped). The name can be prefixed with:
|
6008
5995
|
*
|
6009
5996
|
* * (no prefix) - Locate the required controller on the current element. Throw an error if not found.
|
6010
5997
|
* * `?` - Attempt to locate the required controller or pass `null` to the `link` fn if not found.
|
@@ -6139,7 +6126,7 @@ function $TemplateCacheProvider() {
|
|
6139
6126
|
* `templateUrl` declaration or manual compilation inside the compile function.
|
6140
6127
|
* </div>
|
6141
6128
|
*
|
6142
|
-
* <div class="alert alert-
|
6129
|
+
* <div class="alert alert-danger">
|
6143
6130
|
* **Note:** The `transclude` function that is passed to the compile function is deprecated, as it
|
6144
6131
|
* e.g. does not know about the right outer scope. Please use the transclude function that is passed
|
6145
6132
|
* to the link function instead.
|
@@ -6418,7 +6405,7 @@ function $TemplateCacheProvider() {
|
|
6418
6405
|
* @param {string|DOMElement} element Element or HTML string to compile into a template function.
|
6419
6406
|
* @param {function(angular.Scope, cloneAttachFn=)} transclude function available to directives - DEPRECATED.
|
6420
6407
|
*
|
6421
|
-
* <div class="alert alert-
|
6408
|
+
* <div class="alert alert-danger">
|
6422
6409
|
* **Note:** Passing a `transclude` function to the $compile function is deprecated, as it
|
6423
6410
|
* e.g. will not use the right outer scope. Please pass the transclude function as a
|
6424
6411
|
* `parentBoundTranscludeFn` to the link function instead.
|
@@ -8961,8 +8948,8 @@ function $HttpProvider() {
|
|
8961
8948
|
**/
|
8962
8949
|
var interceptorFactories = this.interceptors = [];
|
8963
8950
|
|
8964
|
-
this.$get = ['$httpBackend', '
|
8965
|
-
function($httpBackend,
|
8951
|
+
this.$get = ['$httpBackend', '$$cookieReader', '$cacheFactory', '$rootScope', '$q', '$injector',
|
8952
|
+
function($httpBackend, $$cookieReader, $cacheFactory, $rootScope, $q, $injector) {
|
8966
8953
|
|
8967
8954
|
var defaultCache = $cacheFactory('$http');
|
8968
8955
|
|
@@ -9807,7 +9794,7 @@ function $HttpProvider() {
|
|
9807
9794
|
// send the request to the backend
|
9808
9795
|
if (isUndefined(cachedResp)) {
|
9809
9796
|
var xsrfValue = urlIsSameOrigin(config.url)
|
9810
|
-
?
|
9797
|
+
? $$cookieReader()[config.xsrfCookieName || defaults.xsrfCookieName]
|
9811
9798
|
: undefined;
|
9812
9799
|
if (xsrfValue) {
|
9813
9800
|
reqHeaders[(config.xsrfHeaderName || defaults.xsrfHeaderName)] = xsrfValue;
|
@@ -10362,7 +10349,7 @@ function $InterpolateProvider() {
|
|
10362
10349
|
// all of these properties are undocumented for now
|
10363
10350
|
exp: text, //just for compatibility with regular watchers created via $watch
|
10364
10351
|
expressions: expressions,
|
10365
|
-
$$watchDelegate: function(scope, listener
|
10352
|
+
$$watchDelegate: function(scope, listener) {
|
10366
10353
|
var lastValue;
|
10367
10354
|
return scope.$watchGroup(parseFns, function interpolateFnWatcher(values, oldValues) {
|
10368
10355
|
var currValue = compute(values);
|
@@ -10370,7 +10357,7 @@ function $InterpolateProvider() {
|
|
10370
10357
|
listener.call(this, currValue, values !== oldValues ? lastValue : currValue, scope);
|
10371
10358
|
}
|
10372
10359
|
lastValue = currValue;
|
10373
|
-
}
|
10360
|
+
});
|
10374
10361
|
}
|
10375
10362
|
});
|
10376
10363
|
}
|
@@ -10461,6 +10448,7 @@ function $IntervalProvider() {
|
|
10461
10448
|
* indefinitely.
|
10462
10449
|
* @param {boolean=} [invokeApply=true] If set to `false` skips model dirty checking, otherwise
|
10463
10450
|
* will invoke `fn` within the {@link ng.$rootScope.Scope#$apply $apply} block.
|
10451
|
+
* @param {...*=} Pass additional parameters to the executed function.
|
10464
10452
|
* @returns {promise} A promise which will be notified on each iteration.
|
10465
10453
|
*
|
10466
10454
|
* @example
|
@@ -10554,7 +10542,9 @@ function $IntervalProvider() {
|
|
10554
10542
|
* </example>
|
10555
10543
|
*/
|
10556
10544
|
function interval(fn, delay, count, invokeApply) {
|
10557
|
-
var
|
10545
|
+
var hasParams = arguments.length > 4,
|
10546
|
+
args = hasParams ? sliceArgs(arguments, 4) : [],
|
10547
|
+
setInterval = $window.setInterval,
|
10558
10548
|
clearInterval = $window.clearInterval,
|
10559
10549
|
iteration = 0,
|
10560
10550
|
skipApply = (isDefined(invokeApply) && !invokeApply),
|
@@ -10563,7 +10553,9 @@ function $IntervalProvider() {
|
|
10563
10553
|
|
10564
10554
|
count = isDefined(count) ? count : 0;
|
10565
10555
|
|
10566
|
-
promise.then(null, null, fn)
|
10556
|
+
promise.then(null, null, (!hasParams) ? fn : function() {
|
10557
|
+
fn.apply(null, args);
|
10558
|
+
});
|
10567
10559
|
|
10568
10560
|
promise.$$intervalId = setInterval(function tick() {
|
10569
10561
|
deferred.notify(iteration++);
|
@@ -10667,7 +10659,15 @@ function $LocaleProvider() {
|
|
10667
10659
|
mediumDate: 'MMM d, y',
|
10668
10660
|
shortDate: 'M/d/yy',
|
10669
10661
|
mediumTime: 'h:mm:ss a',
|
10670
|
-
shortTime: 'h:mm a'
|
10662
|
+
shortTime: 'h:mm a',
|
10663
|
+
ERANAMES: [
|
10664
|
+
"Before Christ",
|
10665
|
+
"Anno Domini"
|
10666
|
+
],
|
10667
|
+
ERAS: [
|
10668
|
+
"BC",
|
10669
|
+
"AD"
|
10670
|
+
]
|
10671
10671
|
},
|
10672
10672
|
|
10673
10673
|
pluralCat: function(num) {
|
@@ -11678,6 +11678,7 @@ function $LocationProvider() {
|
|
11678
11678
|
<button ng-click="$log.warn(message)">warn</button>
|
11679
11679
|
<button ng-click="$log.info(message)">info</button>
|
11680
11680
|
<button ng-click="$log.error(message)">error</button>
|
11681
|
+
<button ng-click="$log.debug(message)">debug</button>
|
11681
11682
|
</div>
|
11682
11683
|
</file>
|
11683
11684
|
</example>
|
@@ -11808,6 +11809,17 @@ function $LogProvider() {
|
|
11808
11809
|
}];
|
11809
11810
|
}
|
11810
11811
|
|
11812
|
+
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
11813
|
+
* Any commits to this file should be reviewed with security in mind. *
|
11814
|
+
* Changes to this file can potentially create security vulnerabilities. *
|
11815
|
+
* An approval from 2 Core members with history of modifying *
|
11816
|
+
* this file is required. *
|
11817
|
+
* *
|
11818
|
+
* Does the change somehow allow for arbitrary javascript to be executed? *
|
11819
|
+
* Or allows for someone to change the prototype of built-in objects? *
|
11820
|
+
* Or gives undesired access to variables likes document or window? *
|
11821
|
+
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
11822
|
+
|
11811
11823
|
var $parseMinErr = minErr('$parse');
|
11812
11824
|
|
11813
11825
|
// Sandboxing Angular Expressions
|
@@ -14381,9 +14393,27 @@ function $RootScopeProvider() {
|
|
14381
14393
|
return TTL;
|
14382
14394
|
};
|
14383
14395
|
|
14396
|
+
function createChildScopeClass(parent) {
|
14397
|
+
function ChildScope() {
|
14398
|
+
this.$$watchers = this.$$nextSibling =
|
14399
|
+
this.$$childHead = this.$$childTail = null;
|
14400
|
+
this.$$listeners = {};
|
14401
|
+
this.$$listenerCount = {};
|
14402
|
+
this.$$watchersCount = 0;
|
14403
|
+
this.$id = nextUid();
|
14404
|
+
this.$$ChildScope = null;
|
14405
|
+
}
|
14406
|
+
ChildScope.prototype = parent;
|
14407
|
+
return ChildScope;
|
14408
|
+
}
|
14409
|
+
|
14384
14410
|
this.$get = ['$injector', '$exceptionHandler', '$parse', '$browser',
|
14385
14411
|
function($injector, $exceptionHandler, $parse, $browser) {
|
14386
14412
|
|
14413
|
+
function destroyChildScope($event) {
|
14414
|
+
$event.currentScope.$$destroyed = true;
|
14415
|
+
}
|
14416
|
+
|
14387
14417
|
/**
|
14388
14418
|
* @ngdoc type
|
14389
14419
|
* @name $rootScope.Scope
|
@@ -14507,16 +14537,7 @@ function $RootScopeProvider() {
|
|
14507
14537
|
// Only create a child scope class if somebody asks for one,
|
14508
14538
|
// but cache it to allow the VM to optimize lookups.
|
14509
14539
|
if (!this.$$ChildScope) {
|
14510
|
-
this.$$ChildScope =
|
14511
|
-
this.$$watchers = this.$$nextSibling =
|
14512
|
-
this.$$childHead = this.$$childTail = null;
|
14513
|
-
this.$$listeners = {};
|
14514
|
-
this.$$listenerCount = {};
|
14515
|
-
this.$$watchersCount = 0;
|
14516
|
-
this.$id = nextUid();
|
14517
|
-
this.$$ChildScope = null;
|
14518
|
-
};
|
14519
|
-
this.$$ChildScope.prototype = this;
|
14540
|
+
this.$$ChildScope = createChildScopeClass(this);
|
14520
14541
|
}
|
14521
14542
|
child = new this.$$ChildScope();
|
14522
14543
|
}
|
@@ -14534,13 +14555,9 @@ function $RootScopeProvider() {
|
|
14534
14555
|
// prototypically. In all other cases, this property needs to be set
|
14535
14556
|
// when the parent scope is destroyed.
|
14536
14557
|
// The listener needs to be added after the parent is set
|
14537
|
-
if (isolate || parent != this) child.$on('$destroy',
|
14558
|
+
if (isolate || parent != this) child.$on('$destroy', destroyChildScope);
|
14538
14559
|
|
14539
14560
|
return child;
|
14540
|
-
|
14541
|
-
function destroyChild() {
|
14542
|
-
child.$$destroyed = true;
|
14543
|
-
}
|
14544
14561
|
},
|
14545
14562
|
|
14546
14563
|
/**
|
@@ -15710,6 +15727,17 @@ function $$SanitizeUriProvider() {
|
|
15710
15727
|
};
|
15711
15728
|
}
|
15712
15729
|
|
15730
|
+
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
15731
|
+
* Any commits to this file should be reviewed with security in mind. *
|
15732
|
+
* Changes to this file can potentially create security vulnerabilities. *
|
15733
|
+
* An approval from 2 Core members with history of modifying *
|
15734
|
+
* this file is required. *
|
15735
|
+
* *
|
15736
|
+
* Does the change somehow allow for arbitrary javascript to be executed? *
|
15737
|
+
* Or allows for someone to change the prototype of built-in objects? *
|
15738
|
+
* Or gives undesired access to variables likes document or window? *
|
15739
|
+
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
15740
|
+
|
15713
15741
|
var $sceMinErr = minErr('$sce');
|
15714
15742
|
|
15715
15743
|
var SCE_CONTEXTS = {
|
@@ -17054,6 +17082,7 @@ function $TimeoutProvider() {
|
|
17054
17082
|
* @param {number=} [delay=0] Delay in milliseconds.
|
17055
17083
|
* @param {boolean=} [invokeApply=true] If set to `false` skips model dirty checking, otherwise
|
17056
17084
|
* will invoke `fn` within the {@link ng.$rootScope.Scope#$apply $apply} block.
|
17085
|
+
* @param {...*=} Pass additional parameters to the executed function.
|
17057
17086
|
* @returns {Promise} Promise that will be resolved when the timeout is reached. The value this
|
17058
17087
|
* promise will be resolved with is the return value of the `fn` function.
|
17059
17088
|
*
|
@@ -17065,14 +17094,15 @@ function $TimeoutProvider() {
|
|
17065
17094
|
fn = noop;
|
17066
17095
|
}
|
17067
17096
|
|
17068
|
-
var
|
17097
|
+
var args = sliceArgs(arguments, 3),
|
17098
|
+
skipApply = (isDefined(invokeApply) && !invokeApply),
|
17069
17099
|
deferred = (skipApply ? $$q : $q).defer(),
|
17070
17100
|
promise = deferred.promise,
|
17071
17101
|
timeoutId;
|
17072
17102
|
|
17073
17103
|
timeoutId = $browser.defer(function() {
|
17074
17104
|
try {
|
17075
|
-
deferred.resolve(fn());
|
17105
|
+
deferred.resolve(fn.apply(null, args));
|
17076
17106
|
} catch (e) {
|
17077
17107
|
deferred.reject(e);
|
17078
17108
|
$exceptionHandler(e);
|
@@ -17264,6 +17294,60 @@ function $WindowProvider() {
|
|
17264
17294
|
this.$get = valueFn(window);
|
17265
17295
|
}
|
17266
17296
|
|
17297
|
+
/**
|
17298
|
+
* @name $$cookieReader
|
17299
|
+
* @requires $document
|
17300
|
+
*
|
17301
|
+
* @description
|
17302
|
+
* This is a private service for reading cookies used by $http and ngCookies
|
17303
|
+
*
|
17304
|
+
* @return {Object} a key/value map of the current cookies
|
17305
|
+
*/
|
17306
|
+
function $$CookieReader($document) {
|
17307
|
+
var rawDocument = $document[0];
|
17308
|
+
var lastCookies = {};
|
17309
|
+
var lastCookieString = '';
|
17310
|
+
|
17311
|
+
function safeDecodeURIComponent(str) {
|
17312
|
+
try {
|
17313
|
+
return decodeURIComponent(str);
|
17314
|
+
} catch (e) {
|
17315
|
+
return str;
|
17316
|
+
}
|
17317
|
+
}
|
17318
|
+
|
17319
|
+
return function() {
|
17320
|
+
var cookieArray, cookie, i, index, name;
|
17321
|
+
|
17322
|
+
if (rawDocument.cookie !== lastCookieString) {
|
17323
|
+
lastCookieString = rawDocument.cookie;
|
17324
|
+
cookieArray = lastCookieString.split('; ');
|
17325
|
+
lastCookies = {};
|
17326
|
+
|
17327
|
+
for (i = 0; i < cookieArray.length; i++) {
|
17328
|
+
cookie = cookieArray[i];
|
17329
|
+
index = cookie.indexOf('=');
|
17330
|
+
if (index > 0) { //ignore nameless cookies
|
17331
|
+
name = safeDecodeURIComponent(cookie.substring(0, index));
|
17332
|
+
// the first value that is seen for a cookie is the most
|
17333
|
+
// specific one. values for the same cookie name that
|
17334
|
+
// follow are for less specific paths.
|
17335
|
+
if (lastCookies[name] === undefined) {
|
17336
|
+
lastCookies[name] = safeDecodeURIComponent(cookie.substring(index + 1));
|
17337
|
+
}
|
17338
|
+
}
|
17339
|
+
}
|
17340
|
+
}
|
17341
|
+
return lastCookies;
|
17342
|
+
};
|
17343
|
+
}
|
17344
|
+
|
17345
|
+
$$CookieReader.$inject = ['$document'];
|
17346
|
+
|
17347
|
+
function $$CookieReaderProvider() {
|
17348
|
+
this.$get = $$CookieReader;
|
17349
|
+
}
|
17350
|
+
|
17267
17351
|
/* global currencyFilter: true,
|
17268
17352
|
dateFilter: true,
|
17269
17353
|
filterFilter: true,
|
@@ -17466,6 +17550,9 @@ function $FilterProvider($provide) {
|
|
17466
17550
|
* - `false|undefined`: A short hand for a function which will look for a substring match in case
|
17467
17551
|
* insensitive way.
|
17468
17552
|
*
|
17553
|
+
* Primitive values are converted to strings. Objects are not compared against primitives,
|
17554
|
+
* unless they have a custom `toString` method (e.g. `Date` objects).
|
17555
|
+
*
|
17469
17556
|
* @example
|
17470
17557
|
<example>
|
17471
17558
|
<file name="index.html">
|
@@ -17568,6 +17655,10 @@ function filterFilter() {
|
|
17568
17655
|
};
|
17569
17656
|
}
|
17570
17657
|
|
17658
|
+
function hasCustomToString(obj) {
|
17659
|
+
return isFunction(obj.toString) && obj.toString !== Object.prototype.toString;
|
17660
|
+
}
|
17661
|
+
|
17571
17662
|
// Helper functions for `filterFilter`
|
17572
17663
|
function createPredicateFn(expression, comparator, matchAgainstAnyProp) {
|
17573
17664
|
var shouldMatchPrimitives = isObject(expression) && ('$' in expression);
|
@@ -17577,8 +17668,8 @@ function createPredicateFn(expression, comparator, matchAgainstAnyProp) {
|
|
17577
17668
|
comparator = equals;
|
17578
17669
|
} else if (!isFunction(comparator)) {
|
17579
17670
|
comparator = function(actual, expected) {
|
17580
|
-
if (isObject(
|
17581
|
-
//
|
17671
|
+
if (isObject(expected) || (isObject(actual) && !hasCustomToString(actual))) {
|
17672
|
+
// Should not compare primitives against objects, unless they have custom `toString` method
|
17582
17673
|
return false;
|
17583
17674
|
}
|
17584
17675
|
|
@@ -17599,8 +17690,8 @@ function createPredicateFn(expression, comparator, matchAgainstAnyProp) {
|
|
17599
17690
|
}
|
17600
17691
|
|
17601
17692
|
function deepCompare(actual, expected, comparator, matchAgainstAnyProp, dontMatchWholeObject) {
|
17602
|
-
var actualType = typeof actual;
|
17603
|
-
var expectedType = typeof expected;
|
17693
|
+
var actualType = (actual !== null) ? typeof actual : 'null';
|
17694
|
+
var expectedType = (expected !== null) ? typeof expected : 'null';
|
17604
17695
|
|
17605
17696
|
if ((expectedType === 'string') && (expected.charAt(0) === '!')) {
|
17606
17697
|
return !deepCompare(actual, expected.substring(1), comparator, matchAgainstAnyProp);
|
@@ -17625,7 +17716,7 @@ function deepCompare(actual, expected, comparator, matchAgainstAnyProp, dontMatc
|
|
17625
17716
|
} else if (expectedType === 'object') {
|
17626
17717
|
for (key in expected) {
|
17627
17718
|
var expectedVal = expected[key];
|
17628
|
-
if (isFunction(expectedVal)) {
|
17719
|
+
if (isFunction(expectedVal) || isUndefined(expectedVal)) {
|
17629
17720
|
continue;
|
17630
17721
|
}
|
17631
17722
|
|
@@ -17949,6 +18040,14 @@ function ampmGetter(date, formats) {
|
|
17949
18040
|
return date.getHours() < 12 ? formats.AMPMS[0] : formats.AMPMS[1];
|
17950
18041
|
}
|
17951
18042
|
|
18043
|
+
function eraGetter(date, formats) {
|
18044
|
+
return date.getFullYear() <= 0 ? formats.ERAS[0] : formats.ERAS[1];
|
18045
|
+
}
|
18046
|
+
|
18047
|
+
function longEraGetter(date, formats) {
|
18048
|
+
return date.getFullYear() <= 0 ? formats.ERANAMES[0] : formats.ERANAMES[1];
|
18049
|
+
}
|
18050
|
+
|
17952
18051
|
var DATE_FORMATS = {
|
17953
18052
|
yyyy: dateGetter('FullYear', 4),
|
17954
18053
|
yy: dateGetter('FullYear', 2, 0, true),
|
@@ -17975,10 +18074,14 @@ var DATE_FORMATS = {
|
|
17975
18074
|
a: ampmGetter,
|
17976
18075
|
Z: timeZoneGetter,
|
17977
18076
|
ww: weekGetter(2),
|
17978
|
-
w: weekGetter(1)
|
18077
|
+
w: weekGetter(1),
|
18078
|
+
G: eraGetter,
|
18079
|
+
GG: eraGetter,
|
18080
|
+
GGG: eraGetter,
|
18081
|
+
GGGG: longEraGetter
|
17979
18082
|
};
|
17980
18083
|
|
17981
|
-
var DATE_FORMATS_SPLIT = /((?:[^
|
18084
|
+
var DATE_FORMATS_SPLIT = /((?:[^yMdHhmsaZEwG']+)|(?:'(?:[^']|'')*')|(?:E+|y+|M+|d+|H+|h+|m+|s+|a|Z|G+|w+))(.*)/,
|
17982
18085
|
NUMBER_STRING = /^\-?\d+$/;
|
17983
18086
|
|
17984
18087
|
/**
|
@@ -18015,6 +18118,8 @@ var DATE_FORMATS_SPLIT = /((?:[^yMdHhmsaZEw']+)|(?:'(?:[^']|'')*')|(?:E+|y+|M+|d
|
|
18015
18118
|
* * `'Z'`: 4 digit (+sign) representation of the timezone offset (-1200-+1200)
|
18016
18119
|
* * `'ww'`: Week of year, padded (00-53). Week 01 is the week with the first Thursday of the year
|
18017
18120
|
* * `'w'`: Week of year (0-53). Week 1 is the week with the first Thursday of the year
|
18121
|
+
* * `'G'`, `'GG'`, `'GGG'`: The abbreviated form of the era string (e.g. 'AD')
|
18122
|
+
* * `'GGGG'`: The long form of the era string (e.g. 'Anno Domini')
|
18018
18123
|
*
|
18019
18124
|
* `format` string can also be one of the following predefined
|
18020
18125
|
* {@link guide/i18n localizable formats}:
|
@@ -18135,12 +18240,8 @@ function dateFilter($locale) {
|
|
18135
18240
|
|
18136
18241
|
var dateTimezoneOffset = date.getTimezoneOffset();
|
18137
18242
|
if (timezone) {
|
18138
|
-
|
18139
|
-
|
18140
|
-
date = new Date(date.getTime());
|
18141
|
-
date.setMinutes(date.getMinutes() + dateTimezoneOffset - requestedTimezoneOffset);
|
18142
|
-
dateTimezoneOffset = requestedTimezoneOffset;
|
18143
|
-
}
|
18243
|
+
dateTimezoneOffset = timezoneToOffset(timezone, date.getTimezoneOffset());
|
18244
|
+
date = convertTimezoneToLocal(date, timezone, true);
|
18144
18245
|
}
|
18145
18246
|
forEach(parts, function(value) {
|
18146
18247
|
fn = DATE_FORMATS[value];
|
@@ -18365,6 +18466,43 @@ function limitToFilter() {
|
|
18365
18466
|
* @param {boolean=} reverse Reverse the order of the array.
|
18366
18467
|
* @returns {Array} Sorted copy of the source array.
|
18367
18468
|
*
|
18469
|
+
*
|
18470
|
+
* @example
|
18471
|
+
* The example below demonstrates a simple ngRepeat, where the data is sorted
|
18472
|
+
* by age in descending order (predicate is set to `'-age'`).
|
18473
|
+
* `reverse` is not set, which means it defaults to `false`.
|
18474
|
+
<example module="orderByExample">
|
18475
|
+
<file name="index.html">
|
18476
|
+
<script>
|
18477
|
+
angular.module('orderByExample', [])
|
18478
|
+
.controller('ExampleController', ['$scope', function($scope) {
|
18479
|
+
$scope.friends =
|
18480
|
+
[{name:'John', phone:'555-1212', age:10},
|
18481
|
+
{name:'Mary', phone:'555-9876', age:19},
|
18482
|
+
{name:'Mike', phone:'555-4321', age:21},
|
18483
|
+
{name:'Adam', phone:'555-5678', age:35},
|
18484
|
+
{name:'Julie', phone:'555-8765', age:29}];
|
18485
|
+
}]);
|
18486
|
+
</script>
|
18487
|
+
<div ng-controller="ExampleController">
|
18488
|
+
<table class="friend">
|
18489
|
+
<tr>
|
18490
|
+
<th>Name</th>
|
18491
|
+
<th>Phone Number</th>
|
18492
|
+
<th>Age</th>
|
18493
|
+
</tr>
|
18494
|
+
<tr ng-repeat="friend in friends | orderBy:'-age'">
|
18495
|
+
<td>{{friend.name}}</td>
|
18496
|
+
<td>{{friend.phone}}</td>
|
18497
|
+
<td>{{friend.age}}</td>
|
18498
|
+
</tr>
|
18499
|
+
</table>
|
18500
|
+
</div>
|
18501
|
+
</file>
|
18502
|
+
</example>
|
18503
|
+
*
|
18504
|
+
* The predicate and reverse parameters can be controlled dynamically through scope properties,
|
18505
|
+
* as shown in the next example.
|
18368
18506
|
* @example
|
18369
18507
|
<example module="orderByExample">
|
18370
18508
|
<file name="index.html">
|
@@ -18747,6 +18885,7 @@ var htmlAnchorDirective = valueFn({
|
|
18747
18885
|
* but not on older IEs:
|
18748
18886
|
*
|
18749
18887
|
* ```html
|
18888
|
+
* <!-- See below for an example of ng-disabled being used correctly -->
|
18750
18889
|
* <div ng-init="isDisabled = false">
|
18751
18890
|
* <button disabled="{{isDisabled}}">Disabled</button>
|
18752
18891
|
* </div>
|
@@ -19334,7 +19473,7 @@ function FormController(element, attrs, $scope, $animate, $interpolate) {
|
|
19334
19473
|
*
|
19335
19474
|
* # Alias: {@link ng.directive:ngForm `ngForm`}
|
19336
19475
|
*
|
19337
|
-
* In Angular forms can be nested. This means that the outer form is valid when all of the child
|
19476
|
+
* In Angular, forms can be nested. This means that the outer form is valid when all of the child
|
19338
19477
|
* forms are valid as well. However, browsers do not allow nesting of `<form>` elements, so
|
19339
19478
|
* Angular provides the {@link ng.directive:ngForm `ngForm`} directive which behaves identically to
|
19340
19479
|
* `<form>` but can be nested. This allows you to have nested forms, which is very useful when
|
@@ -19472,10 +19611,12 @@ var formDirectiveFactory = function(isNgForm) {
|
|
19472
19611
|
name: 'form',
|
19473
19612
|
restrict: isNgForm ? 'EAC' : 'E',
|
19474
19613
|
controller: FormController,
|
19475
|
-
compile: function ngFormCompile(formElement) {
|
19614
|
+
compile: function ngFormCompile(formElement, attr) {
|
19476
19615
|
// Setup initial state of the control
|
19477
19616
|
formElement.addClass(PRISTINE_CLASS).addClass(VALID_CLASS);
|
19478
19617
|
|
19618
|
+
var nameAttr = attr.name ? 'name' : (isNgForm && attr.ngForm ? 'ngForm' : false);
|
19619
|
+
|
19479
19620
|
return {
|
19480
19621
|
pre: function ngFormPreLink(scope, formElement, attr, controller) {
|
19481
19622
|
// if `action` attr is not present on the form, prevent the default action (submission)
|
@@ -19506,23 +19647,21 @@ var formDirectiveFactory = function(isNgForm) {
|
|
19506
19647
|
});
|
19507
19648
|
}
|
19508
19649
|
|
19509
|
-
var parentFormCtrl = controller.$$parentForm
|
19510
|
-
|
19511
|
-
|
19512
|
-
|
19513
|
-
|
19514
|
-
|
19515
|
-
|
19516
|
-
|
19517
|
-
|
19518
|
-
setter(scope, alias, controller, alias);
|
19519
|
-
parentFormCtrl.$$renameControl(controller, alias);
|
19650
|
+
var parentFormCtrl = controller.$$parentForm;
|
19651
|
+
|
19652
|
+
if (nameAttr) {
|
19653
|
+
setter(scope, controller.$name, controller, controller.$name);
|
19654
|
+
attr.$observe(nameAttr, function(newValue) {
|
19655
|
+
if (controller.$name === newValue) return;
|
19656
|
+
setter(scope, controller.$name, undefined, controller.$name);
|
19657
|
+
parentFormCtrl.$$renameControl(controller, newValue);
|
19658
|
+
setter(scope, controller.$name, controller, controller.$name);
|
19520
19659
|
});
|
19521
19660
|
}
|
19522
19661
|
formElement.on('$destroy', function() {
|
19523
19662
|
parentFormCtrl.$removeControl(controller);
|
19524
|
-
if (
|
19525
|
-
setter(scope,
|
19663
|
+
if (nameAttr) {
|
19664
|
+
setter(scope, attr[nameAttr], undefined, controller.$name);
|
19526
19665
|
}
|
19527
19666
|
extend(controller, nullFormCtrl); //stop propagating child destruction handlers upwards
|
19528
19667
|
});
|
@@ -20694,8 +20833,8 @@ function createDateInputType(type, regexp, parseDate, format) {
|
|
20694
20833
|
// parser/formatter in the processing chain so that the model
|
20695
20834
|
// contains some different data format!
|
20696
20835
|
var parsedDate = parseDate(value, previousDate);
|
20697
|
-
if (timezone
|
20698
|
-
parsedDate
|
20836
|
+
if (timezone) {
|
20837
|
+
parsedDate = convertTimezoneToLocal(parsedDate, timezone);
|
20699
20838
|
}
|
20700
20839
|
return parsedDate;
|
20701
20840
|
}
|
@@ -20708,9 +20847,8 @@ function createDateInputType(type, regexp, parseDate, format) {
|
|
20708
20847
|
}
|
20709
20848
|
if (isValidDate(value)) {
|
20710
20849
|
previousDate = value;
|
20711
|
-
if (previousDate && timezone
|
20712
|
-
|
20713
|
-
previousDate = new Date(previousDate.getTime() + timezoneOffset);
|
20850
|
+
if (previousDate && timezone) {
|
20851
|
+
previousDate = convertTimezoneToLocal(previousDate, timezone, true);
|
20714
20852
|
}
|
20715
20853
|
return $filter('date')(value, format, timezone);
|
20716
20854
|
} else {
|
@@ -23182,7 +23320,7 @@ var ngIncludeFillContentDirective = ['$compile',
|
|
23182
23320
|
* The `ngInit` directive allows you to evaluate an expression in the
|
23183
23321
|
* current scope.
|
23184
23322
|
*
|
23185
|
-
* <div class="alert alert-
|
23323
|
+
* <div class="alert alert-danger">
|
23186
23324
|
* The only appropriate use of `ngInit` is for aliasing special properties of
|
23187
23325
|
* {@link ng.directive:ngRepeat `ngRepeat`}, as seen in the demo below. Besides this case, you
|
23188
23326
|
* should use {@link guide/controller controllers} rather than `ngInit`
|
@@ -23495,8 +23633,8 @@ is set to `true`. The parse error is stored in `ngModel.$error.parse`.
|
|
23495
23633
|
* data-binding. Notice how different directives (`contenteditable`, `ng-model`, and `required`)
|
23496
23634
|
* collaborate together to achieve the desired result.
|
23497
23635
|
*
|
23498
|
-
*
|
23499
|
-
* contents be edited in place by the user.
|
23636
|
+
* `contenteditable` is an HTML5 attribute, which tells the browser to let the element
|
23637
|
+
* contents be edited in place by the user.
|
23500
23638
|
*
|
23501
23639
|
* We are using the {@link ng.service:$sce $sce} service here and include the {@link ngSanitize $sanitize}
|
23502
23640
|
* module to automatically remove "bad" content like inline event listener (e.g. `<span onclick="...">`).
|
@@ -24459,8 +24597,10 @@ var DEFAULT_REGEXP = /(\s+|^)default(\s+|$)/;
|
|
24459
24597
|
* - `getterSetter`: boolean value which determines whether or not to treat functions bound to
|
24460
24598
|
`ngModel` as getters/setters.
|
24461
24599
|
* - `timezone`: Defines the timezone to be used to read/write the `Date` instance in the model for
|
24462
|
-
* `<input type="date">`, `<input type="time">`, ... .
|
24463
|
-
*
|
24600
|
+
* `<input type="date">`, `<input type="time">`, ... . It understands UTC/GMT and the
|
24601
|
+
* continental US time zone abbreviations, but for general use, use a time zone offset, for
|
24602
|
+
* example, `'+0430'` (4 hours, 30 minutes east of the Greenwich meridian)
|
24603
|
+
* If not specified, the timezone of the browser will be used.
|
24464
24604
|
*
|
24465
24605
|
* @example
|
24466
24606
|
|
@@ -25068,6 +25208,11 @@ var ngOptionsDirective = ['$compile', '$parse', function($compile, $parse) {
|
|
25068
25208
|
selectValueMap: selectValueMap,
|
25069
25209
|
getOptionFromViewValue: function(value) {
|
25070
25210
|
return selectValueMap[getTrackByValue(value, getLocals(value))];
|
25211
|
+
},
|
25212
|
+
getViewValueFromOption: function(option) {
|
25213
|
+
// If the viewValue could be an object that may be mutated by the application,
|
25214
|
+
// we need to make a copy and not return the reference to the value on the option.
|
25215
|
+
return trackBy ? angular.copy(option.viewValue) : option.viewValue;
|
25071
25216
|
}
|
25072
25217
|
};
|
25073
25218
|
}
|
@@ -25161,7 +25306,7 @@ var ngOptionsDirective = ['$compile', '$parse', function($compile, $parse) {
|
|
25161
25306
|
if (selectedOption && !selectedOption.disabled) {
|
25162
25307
|
removeEmptyOption();
|
25163
25308
|
removeUnknownOption();
|
25164
|
-
return selectedOption
|
25309
|
+
return options.getViewValueFromOption(selectedOption);
|
25165
25310
|
}
|
25166
25311
|
return null;
|
25167
25312
|
};
|
@@ -25195,7 +25340,7 @@ var ngOptionsDirective = ['$compile', '$parse', function($compile, $parse) {
|
|
25195
25340
|
|
25196
25341
|
forEach(selectedValues, function(value) {
|
25197
25342
|
var option = options.selectValueMap[value];
|
25198
|
-
if (!option.disabled) selections.push(option
|
25343
|
+
if (!option.disabled) selections.push(options.getViewValueFromOption(option));
|
25199
25344
|
});
|
25200
25345
|
|
25201
25346
|
return selections;
|
@@ -25226,6 +25371,10 @@ var ngOptionsDirective = ['$compile', '$parse', function($compile, $parse) {
|
|
25226
25371
|
// We will re-render the option elements if the option values or labels change
|
25227
25372
|
scope.$watchCollection(ngOptions.getWatchables, updateOptions);
|
25228
25373
|
|
25374
|
+
// We also need to watch to see if the internals of the model changes, since
|
25375
|
+
// ngModel only watches for object identity change
|
25376
|
+
scope.$watch(attr.ngModel, function() { ngModelCtrl.$render(); }, true);
|
25377
|
+
|
25229
25378
|
// ------------------------------------------------------------------ //
|
25230
25379
|
|
25231
25380
|
|
@@ -25557,7 +25706,6 @@ var ngPluralizeDirective = ['$locale', '$interpolate', '$log', function($locale,
|
|
25557
25706
|
IS_WHEN = /^when(Minus)?(.+)$/;
|
25558
25707
|
|
25559
25708
|
return {
|
25560
|
-
restrict: 'EA',
|
25561
25709
|
link: function(scope, element, attr) {
|
25562
25710
|
var numberExp = attr.count,
|
25563
25711
|
whenExp = attr.$attr.when && element.attr(attr.$attr.when), // we have {{}} in attrs
|