Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
T
todomvc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Sven Franck
todomvc
Commits
a0a139c2
Commit
a0a139c2
authored
Nov 26, 2013
by
Pascal Hartig
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
angularjs_require: upgrade to 1.2.2
parent
28538a24
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
246 additions
and
162 deletions
+246
-162
labs/dependency-examples/angularjs_require/bower_components/angular/angular.js
...les/angularjs_require/bower_components/angular/angular.js
+246
-162
No files found.
labs/dependency-examples/angularjs_require/bower_components/angular/angular.js
100755 → 100644
View file @
a0a139c2
/**
/**
* @license AngularJS v1.2.
1
* @license AngularJS v1.2.
2
* (c) 2010-2012 Google, Inc. http://angularjs.org
* (c) 2010-2012 Google, Inc. http://angularjs.org
* License: MIT
* License: MIT
*/
*/
...
@@ -68,7 +68,7 @@ function minErr(module) {
...
@@ -68,7 +68,7 @@ function minErr(module) {
return
match
;
return
match
;
});
});
message
=
message
+
'
\n
http://errors.angularjs.org/1.2.
1
/
'
+
message
=
message
+
'
\n
http://errors.angularjs.org/1.2.
2
/
'
+
(
module
?
module
+
'
/
'
:
''
)
+
code
;
(
module
?
module
+
'
/
'
:
''
)
+
code
;
for
(
i
=
2
;
i
<
arguments
.
length
;
i
++
)
{
for
(
i
=
2
;
i
<
arguments
.
length
;
i
++
)
{
message
=
message
+
(
i
==
2
?
'
?
'
:
'
&
'
)
+
'
p
'
+
(
i
-
2
)
+
'
=
'
+
message
=
message
+
(
i
==
2
?
'
?
'
:
'
&
'
)
+
'
p
'
+
(
i
-
2
)
+
'
=
'
+
...
@@ -159,7 +159,7 @@ function minErr(module) {
...
@@ -159,7 +159,7 @@ function minErr(module) {
-assertArgFn,
-assertArgFn,
-assertNotHasOwnProperty,
-assertNotHasOwnProperty,
-getter,
-getter,
-getBlockElements
-getBlockElements
,
*/
*/
...
@@ -1181,26 +1181,38 @@ function encodeUriQuery(val, pctEncodeSpaces) {
...
@@ -1181,26 +1181,38 @@ function encodeUriQuery(val, pctEncodeSpaces) {
*
*
* @description
* @description
*
*
* Use this directive to auto-bootstrap an application. Only
* Use this directive to **auto-bootstrap** an AngularJS application. The `ngApp` directive
* one ngApp directive can be used per HTML document. The directive
* designates the **root element** of the application and is typically placed near the root element
* designates the root of the application and is typically placed
* of the page - e.g. on the `<body>` or `<html>` tags.
* at the root of the page.
*
*
* Only one AngularJS application can be auto-bootstrapped per HTML document. The first `ngApp`
* The first ngApp found in the document will be auto-bootstrapped. To use multiple applications in
* found in the document will be used to define the root element to auto-bootstrap as an
* an HTML document you must manually bootstrap them using {@link angular.bootstrap}.
* application. To run multiple applications in an HTML document you must manually bootstrap them using
* Applications cannot be nested.
* {@link angular.bootstrap} instead. AngularJS applications cannot be nested within each other.
*
*
* In the example below if the `ngApp` directive were not placed
* You can specify an **AngularJS module** to be used as the root module for the application. This
* on the `html` element then the document would not be compiled
* module will be loaded into the {@link AUTO.$injector} when the application is bootstrapped and
* and the `{{ 1+2 }}` would not be resolved to `3`.
* should contain the application code needed or have dependencies on other modules that will
*
* contain the code. See {@link angular.module} for more information.
* `ngApp` is the easiest way to bootstrap an application.
*
*
* In the example below if the `ngApp` directive were not placed on the `html` element then the
<doc:example>
* document would not be compiled, the `AppController` would not be instantiated and the `{{ a+b }}`
<doc:source>
* would not be resolved to `3`.
I can add: 1 + 2 = {{ 1+2 }}
*
</doc:source>
* `ngApp` is the easiest, and most common, way to bootstrap an application.
</doc:example>
*
<example module="ngAppDemo">
<file name="index.html">
<div ng-controller="ngAppDemoController">
I can add: {{a}} + {{b}} = {{ a+b }}
</file>
<file name="script.js">
angular.module('ngAppDemo', []).controller('ngAppDemoController', function($scope) {
$scope.a = 1;
$scope.b = 2;
});
</file>
</example>
*
*
*/
*/
function
angularInit
(
element
,
bootstrap
)
{
function
angularInit
(
element
,
bootstrap
)
{
...
@@ -1435,7 +1447,12 @@ function setupModuleLoader(window) {
...
@@ -1435,7 +1447,12 @@ function setupModuleLoader(window) {
return
obj
[
name
]
||
(
obj
[
name
]
=
factory
());
return
obj
[
name
]
||
(
obj
[
name
]
=
factory
());
}
}
return
ensure
(
ensure
(
window
,
'
angular
'
,
Object
),
'
module
'
,
function
()
{
var
angular
=
ensure
(
window
,
'
angular
'
,
Object
);
// We need to expose `angular.$$minErr` to modules such as `ngResource` that reference it during bootstrap
angular
.
$$minErr
=
angular
.
$$minErr
||
minErr
;
return
ensure
(
angular
,
'
module
'
,
function
()
{
/** @type {Object.<string, angular.Module>} */
/** @type {Object.<string, angular.Module>} */
var
modules
=
{};
var
modules
=
{};
...
@@ -1808,11 +1825,11 @@ function setupModuleLoader(window) {
...
@@ -1808,11 +1825,11 @@ function setupModuleLoader(window) {
* - `codeName` – `{string}` – Code name of the release, such as "jiggling-armfat".
* - `codeName` – `{string}` – Code name of the release, such as "jiggling-armfat".
*/
*/
var
version
=
{
var
version
=
{
full
:
'
1.2.
1
'
,
// all of these placeholder strings will be replaced by grunt's
full
:
'
1.2.
2
'
,
// all of these placeholder strings will be replaced by grunt's
major
:
1
,
// package task
major
:
1
,
// package task
minor
:
2
,
minor
:
2
,
dot
:
1
,
dot
:
2
,
codeName
:
'
underscore-empathy
'
codeName
:
'
consciousness-inertia
'
};
};
...
@@ -3359,11 +3376,11 @@ function annotate(fn) {
...
@@ -3359,11 +3376,11 @@ function annotate(fn) {
* @example
* @example
* Here are some examples of creating value services.
* Here are some examples of creating value services.
* <pre>
* <pre>
* $provide.
constant
('ADMIN_USER', 'admin');
* $provide.
value
('ADMIN_USER', 'admin');
*
*
* $provide.
constant
('RoleLookup', { admin: 0, writer: 1, reader: 2 });
* $provide.
value
('RoleLookup', { admin: 0, writer: 1, reader: 2 });
*
*
* $provide.
constant
('halfOf', function(value) {
* $provide.
value
('halfOf', function(value) {
* return value / 2;
* return value / 2;
* });
* });
* </pre>
* </pre>
...
@@ -3849,13 +3866,14 @@ var $AnimateProvider = ['$provide', function($provide) {
...
@@ -3849,13 +3866,14 @@ var $AnimateProvider = ['$provide', function($provide) {
* inserted into the DOM
* inserted into the DOM
*/
*/
enter
:
function
(
element
,
parent
,
after
,
done
)
{
enter
:
function
(
element
,
parent
,
after
,
done
)
{
var
afterNode
=
after
&&
after
[
after
.
length
-
1
];
if
(
after
)
{
var
parentNode
=
parent
&&
parent
[
0
]
||
afterNode
&&
afterNode
.
parentNode
;
after
.
after
(
element
);
// IE does not like undefined so we have to pass null.
}
else
{
var
afterNextSibling
=
(
afterNode
&&
afterNode
.
nextSibling
)
||
null
;
if
(
!
parent
||
!
parent
[
0
])
{
forEach
(
element
,
function
(
node
)
{
parent
=
after
.
parent
();
parentNode
.
insertBefore
(
node
,
afterNextSibling
);
}
});
parent
.
append
(
element
);
}
done
&&
$timeout
(
done
,
0
,
false
);
done
&&
$timeout
(
done
,
0
,
false
);
},
},
...
@@ -5260,6 +5278,24 @@ function $CompileProvider($provide) {
...
@@ -5260,6 +5278,24 @@ function $CompileProvider($provide) {
}
}
},
},
/**
* @ngdoc function
* @name ng.$compile.directive.Attributes#$updateClass
* @methodOf ng.$compile.directive.Attributes
* @function
*
* @description
* Adds and removes the appropriate CSS class values to the element based on the difference
* between the new and old CSS class values (specified as newClasses and oldClasses).
*
* @param {string} newClasses The current CSS className value
* @param {string} oldClasses The former CSS className value
*/
$updateClass
:
function
(
newClasses
,
oldClasses
)
{
this
.
$removeClass
(
tokenDifference
(
oldClasses
,
newClasses
));
this
.
$addClass
(
tokenDifference
(
newClasses
,
oldClasses
));
},
/**
/**
* Set a normalized attribute on the element in a way such that all directives
* Set a normalized attribute on the element in a way such that all directives
* can share the attribute. This function properly handles boolean attributes.
* can share the attribute. This function properly handles boolean attributes.
...
@@ -5270,59 +5306,53 @@ function $CompileProvider($provide) {
...
@@ -5270,59 +5306,53 @@ function $CompileProvider($provide) {
* @param {string=} attrName Optional none normalized name. Defaults to key.
* @param {string=} attrName Optional none normalized name. Defaults to key.
*/
*/
$set
:
function
(
key
,
value
,
writeAttr
,
attrName
)
{
$set
:
function
(
key
,
value
,
writeAttr
,
attrName
)
{
//special case for class attribute addition + removal
// TODO: decide whether or not to throw an error if "class"
//so that class changes can tap into the animation
//is set through this function since it may cause $updateClass to
//hooks provided by the $animate service
//become unstable.
if
(
key
==
'
class
'
)
{
value
=
value
||
''
;
var
current
=
this
.
$$element
.
attr
(
'
class
'
)
||
''
;
this
.
$removeClass
(
tokenDifference
(
current
,
value
).
join
(
'
'
));
this
.
$addClass
(
tokenDifference
(
value
,
current
).
join
(
'
'
));
}
else
{
var
booleanKey
=
getBooleanAttrName
(
this
.
$$element
[
0
],
key
),
normalizedVal
,
nodeName
;
if
(
booleanKey
)
{
var
booleanKey
=
getBooleanAttrName
(
this
.
$$element
[
0
],
key
),
this
.
$$element
.
prop
(
key
,
value
);
normalizedVal
,
attrName
=
booleanKey
;
nodeName
;
}
this
[
key
]
=
value
;
if
(
booleanKey
)
{
this
.
$$element
.
prop
(
key
,
value
);
attrName
=
booleanKey
;
}
// translate normalized key to actual key
this
[
key
]
=
value
;
if
(
attrName
)
{
this
.
$attr
[
key
]
=
attrName
;
// translate normalized key to actual key
}
else
{
if
(
attrName
)
{
attrName
=
this
.
$attr
[
key
];
this
.
$attr
[
key
]
=
attrName
;
if
(
!
attrName
)
{
}
else
{
this
.
$attr
[
key
]
=
attrName
=
snake_case
(
key
,
'
-
'
);
attrName
=
this
.
$attr
[
key
];
}
if
(
!
attrName
)
{
this
.
$attr
[
key
]
=
attrName
=
snake_case
(
key
,
'
-
'
);
}
}
}
nodeName
=
nodeName_
(
this
.
$$element
);
nodeName
=
nodeName_
(
this
.
$$element
);
// sanitize a[href] and img[src] values
// sanitize a[href] and img[src] values
if
((
nodeName
===
'
A
'
&&
key
===
'
href
'
)
||
if
((
nodeName
===
'
A
'
&&
key
===
'
href
'
)
||
(
nodeName
===
'
IMG
'
&&
key
===
'
src
'
))
{
(
nodeName
===
'
IMG
'
&&
key
===
'
src
'
))
{
// NOTE: urlResolve() doesn't support IE < 8 so we don't sanitize for that case.
// NOTE: urlResolve() doesn't support IE < 8 so we don't sanitize for that case.
if
(
!
msie
||
msie
>=
8
)
{
if
(
!
msie
||
msie
>=
8
)
{
normalizedVal
=
urlResolve
(
value
).
href
;
normalizedVal
=
urlResolve
(
value
).
href
;
if
(
normalizedVal
!==
''
)
{
if
(
normalizedVal
!==
''
)
{
if
((
key
===
'
href
'
&&
!
normalizedVal
.
match
(
aHrefSanitizationWhitelist
))
||
if
((
key
===
'
href
'
&&
!
normalizedVal
.
match
(
aHrefSanitizationWhitelist
))
||
(
key
===
'
src
'
&&
!
normalizedVal
.
match
(
imgSrcSanitizationWhitelist
)))
{
(
key
===
'
src
'
&&
!
normalizedVal
.
match
(
imgSrcSanitizationWhitelist
)))
{
this
[
key
]
=
value
=
'
unsafe:
'
+
normalizedVal
;
this
[
key
]
=
value
=
'
unsafe:
'
+
normalizedVal
;
}
}
}
}
}
}
}
}
if
(
writeAttr
!==
false
)
{
if
(
writeAttr
!==
false
)
{
if
(
value
===
null
||
value
===
undefined
)
{
if
(
value
===
null
||
value
===
undefined
)
{
this
.
$$element
.
removeAttr
(
attrName
);
this
.
$$element
.
removeAttr
(
attrName
);
}
else
{
}
else
{
this
.
$$element
.
attr
(
attrName
,
value
);
this
.
$$element
.
attr
(
attrName
,
value
);
}
}
}
}
}
...
@@ -5335,22 +5365,6 @@ function $CompileProvider($provide) {
...
@@ -5335,22 +5365,6 @@ function $CompileProvider($provide) {
$exceptionHandler
(
e
);
$exceptionHandler
(
e
);
}
}
});
});
function
tokenDifference
(
str1
,
str2
)
{
var
values
=
[],
tokens1
=
str1
.
split
(
/
\s
+/
),
tokens2
=
str2
.
split
(
/
\s
+/
);
outer
:
for
(
var
i
=
0
;
i
<
tokens1
.
length
;
i
++
)
{
var
token
=
tokens1
[
i
];
for
(
var
j
=
0
;
j
<
tokens2
.
length
;
j
++
)
{
if
(
token
==
tokens2
[
j
])
continue
outer
;
}
values
.
push
(
token
);
}
return
values
;
}
},
},
...
@@ -6372,10 +6386,15 @@ function $CompileProvider($provide) {
...
@@ -6372,10 +6386,15 @@ function $CompileProvider($provide) {
function
getTrustedContext
(
node
,
attrNormalizedName
)
{
function
getTrustedContext
(
node
,
attrNormalizedName
)
{
if
(
attrNormalizedName
==
"
srcdoc
"
)
{
return
$sce
.
HTML
;
}
var
tag
=
nodeName_
(
node
);
// maction[xlink:href] can source SVG. It's not limited to <maction>.
// maction[xlink:href] can source SVG. It's not limited to <maction>.
if
(
attrNormalizedName
==
"
xlinkHref
"
||
if
(
attrNormalizedName
==
"
xlinkHref
"
||
(
nodeName_
(
node
)
!=
"
IMG
"
&&
(
attrNormalizedName
==
"
src
"
||
(
tag
==
"
FORM
"
&&
attrNormalizedName
==
"
action
"
)
||
attrNormalizedName
==
"
ngSrc
"
)))
{
(
tag
!=
"
IMG
"
&&
(
attrNormalizedName
==
"
src
"
||
attrNormalizedName
==
"
ngSrc
"
)))
{
return
$sce
.
RESOURCE_URL
;
return
$sce
.
RESOURCE_URL
;
}
}
}
}
...
@@ -6420,9 +6439,19 @@ function $CompileProvider($provide) {
...
@@ -6420,9 +6439,19 @@ function $CompileProvider($provide) {
attr
[
name
]
=
interpolateFn
(
scope
);
attr
[
name
]
=
interpolateFn
(
scope
);
(
$$observers
[
name
]
||
(
$$observers
[
name
]
=
[])).
$$inter
=
true
;
(
$$observers
[
name
]
||
(
$$observers
[
name
]
=
[])).
$$inter
=
true
;
(
attr
.
$$observers
&&
attr
.
$$observers
[
name
].
$$scope
||
scope
).
(
attr
.
$$observers
&&
attr
.
$$observers
[
name
].
$$scope
||
scope
).
$watch
(
interpolateFn
,
function
interpolateFnWatchAction
(
value
)
{
$watch
(
interpolateFn
,
function
interpolateFnWatchAction
(
newValue
,
oldValue
)
{
attr
.
$set
(
name
,
value
);
//special case for class attribute addition + removal
});
//so that class changes can tap into the animation
//hooks provided by the $animate service. Be sure to
//skip animations when the first digest occurs (when
//both the new and the old values are the same) since
//the CSS classes are the non-interpolated values
if
(
name
===
'
class
'
&&
newValue
!=
oldValue
)
{
attr
.
$updateClass
(
newValue
,
oldValue
);
}
else
{
attr
.
$set
(
name
,
newValue
);
}
});
}
}
};
};
}
}
...
@@ -6563,6 +6592,22 @@ function directiveLinkingFn(
...
@@ -6563,6 +6592,22 @@ function directiveLinkingFn(
/* function(Function) */
boundTranscludeFn
/* function(Function) */
boundTranscludeFn
){}
){}
function
tokenDifference
(
str1
,
str2
)
{
var
values
=
''
,
tokens1
=
str1
.
split
(
/
\s
+/
),
tokens2
=
str2
.
split
(
/
\s
+/
);
outer
:
for
(
var
i
=
0
;
i
<
tokens1
.
length
;
i
++
)
{
var
token
=
tokens1
[
i
];
for
(
var
j
=
0
;
j
<
tokens2
.
length
;
j
++
)
{
if
(
token
==
tokens2
[
j
])
continue
outer
;
}
values
+=
(
values
.
length
>
0
?
'
'
:
''
)
+
token
;
}
return
values
;
}
/**
/**
* @ngdoc object
* @ngdoc object
* @name ng.$controllerProvider
* @name ng.$controllerProvider
...
@@ -7779,6 +7824,8 @@ function $HttpBackendProvider() {
...
@@ -7779,6 +7824,8 @@ function $HttpBackendProvider() {
}
}
function
createHttpBackend
(
$browser
,
XHR
,
$browserDefer
,
callbacks
,
rawDocument
,
locationProtocol
)
{
function
createHttpBackend
(
$browser
,
XHR
,
$browserDefer
,
callbacks
,
rawDocument
,
locationProtocol
)
{
var
ABORTED
=
-
1
;
// TODO(vojta): fix the signature
// TODO(vojta): fix the signature
return
function
(
method
,
url
,
post
,
callback
,
headers
,
timeout
,
withCredentials
,
responseType
)
{
return
function
(
method
,
url
,
post
,
callback
,
headers
,
timeout
,
withCredentials
,
responseType
)
{
var
status
;
var
status
;
...
@@ -7814,13 +7861,19 @@ function createHttpBackend($browser, XHR, $browserDefer, callbacks, rawDocument,
...
@@ -7814,13 +7861,19 @@ function createHttpBackend($browser, XHR, $browserDefer, callbacks, rawDocument,
// always async
// always async
xhr
.
onreadystatechange
=
function
()
{
xhr
.
onreadystatechange
=
function
()
{
if
(
xhr
.
readyState
==
4
)
{
if
(
xhr
.
readyState
==
4
)
{
var
responseHeaders
=
xhr
.
getAllResponseHeaders
();
var
responseHeaders
=
null
,
response
=
null
;
if
(
status
!==
ABORTED
)
{
responseHeaders
=
xhr
.
getAllResponseHeaders
();
response
=
xhr
.
responseType
?
xhr
.
response
:
xhr
.
responseText
;
}
// responseText is the old-school way of retrieving response (supported by IE8 & 9)
// responseText is the old-school way of retrieving response (supported by IE8 & 9)
// response/responseType properties were introduced in XHR Level2 spec (supported by IE10)
// response/responseType properties were introduced in XHR Level2 spec (supported by IE10)
completeRequest
(
callback
,
completeRequest
(
callback
,
status
||
xhr
.
status
,
status
||
xhr
.
status
,
(
xhr
.
responseType
?
xhr
.
response
:
xhr
.
responseText
)
,
response
,
responseHeaders
);
responseHeaders
);
}
}
};
};
...
@@ -7844,7 +7897,7 @@ function createHttpBackend($browser, XHR, $browserDefer, callbacks, rawDocument,
...
@@ -7844,7 +7897,7 @@ function createHttpBackend($browser, XHR, $browserDefer, callbacks, rawDocument,
function
timeoutRequest
()
{
function
timeoutRequest
()
{
status
=
-
1
;
status
=
ABORTED
;
jsonpDone
&&
jsonpDone
();
jsonpDone
&&
jsonpDone
();
xhr
&&
xhr
.
abort
();
xhr
&&
xhr
.
abort
();
}
}
...
@@ -7873,6 +7926,7 @@ function createHttpBackend($browser, XHR, $browserDefer, callbacks, rawDocument,
...
@@ -7873,6 +7926,7 @@ function createHttpBackend($browser, XHR, $browserDefer, callbacks, rawDocument,
// - adds and immediately removes script elements from the document
// - adds and immediately removes script elements from the document
var
script
=
rawDocument
.
createElement
(
'
script
'
),
var
script
=
rawDocument
.
createElement
(
'
script
'
),
doneWrapper
=
function
()
{
doneWrapper
=
function
()
{
script
.
onreadystatechange
=
script
.
onload
=
script
.
onerror
=
null
;
rawDocument
.
body
.
removeChild
(
script
);
rawDocument
.
body
.
removeChild
(
script
);
if
(
done
)
done
();
if
(
done
)
done
();
};
};
...
@@ -7880,12 +7934,16 @@ function createHttpBackend($browser, XHR, $browserDefer, callbacks, rawDocument,
...
@@ -7880,12 +7934,16 @@ function createHttpBackend($browser, XHR, $browserDefer, callbacks, rawDocument,
script
.
type
=
'
text/javascript
'
;
script
.
type
=
'
text/javascript
'
;
script
.
src
=
url
;
script
.
src
=
url
;
if
(
msie
)
{
if
(
msie
&&
msie
<=
8
)
{
script
.
onreadystatechange
=
function
()
{
script
.
onreadystatechange
=
function
()
{
if
(
/loaded|complete/
.
test
(
script
.
readyState
))
doneWrapper
();
if
(
/loaded|complete/
.
test
(
script
.
readyState
))
{
doneWrapper
();
}
};
};
}
else
{
}
else
{
script
.
onload
=
script
.
onerror
=
doneWrapper
;
script
.
onload
=
script
.
onerror
=
function
()
{
doneWrapper
();
};
}
}
rawDocument
.
body
.
appendChild
(
script
);
rawDocument
.
body
.
appendChild
(
script
);
...
@@ -8962,7 +9020,7 @@ function $LocationProvider(){
...
@@ -8962,7 +9020,7 @@ function $LocationProvider(){
*
*
* The main purpose of this service is to simplify debugging and troubleshooting.
* The main purpose of this service is to simplify debugging and troubleshooting.
*
*
* The default is
not
to log `debug` messages. You can use
* The default is to log `debug` messages. You can use
* {@link ng.$logProvider ng.$logProvider#debugEnabled} to change this.
* {@link ng.$logProvider ng.$logProvider#debugEnabled} to change this.
*
*
* @example
* @example
...
@@ -10128,7 +10186,7 @@ function getterFn(path, options, fullExp) {
...
@@ -10128,7 +10186,7 @@ function getterFn(path, options, fullExp) {
:
'
((k&&k.hasOwnProperty("
'
+
key
+
'
"))?k:s)
'
)
+
'
["
'
+
key
+
'
"]
'
+
'
;
\n
'
+
:
'
((k&&k.hasOwnProperty("
'
+
key
+
'
"))?k:s)
'
)
+
'
["
'
+
key
+
'
"]
'
+
'
;
\n
'
+
(
options
.
unwrapPromises
(
options
.
unwrapPromises
?
'
if (s && s.then) {
\n
'
+
?
'
if (s && s.then) {
\n
'
+
'
pw("
'
+
fullExp
.
replace
(
/
\"
/g
,
'
\\
"
'
)
+
'
");
\n
'
+
'
pw("
'
+
fullExp
.
replace
(
/
([
"
\r\n])
/g
,
'
\\
$1
'
)
+
'
");
\n
'
+
'
if (!("$$v" in s)) {
\n
'
+
'
if (!("$$v" in s)) {
\n
'
+
'
p=s;
\n
'
+
'
p=s;
\n
'
+
'
p.$$v = undefined;
\n
'
+
'
p.$$v = undefined;
\n
'
+
...
@@ -12098,8 +12156,7 @@ function $SceDelegateProvider() {
...
@@ -12098,8 +12156,7 @@ function $SceDelegateProvider() {
return
resourceUrlBlacklist
;
return
resourceUrlBlacklist
;
};
};
this
.
$get
=
[
'
$log
'
,
'
$document
'
,
'
$injector
'
,
function
(
this
.
$get
=
[
'
$injector
'
,
function
(
$injector
)
{
$log
,
$document
,
$injector
)
{
var
htmlSanitizer
=
function
htmlSanitizer
(
html
)
{
var
htmlSanitizer
=
function
htmlSanitizer
(
html
)
{
throw
$sceMinErr
(
'
unsafe
'
,
'
Attempting to use an unsafe value in a safe context.
'
);
throw
$sceMinErr
(
'
unsafe
'
,
'
Attempting to use an unsafe value in a safe context.
'
);
...
@@ -12630,18 +12687,15 @@ function $SceProvider() {
...
@@ -12630,18 +12687,15 @@ function $SceProvider() {
* sce.js and sceSpecs.js would need to be aware of this detail.
* sce.js and sceSpecs.js would need to be aware of this detail.
*/
*/
this
.
$get
=
[
'
$parse
'
,
'
$
document
'
,
'
$sceDelegate
'
,
function
(
this
.
$get
=
[
'
$parse
'
,
'
$
sniffer
'
,
'
$sceDelegate
'
,
function
(
$parse
,
$
document
,
$sceDelegate
)
{
$parse
,
$
sniffer
,
$sceDelegate
)
{
// Prereq: Ensure that we're not running in IE8 quirks mode. In that mode, IE allows
// Prereq: Ensure that we're not running in IE8 quirks mode. In that mode, IE allows
// the "expression(javascript expression)" syntax which is insecure.
// the "expression(javascript expression)" syntax which is insecure.
if
(
enabled
&&
msie
)
{
if
(
enabled
&&
$sniffer
.
msie
&&
$sniffer
.
msieDocumentMode
<
8
)
{
var
documentMode
=
$document
[
0
].
documentMode
;
throw
$sceMinErr
(
'
iequirks
'
,
if
(
documentMode
!==
undefined
&&
documentMode
<
8
)
{
'
Strict Contextual Escaping does not support Internet Explorer version < 9 in quirks
'
+
throw
$sceMinErr
(
'
iequirks
'
,
'
mode. You can fix this by adding the text <!doctype html> to the top of your HTML
'
+
'
Strict Contextual Escaping does not support Internet Explorer version < 9 in quirks
'
+
'
document. See http://docs.angularjs.org/api/ng.$sce for more information.
'
);
'
mode. You can fix this by adding the text <!doctype html> to the top of your HTML
'
+
'
document. See http://docs.angularjs.org/api/ng.$sce for more information.
'
);
}
}
}
var
sce
=
copy
(
SCE_CONTEXTS
);
var
sce
=
copy
(
SCE_CONTEXTS
);
...
@@ -13003,6 +13057,7 @@ function $SnifferProvider() {
...
@@ -13003,6 +13057,7 @@ function $SnifferProvider() {
int
((
/android
(\d
+
)
/
.
exec
(
lowercase
((
$window
.
navigator
||
{}).
userAgent
))
||
[])[
1
]),
int
((
/android
(\d
+
)
/
.
exec
(
lowercase
((
$window
.
navigator
||
{}).
userAgent
))
||
[])[
1
]),
boxee
=
/Boxee/i
.
test
((
$window
.
navigator
||
{}).
userAgent
),
boxee
=
/Boxee/i
.
test
((
$window
.
navigator
||
{}).
userAgent
),
document
=
$document
[
0
]
||
{},
document
=
$document
[
0
]
||
{},
documentMode
=
document
.
documentMode
,
vendorPrefix
,
vendorPrefix
,
vendorRegex
=
/^
(
Moz|webkit|O|ms
)(?=[
A-Z
])
/
,
vendorRegex
=
/^
(
Moz|webkit|O|ms
)(?=[
A-Z
])
/
,
bodyStyle
=
document
.
body
&&
document
.
body
.
style
,
bodyStyle
=
document
.
body
&&
document
.
body
.
style
,
...
@@ -13047,7 +13102,7 @@ function $SnifferProvider() {
...
@@ -13047,7 +13102,7 @@ function $SnifferProvider() {
// jshint +W018
// jshint +W018
hashchange
:
'
onhashchange
'
in
$window
&&
hashchange
:
'
onhashchange
'
in
$window
&&
// IE8 compatible mode lies
// IE8 compatible mode lies
(
!
document
.
documentMode
||
document
.
documentMode
>
7
),
(
!
document
Mode
||
documentMode
>
7
),
hasEvent
:
function
(
event
)
{
hasEvent
:
function
(
event
)
{
// IE9 implements 'input' event it's so fubared that we rather pretend that it doesn't have
// IE9 implements 'input' event it's so fubared that we rather pretend that it doesn't have
// it. In particular the event is not fired when backspace or delete key are pressed or
// it. In particular the event is not fired when backspace or delete key are pressed or
...
@@ -13065,7 +13120,8 @@ function $SnifferProvider() {
...
@@ -13065,7 +13120,8 @@ function $SnifferProvider() {
vendorPrefix
:
vendorPrefix
,
vendorPrefix
:
vendorPrefix
,
transitions
:
transitions
,
transitions
:
transitions
,
animations
:
animations
,
animations
:
animations
,
msie
:
msie
msie
:
msie
,
msieDocumentMode
:
documentMode
};
};
}];
}];
}
}
...
@@ -14680,8 +14736,11 @@ var htmlAnchorDirective = valueFn({
...
@@ -14680,8 +14736,11 @@ var htmlAnchorDirective = valueFn({
*
*
* The HTML specification does not require browsers to preserve the values of boolean attributes
* The HTML specification does not require browsers to preserve the values of boolean attributes
* such as disabled. (Their presence means true and their absence means false.)
* such as disabled. (Their presence means true and their absence means false.)
* This prevents the Angular compiler from retrieving the binding expression.
* If we put an Angular interpolation expression into such an attribute then the
* binding information would be lost when the browser removes the attribute.
* The `ngDisabled` directive solves this problem for the `disabled` attribute.
* The `ngDisabled` directive solves this problem for the `disabled` attribute.
* This complementary directive is not removed by the browser and so provides
* a permanent reliable place to store the binding information.
*
*
* @example
* @example
<doc:example>
<doc:example>
...
@@ -14712,8 +14771,11 @@ var htmlAnchorDirective = valueFn({
...
@@ -14712,8 +14771,11 @@ var htmlAnchorDirective = valueFn({
* @description
* @description
* The HTML specification does not require browsers to preserve the values of boolean attributes
* The HTML specification does not require browsers to preserve the values of boolean attributes
* such as checked. (Their presence means true and their absence means false.)
* such as checked. (Their presence means true and their absence means false.)
* This prevents the Angular compiler from retrieving the binding expression.
* If we put an Angular interpolation expression into such an attribute then the
* binding information would be lost when the browser removes the attribute.
* The `ngChecked` directive solves this problem for the `checked` attribute.
* The `ngChecked` directive solves this problem for the `checked` attribute.
* This complementary directive is not removed by the browser and so provides
* a permanent reliable place to store the binding information.
* @example
* @example
<doc:example>
<doc:example>
<doc:source>
<doc:source>
...
@@ -14743,8 +14805,12 @@ var htmlAnchorDirective = valueFn({
...
@@ -14743,8 +14805,12 @@ var htmlAnchorDirective = valueFn({
* @description
* @description
* The HTML specification does not require browsers to preserve the values of boolean attributes
* The HTML specification does not require browsers to preserve the values of boolean attributes
* such as readonly. (Their presence means true and their absence means false.)
* such as readonly. (Their presence means true and their absence means false.)
* This prevents the Angular compiler from retrieving the binding expression.
* If we put an Angular interpolation expression into such an attribute then the
* binding information would be lost when the browser removes the attribute.
* The `ngReadonly` directive solves this problem for the `readonly` attribute.
* The `ngReadonly` directive solves this problem for the `readonly` attribute.
* This complementary directive is not removed by the browser and so provides
* a permanent reliable place to store the binding information.
* @example
* @example
<doc:example>
<doc:example>
<doc:source>
<doc:source>
...
@@ -14774,8 +14840,11 @@ var htmlAnchorDirective = valueFn({
...
@@ -14774,8 +14840,11 @@ var htmlAnchorDirective = valueFn({
* @description
* @description
* The HTML specification does not require browsers to preserve the values of boolean attributes
* The HTML specification does not require browsers to preserve the values of boolean attributes
* such as selected. (Their presence means true and their absence means false.)
* such as selected. (Their presence means true and their absence means false.)
* This prevents the Angular compiler from retrieving the binding expression.
* If we put an Angular interpolation expression into such an attribute then the
* binding information would be lost when the browser removes the attribute.
* The `ngSelected` directive solves this problem for the `selected` atttribute.
* The `ngSelected` directive solves this problem for the `selected` atttribute.
* This complementary directive is not removed by the browser and so provides
* a permanent reliable place to store the binding information.
* @example
* @example
<doc:example>
<doc:example>
<doc:source>
<doc:source>
...
@@ -14807,8 +14876,12 @@ var htmlAnchorDirective = valueFn({
...
@@ -14807,8 +14876,12 @@ var htmlAnchorDirective = valueFn({
* @description
* @description
* The HTML specification does not require browsers to preserve the values of boolean attributes
* The HTML specification does not require browsers to preserve the values of boolean attributes
* such as open. (Their presence means true and their absence means false.)
* such as open. (Their presence means true and their absence means false.)
* This prevents the Angular compiler from retrieving the binding expression.
* If we put an Angular interpolation expression into such an attribute then the
* binding information would be lost when the browser removes the attribute.
* The `ngOpen` directive solves this problem for the `open` attribute.
* The `ngOpen` directive solves this problem for the `open` attribute.
* This complementary directive is not removed by the browser and so provides
* a permanent reliable place to store the binding information.
*
*
* @example
* @example
<doc:example>
<doc:example>
...
@@ -15638,8 +15711,21 @@ var inputType = {
...
@@ -15638,8 +15711,21 @@ var inputType = {
function
textInputType
(
scope
,
element
,
attr
,
ctrl
,
$sniffer
,
$browser
)
{
function
textInputType
(
scope
,
element
,
attr
,
ctrl
,
$sniffer
,
$browser
)
{
// In composition mode, users are still inputing intermediate text buffer,
// hold the listener until composition is done.
// More about composition events: https://developer.mozilla.org/en-US/docs/Web/API/CompositionEvent
var
composing
=
false
;
element
.
on
(
'
compositionstart
'
,
function
()
{
composing
=
true
;
});
element
.
on
(
'
compositionend
'
,
function
()
{
composing
=
false
;
});
var
listener
=
function
()
{
var
listener
=
function
()
{
if
(
composing
)
return
;
var
value
=
element
.
val
();
var
value
=
element
.
val
();
// By default we will trim the value
// By default we will trim the value
...
@@ -16929,11 +17015,10 @@ function classDirective(name, selector) {
...
@@ -16929,11 +17015,10 @@ function classDirective(name, selector) {
// jshint bitwise: false
// jshint bitwise: false
var
mod
=
$index
&
1
;
var
mod
=
$index
&
1
;
if
(
mod
!==
old$index
&
1
)
{
if
(
mod
!==
old$index
&
1
)
{
if
(
mod
===
selector
)
{
var
classes
=
flattenClasses
(
scope
.
$eval
(
attr
[
name
]));
addClass
(
scope
.
$eval
(
attr
[
name
]));
mod
===
selector
?
}
else
{
attr
.
$addClass
(
classes
)
:
removeClass
(
scope
.
$eval
(
attr
[
name
]));
attr
.
$removeClass
(
classes
);
}
}
}
});
});
}
}
...
@@ -16941,24 +17026,17 @@ function classDirective(name, selector) {
...
@@ -16941,24 +17026,17 @@ function classDirective(name, selector) {
function
ngClassWatchAction
(
newVal
)
{
function
ngClassWatchAction
(
newVal
)
{
if
(
selector
===
true
||
scope
.
$index
%
2
===
selector
)
{
if
(
selector
===
true
||
scope
.
$index
%
2
===
selector
)
{
if
(
oldVal
&&
!
equals
(
newVal
,
oldVal
))
{
var
newClasses
=
flattenClasses
(
newVal
||
''
);
removeClass
(
oldVal
);
if
(
!
oldVal
)
{
attr
.
$addClass
(
newClasses
);
}
else
if
(
!
equals
(
newVal
,
oldVal
))
{
attr
.
$updateClass
(
newClasses
,
flattenClasses
(
oldVal
));
}
}
addClass
(
newVal
);
}
}
oldVal
=
copy
(
newVal
);
oldVal
=
copy
(
newVal
);
}
}
function
removeClass
(
classVal
)
{
attr
.
$removeClass
(
flattenClasses
(
classVal
));
}
function
addClass
(
classVal
)
{
attr
.
$addClass
(
flattenClasses
(
classVal
));
}
function
flattenClasses
(
classVal
)
{
function
flattenClasses
(
classVal
)
{
if
(
isArray
(
classVal
))
{
if
(
isArray
(
classVal
))
{
return
classVal
.
join
(
'
'
);
return
classVal
.
join
(
'
'
);
...
@@ -17436,7 +17514,8 @@ var ngCloakDirective = ngDirective({
...
@@ -17436,7 +17514,8 @@ var ngCloakDirective = ngDirective({
var
ngControllerDirective
=
[
function
()
{
var
ngControllerDirective
=
[
function
()
{
return
{
return
{
scope
:
true
,
scope
:
true
,
controller
:
'
@
'
controller
:
'
@
'
,
priority
:
500
};
};
}];
}];
...
@@ -18132,18 +18211,23 @@ var ngIncludeDirective = ['$http', '$templateCache', '$anchorScroll', '$compile'
...
@@ -18132,18 +18211,23 @@ var ngIncludeDirective = ['$http', '$templateCache', '$anchorScroll', '$compile'
if
(
thisChangeId
!==
changeCounter
)
return
;
if
(
thisChangeId
!==
changeCounter
)
return
;
var
newScope
=
scope
.
$new
();
var
newScope
=
scope
.
$new
();
$transclude
(
newScope
,
function
(
clone
)
{
// Note: This will also link all children of ng-include that were contained in the original
cleanupLastIncludeContent
();
// html. If that content contains controllers, ... they could pollute/change the scope.
// However, using ng-include on an element with additional content does not make sense...
currentScope
=
newScope
;
// Note: We can't remove them in the cloneAttchFn of $transclude as that
currentElement
=
clone
;
// function is called before linking the content, which would apply child
// directives to non existing elements.
currentElement
.
html
(
response
);
var
clone
=
$transclude
(
newScope
,
noop
);
$animate
.
enter
(
currentElement
,
null
,
$element
,
afterAnimation
);
cleanupLastIncludeContent
();
$compile
(
currentElement
.
contents
())(
currentScope
);
currentScope
.
$emit
(
'
$includeContentLoaded
'
);
currentScope
=
newScope
;
scope
.
$eval
(
onloadExp
);
currentElement
=
clone
;
});
currentElement
.
html
(
response
);
$animate
.
enter
(
currentElement
,
null
,
$element
,
afterAnimation
);
$compile
(
currentElement
.
contents
())(
currentScope
);
currentScope
.
$emit
(
'
$includeContentLoaded
'
);
scope
.
$eval
(
onloadExp
);
}).
error
(
function
()
{
}).
error
(
function
()
{
if
(
thisChangeId
===
changeCounter
)
cleanupLastIncludeContent
();
if
(
thisChangeId
===
changeCounter
)
cleanupLastIncludeContent
();
});
});
...
@@ -18298,7 +18382,7 @@ var ngNonBindableDirective = ngDirective({ terminal: true, priority: 1000 });
...
@@ -18298,7 +18382,7 @@ var ngNonBindableDirective = ngDirective({ terminal: true, priority: 1000 });
* other numbers, for example 12, so that instead of showing "12 people are viewing", you can
* other numbers, for example 12, so that instead of showing "12 people are viewing", you can
* show "a dozen people are viewing".
* show "a dozen people are viewing".
*
*
* You can use a set of closed braces(`{}`) as a placeholder for the number that you want substituted
* You can use a set of closed braces
(`{}`) as a placeholder for the number that you want substituted
* into pluralized strings. In the previous example, Angular will replace `{}` with
* into pluralized strings. In the previous example, Angular will replace `{}` with
* <span ng-non-bindable>`{{personCount}}`</span>. The closed braces `{}` is a placeholder
* <span ng-non-bindable>`{{personCount}}`</span>. The closed braces `{}` is a placeholder
* for <span ng-non-bindable>{{numberExpression}}</span>.
* for <span ng-non-bindable>{{numberExpression}}</span>.
...
@@ -18559,7 +18643,7 @@ var ngPluralizeDirective = ['$locale', '$interpolate', function($locale, $interp
...
@@ -18559,7 +18643,7 @@ var ngPluralizeDirective = ['$locale', '$interpolate', function($locale, $interp
* For example: `item in items track by $id(item)`. A built in `$id()` function can be used to assign a unique
* For example: `item in items track by $id(item)`. A built in `$id()` function can be used to assign a unique
* `$$hashKey` property to each item in the array. This property is then used as a key to associated DOM elements
* `$$hashKey` property to each item in the array. This property is then used as a key to associated DOM elements
* with the corresponding item in the array by identity. Moving the same object in array would move the DOM
* with the corresponding item in the array by identity. Moving the same object in array would move the DOM
* element in the same way i
a
n the DOM.
* element in the same way in the DOM.
*
*
* For example: `item in items track by item.id` is a typical pattern when the items come from the database. In this
* For example: `item in items track by item.id` is a typical pattern when the items come from the database. In this
* case the object identity does not matter. Two objects are considered equivalent as long as their `id`
* case the object identity does not matter. Two objects are considered equivalent as long as their `id`
...
@@ -20128,4 +20212,4 @@ var styleDirective = valueFn({
...
@@ -20128,4 +20212,4 @@ var styleDirective = valueFn({
})(
window
,
document
);
})(
window
,
document
);
!
angular
.
$$csp
()
&&
angular
.
element
(
document
).
find
(
'
head
'
).
prepend
(
'
<style type="text/css">@charset "UTF-8";[ng
\\
:cloak],[ng-cloak],[data-ng-cloak],[x-ng-cloak],.ng-cloak,.x-ng-cloak,.ng-hide{display:none !important;}ng
\\
:form{display:block;}.ng-animate-start{clip:rect(0,auto,auto,0);-ms-zoom:1.0001;}.ng-animate-active{clip:rect(-1px,auto,auto,0);-ms-zoom:1;}</style>
'
);
!
angular
.
$$csp
()
&&
angular
.
element
(
document
).
find
(
'
head
'
).
prepend
(
'
<style type="text/css">@charset "UTF-8";[ng
\\
:cloak],[ng-cloak],[data-ng-cloak],[x-ng-cloak],.ng-cloak,.x-ng-cloak,.ng-hide{display:none !important;}ng
\\
:form{display:block;}.ng-animate-start{border-spacing:1px 1px;-ms-zoom:1.0001;}.ng-animate-active{border-spacing:0px 0px;-ms-zoom:1;}</style>
'
);
\ No newline at end of file
\ No newline at end of file
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment