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
* License: MIT
*/
...
...
@@ -68,7 +68,7 @@ function minErr(module) {
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
;
for
(
i
=
2
;
i
<
arguments
.
length
;
i
++
)
{
message
=
message
+
(
i
==
2
?
'
?
'
:
'
&
'
)
+
'
p
'
+
(
i
-
2
)
+
'
=
'
+
...
...
@@ -159,7 +159,7 @@ function minErr(module) {
-assertArgFn,
-assertNotHasOwnProperty,
-getter,
-getBlockElements
-getBlockElements
,
*/
...
...
@@ -1181,26 +1181,38 @@ function encodeUriQuery(val, pctEncodeSpaces) {
*
* @description
*
* Use this directive to auto-bootstrap an application. Only
* one ngApp directive can be used per HTML document. The directive
* designates the root of the application and is typically placed
* at the root of the page.
*
* The first ngApp found in the document will be auto-bootstrapped. To use multiple applications in
* an HTML document you must manually bootstrap them using {@link angular.bootstrap}.
* Applications cannot be nested.
*
* In the example below if the `ngApp` directive were not placed
* on the `html` element then the document would not be compiled
* and the `{{ 1+2 }}` would not be resolved to `3`.
*
* `ngApp` is the easiest way to bootstrap an application.
*
<doc:example>
<doc:source>
I can add: 1 + 2 = {{ 1+2 }}
</doc:source>
</doc:example>
* Use this directive to **auto-bootstrap** an AngularJS application. The `ngApp` directive
* designates the **root element** of the application and is typically placed near the root element
* of the page - e.g. on the `<body>` or `<html>` tags.
*
* Only one AngularJS application can be auto-bootstrapped per HTML document. The first `ngApp`
* found in the document will be used to define the root element to auto-bootstrap as an
* application. To run multiple applications in an HTML document you must manually bootstrap them using
* {@link angular.bootstrap} instead. AngularJS applications cannot be nested within each other.
*
* You can specify an **AngularJS module** to be used as the root module for the application. This
* module will be loaded into the {@link AUTO.$injector} when the application is bootstrapped and
* should contain the application code needed or have dependencies on other modules that will
* contain the code. See {@link angular.module} for more information.
*
* In the example below if the `ngApp` directive were not placed on the `html` element then the
* document would not be compiled, the `AppController` would not be instantiated and the `{{ a+b }}`
* would not be resolved to `3`.
*
* `ngApp` is the easiest, and most common, way to bootstrap an application.
*
<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
)
{
...
...
@@ -1435,7 +1447,12 @@ function setupModuleLoader(window) {
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>} */
var
modules
=
{};
...
...
@@ -1808,11 +1825,11 @@ function setupModuleLoader(window) {
* - `codeName` – `{string}` – Code name of the release, such as "jiggling-armfat".
*/
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
minor
:
2
,
dot
:
1
,
codeName
:
'
underscore-empathy
'
dot
:
2
,
codeName
:
'
consciousness-inertia
'
};
...
...
@@ -3359,11 +3376,11 @@ function annotate(fn) {
* @example
* Here are some examples of creating value services.
* <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;
* });
* </pre>
...
...
@@ -3849,13 +3866,14 @@ var $AnimateProvider = ['$provide', function($provide) {
* inserted into the DOM
*/
enter
:
function
(
element
,
parent
,
after
,
done
)
{
var
afterNode
=
after
&&
after
[
after
.
length
-
1
];
var
parentNode
=
parent
&&
parent
[
0
]
||
afterNode
&&
afterNode
.
parentNode
;
// IE does not like undefined so we have to pass null.
var
afterNextSibling
=
(
afterNode
&&
afterNode
.
nextSibling
)
||
null
;
forEach
(
element
,
function
(
node
)
{
parentNode
.
insertBefore
(
node
,
afterNextSibling
);
});
if
(
after
)
{
after
.
after
(
element
);
}
else
{
if
(
!
parent
||
!
parent
[
0
])
{
parent
=
after
.
parent
();
}
parent
.
append
(
element
);
}
done
&&
$timeout
(
done
,
0
,
false
);
},
...
...
@@ -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
* can share the attribute. This function properly handles boolean attributes.
...
...
@@ -5270,59 +5306,53 @@ function $CompileProvider($provide) {
* @param {string=} attrName Optional none normalized name. Defaults to key.
*/
$set
:
function
(
key
,
value
,
writeAttr
,
attrName
)
{
//special case for class attribute addition + removal
//so that class changes can tap into the animation
//hooks provided by the $animate service
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
;
// TODO: decide whether or not to throw an error if "class"
//is set through this function since it may cause $updateClass to
//become unstable.
if
(
booleanKey
)
{
this
.
$$element
.
prop
(
key
,
value
);
attrName
=
booleanKey
;
}
var
booleanKey
=
getBooleanAttrName
(
this
.
$$element
[
0
],
key
),
normalizedVal
,
nodeName
;
this
[
key
]
=
value
;
if
(
booleanKey
)
{
this
.
$$element
.
prop
(
key
,
value
);
attrName
=
booleanKey
;
}
// translate normalized key to actual key
if
(
attrName
)
{
this
.
$attr
[
key
]
=
attrName
;
}
else
{
attrName
=
this
.
$attr
[
key
];
if
(
!
attrName
)
{
this
.
$attr
[
key
]
=
attrName
=
snake_case
(
key
,
'
-
'
);
}
this
[
key
]
=
value
;
// translate normalized key to actual key
if
(
attrName
)
{
this
.
$attr
[
key
]
=
attrName
;
}
else
{
attrName
=
this
.
$attr
[
key
];
if
(
!
attrName
)
{
this
.
$attr
[
key
]
=
attrName
=
snake_case
(
key
,
'
-
'
);
}
}
nodeName
=
nodeName_
(
this
.
$$element
);
// sanitize a[href] and img[src] values
if
((
nodeName
===
'
A
'
&&
key
===
'
href
'
)
||
(
nodeName
===
'
IMG
'
&&
key
===
'
src
'
))
{
// NOTE: urlResolve() doesn't support IE < 8 so we don't sanitize for that case.
if
(
!
msie
||
msie
>=
8
)
{
normalizedVal
=
urlResolve
(
value
).
href
;
if
(
normalizedVal
!==
''
)
{
if
((
key
===
'
href
'
&&
!
normalizedVal
.
match
(
aHrefSanitizationWhitelist
))
||
(
key
===
'
src
'
&&
!
normalizedVal
.
match
(
imgSrcSanitizationWhitelist
)))
{
this
[
key
]
=
value
=
'
unsafe:
'
+
normalizedVal
;
}
nodeName
=
nodeName_
(
this
.
$$element
);
// sanitize a[href] and img[src] values
if
((
nodeName
===
'
A
'
&&
key
===
'
href
'
)
||
(
nodeName
===
'
IMG
'
&&
key
===
'
src
'
))
{
// NOTE: urlResolve() doesn't support IE < 8 so we don't sanitize for that case.
if
(
!
msie
||
msie
>=
8
)
{
normalizedVal
=
urlResolve
(
value
).
href
;
if
(
normalizedVal
!==
''
)
{
if
((
key
===
'
href
'
&&
!
normalizedVal
.
match
(
aHrefSanitizationWhitelist
))
||
(
key
===
'
src
'
&&
!
normalizedVal
.
match
(
imgSrcSanitizationWhitelist
)))
{
this
[
key
]
=
value
=
'
unsafe:
'
+
normalizedVal
;
}
}
}
}
if
(
writeAttr
!==
false
)
{
if
(
value
===
null
||
value
===
undefined
)
{
this
.
$$element
.
removeAttr
(
attrName
);
}
else
{
this
.
$$element
.
attr
(
attrName
,
value
);
}
if
(
writeAttr
!==
false
)
{
if
(
value
===
null
||
value
===
undefined
)
{
this
.
$$element
.
removeAttr
(
attrName
);
}
else
{
this
.
$$element
.
attr
(
attrName
,
value
);
}
}
...
...
@@ -5335,22 +5365,6 @@ function $CompileProvider($provide) {
$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) {
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>.
if
(
attrNormalizedName
==
"
xlinkHref
"
||
(
nodeName_
(
node
)
!=
"
IMG
"
&&
(
attrNormalizedName
==
"
src
"
||
attrNormalizedName
==
"
ngSrc
"
)))
{
(
tag
==
"
FORM
"
&&
attrNormalizedName
==
"
action
"
)
||
(
tag
!=
"
IMG
"
&&
(
attrNormalizedName
==
"
src
"
||
attrNormalizedName
==
"
ngSrc
"
)))
{
return
$sce
.
RESOURCE_URL
;
}
}
...
...
@@ -6420,9 +6439,19 @@ function $CompileProvider($provide) {
attr
[
name
]
=
interpolateFn
(
scope
);
(
$$observers
[
name
]
||
(
$$observers
[
name
]
=
[])).
$$inter
=
true
;
(
attr
.
$$observers
&&
attr
.
$$observers
[
name
].
$$scope
||
scope
).
$watch
(
interpolateFn
,
function
interpolateFnWatchAction
(
value
)
{
attr
.
$set
(
name
,
value
);
});
$watch
(
interpolateFn
,
function
interpolateFnWatchAction
(
newValue
,
oldValue
)
{
//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(
/* 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
* @name ng.$controllerProvider
...
...
@@ -7779,6 +7824,8 @@ function $HttpBackendProvider() {
}
function
createHttpBackend
(
$browser
,
XHR
,
$browserDefer
,
callbacks
,
rawDocument
,
locationProtocol
)
{
var
ABORTED
=
-
1
;
// TODO(vojta): fix the signature
return
function
(
method
,
url
,
post
,
callback
,
headers
,
timeout
,
withCredentials
,
responseType
)
{
var
status
;
...
...
@@ -7814,13 +7861,19 @@ function createHttpBackend($browser, XHR, $browserDefer, callbacks, rawDocument,
// always async
xhr
.
onreadystatechange
=
function
()
{
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)
// response/responseType properties were introduced in XHR Level2 spec (supported by IE10)
completeRequest
(
callback
,
status
||
xhr
.
status
,
(
xhr
.
responseType
?
xhr
.
response
:
xhr
.
responseText
)
,
response
,
responseHeaders
);
}
};
...
...
@@ -7844,7 +7897,7 @@ function createHttpBackend($browser, XHR, $browserDefer, callbacks, rawDocument,
function
timeoutRequest
()
{
status
=
-
1
;
status
=
ABORTED
;
jsonpDone
&&
jsonpDone
();
xhr
&&
xhr
.
abort
();
}
...
...
@@ -7873,6 +7926,7 @@ function createHttpBackend($browser, XHR, $browserDefer, callbacks, rawDocument,
// - adds and immediately removes script elements from the document
var
script
=
rawDocument
.
createElement
(
'
script
'
),
doneWrapper
=
function
()
{
script
.
onreadystatechange
=
script
.
onload
=
script
.
onerror
=
null
;
rawDocument
.
body
.
removeChild
(
script
);
if
(
done
)
done
();
};
...
...
@@ -7880,12 +7934,16 @@ function createHttpBackend($browser, XHR, $browserDefer, callbacks, rawDocument,
script
.
type
=
'
text/javascript
'
;
script
.
src
=
url
;
if
(
msie
)
{
if
(
msie
&&
msie
<=
8
)
{
script
.
onreadystatechange
=
function
()
{
if
(
/loaded|complete/
.
test
(
script
.
readyState
))
doneWrapper
();
if
(
/loaded|complete/
.
test
(
script
.
readyState
))
{
doneWrapper
();
}
};
}
else
{
script
.
onload
=
script
.
onerror
=
doneWrapper
;
script
.
onload
=
script
.
onerror
=
function
()
{
doneWrapper
();
};
}
rawDocument
.
body
.
appendChild
(
script
);
...
...
@@ -8962,7 +9020,7 @@ function $LocationProvider(){
*
* 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.
*
* @example
...
...
@@ -10128,7 +10186,7 @@ function getterFn(path, options, fullExp) {
:
'
((k&&k.hasOwnProperty("
'
+
key
+
'
"))?k:s)
'
)
+
'
["
'
+
key
+
'
"]
'
+
'
;
\n
'
+
(
options
.
unwrapPromises
?
'
if (s && s.then) {
\n
'
+
'
pw("
'
+
fullExp
.
replace
(
/
\"
/g
,
'
\\
"
'
)
+
'
");
\n
'
+
'
pw("
'
+
fullExp
.
replace
(
/
([
"
\r\n])
/g
,
'
\\
$1
'
)
+
'
");
\n
'
+
'
if (!("$$v" in s)) {
\n
'
+
'
p=s;
\n
'
+
'
p.$$v = undefined;
\n
'
+
...
...
@@ -12098,8 +12156,7 @@ function $SceDelegateProvider() {
return
resourceUrlBlacklist
;
};
this
.
$get
=
[
'
$log
'
,
'
$document
'
,
'
$injector
'
,
function
(
$log
,
$document
,
$injector
)
{
this
.
$get
=
[
'
$injector
'
,
function
(
$injector
)
{
var
htmlSanitizer
=
function
htmlSanitizer
(
html
)
{
throw
$sceMinErr
(
'
unsafe
'
,
'
Attempting to use an unsafe value in a safe context.
'
);
...
...
@@ -12630,18 +12687,15 @@ function $SceProvider() {
* sce.js and sceSpecs.js would need to be aware of this detail.
*/
this
.
$get
=
[
'
$parse
'
,
'
$
document
'
,
'
$sceDelegate
'
,
function
(
$parse
,
$
document
,
$sceDelegate
)
{
this
.
$get
=
[
'
$parse
'
,
'
$
sniffer
'
,
'
$sceDelegate
'
,
function
(
$parse
,
$
sniffer
,
$sceDelegate
)
{
// Prereq: Ensure that we're not running in IE8 quirks mode. In that mode, IE allows
// the "expression(javascript expression)" syntax which is insecure.
if
(
enabled
&&
msie
)
{
var
documentMode
=
$document
[
0
].
documentMode
;
if
(
documentMode
!==
undefined
&&
documentMode
<
8
)
{
throw
$sceMinErr
(
'
iequirks
'
,
'
Strict Contextual Escaping does not support Internet Explorer version < 9 in quirks
'
+
'
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.
'
);
}
if
(
enabled
&&
$sniffer
.
msie
&&
$sniffer
.
msieDocumentMode
<
8
)
{
throw
$sceMinErr
(
'
iequirks
'
,
'
Strict Contextual Escaping does not support Internet Explorer version < 9 in quirks
'
+
'
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
);
...
...
@@ -13003,6 +13057,7 @@ function $SnifferProvider() {
int
((
/android
(\d
+
)
/
.
exec
(
lowercase
((
$window
.
navigator
||
{}).
userAgent
))
||
[])[
1
]),
boxee
=
/Boxee/i
.
test
((
$window
.
navigator
||
{}).
userAgent
),
document
=
$document
[
0
]
||
{},
documentMode
=
document
.
documentMode
,
vendorPrefix
,
vendorRegex
=
/^
(
Moz|webkit|O|ms
)(?=[
A-Z
])
/
,
bodyStyle
=
document
.
body
&&
document
.
body
.
style
,
...
...
@@ -13047,7 +13102,7 @@ function $SnifferProvider() {
// jshint +W018
hashchange
:
'
onhashchange
'
in
$window
&&
// IE8 compatible mode lies
(
!
document
.
documentMode
||
document
.
documentMode
>
7
),
(
!
document
Mode
||
documentMode
>
7
),
hasEvent
:
function
(
event
)
{
// 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
...
...
@@ -13065,7 +13120,8 @@ function $SnifferProvider() {
vendorPrefix
:
vendorPrefix
,
transitions
:
transitions
,
animations
:
animations
,
msie
:
msie
msie
:
msie
,
msieDocumentMode
:
documentMode
};
}];
}
...
...
@@ -14680,8 +14736,11 @@ var htmlAnchorDirective = valueFn({
*
* 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.)
* 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.
* This complementary directive is not removed by the browser and so provides
* a permanent reliable place to store the binding information.
*
* @example
<doc:example>
...
...
@@ -14712,8 +14771,11 @@ var htmlAnchorDirective = valueFn({
* @description
* 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.)
* 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.
* This complementary directive is not removed by the browser and so provides
* a permanent reliable place to store the binding information.
* @example
<doc:example>
<doc:source>
...
...
@@ -14743,8 +14805,12 @@ var htmlAnchorDirective = valueFn({
* @description
* 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.)
* 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.
* This complementary directive is not removed by the browser and so provides
* a permanent reliable place to store the binding information.
* @example
<doc:example>
<doc:source>
...
...
@@ -14774,8 +14840,11 @@ var htmlAnchorDirective = valueFn({
* @description
* 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.)
* 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.
* This complementary directive is not removed by the browser and so provides
* a permanent reliable place to store the binding information.
* @example
<doc:example>
<doc:source>
...
...
@@ -14807,8 +14876,12 @@ var htmlAnchorDirective = valueFn({
* @description
* 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.)
* 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.
* This complementary directive is not removed by the browser and so provides
* a permanent reliable place to store the binding information.
*
* @example
<doc:example>
...
...
@@ -15638,8 +15711,21 @@ var inputType = {
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
()
{
if
(
composing
)
return
;
var
value
=
element
.
val
();
// By default we will trim the value
...
...
@@ -16929,11 +17015,10 @@ function classDirective(name, selector) {
// jshint bitwise: false
var
mod
=
$index
&
1
;
if
(
mod
!==
old$index
&
1
)
{
if
(
mod
===
selector
)
{
addClass
(
scope
.
$eval
(
attr
[
name
]));
}
else
{
removeClass
(
scope
.
$eval
(
attr
[
name
]));
}
var
classes
=
flattenClasses
(
scope
.
$eval
(
attr
[
name
]));
mod
===
selector
?
attr
.
$addClass
(
classes
)
:
attr
.
$removeClass
(
classes
);
}
});
}
...
...
@@ -16941,24 +17026,17 @@ function classDirective(name, selector) {
function
ngClassWatchAction
(
newVal
)
{
if
(
selector
===
true
||
scope
.
$index
%
2
===
selector
)
{
if
(
oldVal
&&
!
equals
(
newVal
,
oldVal
))
{
removeClass
(
oldVal
);
var
newClasses
=
flattenClasses
(
newVal
||
''
);
if
(
!
oldVal
)
{
attr
.
$addClass
(
newClasses
);
}
else
if
(
!
equals
(
newVal
,
oldVal
))
{
attr
.
$updateClass
(
newClasses
,
flattenClasses
(
oldVal
));
}
addClass
(
newVal
);
}
oldVal
=
copy
(
newVal
);
}
function
removeClass
(
classVal
)
{
attr
.
$removeClass
(
flattenClasses
(
classVal
));
}
function
addClass
(
classVal
)
{
attr
.
$addClass
(
flattenClasses
(
classVal
));
}
function
flattenClasses
(
classVal
)
{
if
(
isArray
(
classVal
))
{
return
classVal
.
join
(
'
'
);
...
...
@@ -17436,7 +17514,8 @@ var ngCloakDirective = ngDirective({
var
ngControllerDirective
=
[
function
()
{
return
{
scope
:
true
,
controller
:
'
@
'
controller
:
'
@
'
,
priority
:
500
};
}];
...
...
@@ -18132,18 +18211,23 @@ var ngIncludeDirective = ['$http', '$templateCache', '$anchorScroll', '$compile'
if
(
thisChangeId
!==
changeCounter
)
return
;
var
newScope
=
scope
.
$new
();
$transclude
(
newScope
,
function
(
clone
)
{
cleanupLastIncludeContent
();
currentScope
=
newScope
;
currentElement
=
clone
;
currentElement
.
html
(
response
);
$animate
.
enter
(
currentElement
,
null
,
$element
,
afterAnimation
);
$compile
(
currentElement
.
contents
())(
currentScope
);
currentScope
.
$emit
(
'
$includeContentLoaded
'
);
scope
.
$eval
(
onloadExp
);
});
// Note: This will also link all children of ng-include that were contained in the original
// 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...
// Note: We can't remove them in the cloneAttchFn of $transclude as that
// function is called before linking the content, which would apply child
// directives to non existing elements.
var
clone
=
$transclude
(
newScope
,
noop
);
cleanupLastIncludeContent
();
currentScope
=
newScope
;
currentElement
=
clone
;
currentElement
.
html
(
response
);
$animate
.
enter
(
currentElement
,
null
,
$element
,
afterAnimation
);
$compile
(
currentElement
.
contents
())(
currentScope
);
currentScope
.
$emit
(
'
$includeContentLoaded
'
);
scope
.
$eval
(
onloadExp
);
}).
error
(
function
()
{
if
(
thisChangeId
===
changeCounter
)
cleanupLastIncludeContent
();
});
...
...
@@ -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
* 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
* <span ng-non-bindable>`{{personCount}}`</span>. The closed braces `{}` is a placeholder
* for <span ng-non-bindable>{{numberExpression}}</span>.
...
...
@@ -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
* `$$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
* 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
* case the object identity does not matter. Two objects are considered equivalent as long as their `id`
...
...
@@ -20128,4 +20212,4 @@ var styleDirective = valueFn({
})(
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>
'
);
\ No newline at end of file
!
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
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