react 0.6.2 → 0.8.0
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.
- package/README.md +15 -217
- package/ReactJSErrors.js +40 -0
- package/addons.js +4 -0
- package/lib/$.js +46 -0
- package/lib/CSSCore.js +114 -0
- package/lib/CSSProperty.js +90 -0
- package/lib/CSSPropertyOperations.js +97 -0
- package/lib/CallbackRegistry.js +91 -0
- package/lib/ChangeEventPlugin.js +365 -0
- package/lib/CompositionEventPlugin.js +212 -0
- package/lib/DOMChildrenOperations.js +135 -0
- package/lib/DOMProperty.js +266 -0
- package/lib/DOMPropertyOperations.js +168 -0
- package/lib/Danger.js +186 -0
- package/lib/DefaultDOMPropertyConfig.js +187 -0
- package/lib/DefaultEventPluginOrder.js +44 -0
- package/lib/EnterLeaveEventPlugin.js +112 -0
- package/lib/EventConstants.js +73 -0
- package/lib/EventListener.js +61 -0
- package/lib/EventPluginHub.js +190 -0
- package/lib/EventPluginRegistry.js +237 -0
- package/lib/EventPluginUtils.js +185 -0
- package/lib/EventPropagators.js +179 -0
- package/lib/ExecutionEnvironment.js +41 -0
- package/lib/LinkedStateMixin.js +46 -0
- package/lib/LinkedValueMixin.js +68 -0
- package/lib/MobileSafariClickEventPlugin.js +63 -0
- package/lib/PooledClass.js +113 -0
- package/lib/React.js +71 -0
- package/lib/ReactChildren.js +132 -0
- package/lib/ReactComponent.js +515 -0
- package/lib/ReactComponentBrowserEnvironment.js +140 -0
- package/lib/ReactComponentEnvironment.js +24 -0
- package/lib/ReactCompositeComponent.js +1020 -0
- package/lib/ReactCurrentOwner.js +39 -0
- package/lib/ReactDOM.js +194 -0
- package/lib/ReactDOMButton.js +64 -0
- package/lib/ReactDOMComponent.js +374 -0
- package/lib/ReactDOMForm.js +52 -0
- package/lib/ReactDOMIDOperations.js +173 -0
- package/lib/ReactDOMInput.js +169 -0
- package/lib/ReactDOMOption.js +50 -0
- package/lib/ReactDOMSelect.js +160 -0
- package/lib/ReactDOMSelection.js +189 -0
- package/lib/ReactDOMTextarea.js +136 -0
- package/lib/ReactDefaultBatchingStrategy.js +75 -0
- package/lib/ReactDefaultInjection.js +91 -0
- package/lib/ReactDefaultPerf.js +407 -0
- package/lib/ReactErrorUtils.js +46 -0
- package/lib/ReactEventEmitter.js +341 -0
- package/lib/ReactEventEmitterMixin.js +89 -0
- package/lib/ReactEventTopLevelCallback.js +89 -0
- package/lib/ReactInputSelection.js +140 -0
- package/lib/ReactInstanceHandles.js +322 -0
- package/lib/ReactLink.js +54 -0
- package/lib/ReactMarkupChecksum.js +53 -0
- package/lib/ReactMount.js +617 -0
- package/lib/ReactMountReady.js +95 -0
- package/lib/ReactMultiChild.js +441 -0
- package/lib/ReactMultiChildUpdateTypes.js +36 -0
- package/lib/ReactOwner.js +146 -0
- package/lib/ReactPerf.js +88 -0
- package/lib/ReactPropTransferer.js +128 -0
- package/lib/ReactPropTypes.js +158 -0
- package/lib/ReactReconcileTransaction.js +161 -0
- package/lib/ReactServerRendering.js +62 -0
- package/lib/ReactStateSetters.js +111 -0
- package/lib/ReactTextComponent.js +94 -0
- package/lib/ReactTransitionEvents.js +97 -0
- package/lib/ReactTransitionGroup.js +112 -0
- package/lib/ReactTransitionKeySet.js +111 -0
- package/lib/ReactTransitionableChild.js +152 -0
- package/lib/ReactUpdates.js +145 -0
- package/lib/ReactWithAddons.js +41 -0
- package/lib/SelectEventPlugin.js +217 -0
- package/lib/SimpleEventPlugin.js +365 -0
- package/lib/SyntheticClipboardEvent.js +45 -0
- package/lib/SyntheticCompositionEvent.js +51 -0
- package/lib/SyntheticEvent.js +163 -0
- package/lib/SyntheticFocusEvent.js +44 -0
- package/lib/SyntheticKeyboardEvent.js +56 -0
- package/lib/SyntheticMouseEvent.js +85 -0
- package/lib/SyntheticTouchEvent.js +50 -0
- package/lib/SyntheticUIEvent.js +45 -0
- package/lib/SyntheticWheelEvent.js +63 -0
- package/lib/Transaction.js +251 -0
- package/lib/ViewportMetrics.js +37 -0
- package/lib/accumulate.js +54 -0
- package/lib/adler32.js +39 -0
- package/lib/containsNode.js +49 -0
- package/lib/copyProperties.js +54 -0
- package/lib/createArrayFrom.js +94 -0
- package/lib/createNodesFromMarkup.js +93 -0
- package/lib/createObjectFrom.js +61 -0
- package/lib/cx.js +44 -0
- package/lib/dangerousStyleValue.js +57 -0
- package/lib/emptyFunction.js +43 -0
- package/lib/escapeTextForBrowser.js +47 -0
- package/lib/ex.js +49 -0
- package/lib/filterAttributes.js +45 -0
- package/lib/flattenChildren.js +54 -0
- package/lib/forEachAccumulated.js +36 -0
- package/lib/ge.js +76 -0
- package/lib/getActiveElement.js +33 -0
- package/lib/getEventTarget.js +36 -0
- package/lib/getMarkupWrap.js +108 -0
- package/lib/getNodeForCharacterOffset.js +80 -0
- package/lib/getReactRootElementInContainer.js +40 -0
- package/lib/getTextContentAccessor.js +40 -0
- package/lib/getUnboundedScrollPosition.js +45 -0
- package/lib/hyphenate.js +35 -0
- package/lib/invariant.js +54 -0
- package/lib/isEventSupported.js +74 -0
- package/lib/isNode.js +33 -0
- package/lib/isTextInputElement.js +49 -0
- package/lib/isTextNode.js +30 -0
- package/lib/joinClasses.js +44 -0
- package/lib/keyMirror.js +58 -0
- package/lib/keyOf.js +41 -0
- package/lib/memoizeStringOnly.js +39 -0
- package/lib/merge.js +37 -0
- package/lib/mergeHelpers.js +137 -0
- package/lib/mergeInto.js +45 -0
- package/lib/mixInto.js +34 -0
- package/lib/mutateHTMLNodeWithMarkup.js +100 -0
- package/lib/objMap.js +47 -0
- package/lib/objMapKeyVal.js +47 -0
- package/lib/performanceNow.js +42 -0
- package/lib/shallowEqual.js +49 -0
- package/lib/traverseAllChildren.js +127 -0
- package/package.json +33 -21
- package/react.js +4 -0
- package/.npmignore +0 -7
- package/.travis.yml +0 -5
- package/Jakefile.js +0 -39
- package/LICENSE +0 -19
- package/browser-test/dist.html +0 -89
- package/browser-test/index.html +0 -85
- package/browser-test/min.html +0 -89
- package/dist/react.js +0 -3094
- package/dist/react.min.js +0 -22
- package/doc/advanced.md +0 -166
- package/doc/color-def.graffle +0 -938
- package/doc/color-def.png +0 -0
- package/doc/simple.dot +0 -25
- package/doc/simple.png +0 -0
- package/examples/longer-example.js +0 -41
- package/examples/simple.js +0 -45
- package/examples/using-ast-directly.js +0 -30
- package/examples/using-events1.js +0 -79
- package/examples/using-log-events.js +0 -43
- package/lib/base-task.js +0 -123
- package/lib/cb-task.js +0 -84
- package/lib/core.js +0 -138
- package/lib/dsl.js +0 -138
- package/lib/error.js +0 -55
- package/lib/event-collector.js +0 -81
- package/lib/event-manager.js +0 -85
- package/lib/eventemitter.js +0 -20
- package/lib/finalcb-first-task.js +0 -68
- package/lib/finalcb-task.js +0 -65
- package/lib/id.js +0 -22
- package/lib/input-parser.js +0 -56
- package/lib/log-events.js +0 -92
- package/lib/parse.js +0 -41
- package/lib/promise-resolve.js +0 -50
- package/lib/promise-task.js +0 -93
- package/lib/react.js +0 -59
- package/lib/ret-task.js +0 -71
- package/lib/sprintf.js +0 -18
- package/lib/status.js +0 -14
- package/lib/task.js +0 -251
- package/lib/track-tasks.js +0 -74
- package/lib/validate.js +0 -159
- package/lib/vcon.js +0 -90
- package/lib/when-task.js +0 -85
- package/src/dist.build.requirejs +0 -20
- package/test/ast.mocha.js +0 -136
- package/test/cb-task.mocha.js +0 -220
- package/test/core-deferred.mocha.js +0 -143
- package/test/core-when.mocha.js +0 -96
- package/test/core.mocha.js +0 -589
- package/test/dsl.mocha.js +0 -350
- package/test/event-manager.mocha.js +0 -119
- package/test/exec-options.mocha.js +0 -48
- package/test/finalcb-task.mocha.js +0 -58
- package/test/input-parser.mocha.js +0 -86
- package/test/mocha.opts +0 -2
- package/test/module-use.mocha.js +0 -147
- package/test/promise-auto-resolve.mocha.js +0 -68
- package/test/ret-task.mocha.js +0 -220
- package/test/task.mocha.js +0 -42
- package/test/validate-cb-task.mocha.js +0 -100
- package/test/validate-ret-task.mocha.js +0 -110
- package/test/validate.mocha.js +0 -324
- package/test/vcon.mocha.js +0 -193
- package/vendor/chai/chai.js +0 -2038
- package/vendor/jquery/jquery-1.7.1.js +0 -9266
- package/vendor/jquery/jquery-1.7.1.min.js +0 -4
- package/vendor/mocha/mocha.css +0 -135
- package/vendor/mocha/mocha.js +0 -3589
- package/vendor/node/util.js +0 -531
- package/vendor/requirejs/require.js +0 -2053
- package/vendor/requirejs/require.min.js +0 -33
package/lib/cx.js
ADDED
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright 2013 Facebook, Inc.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*
|
|
16
|
+
* @providesModule cx
|
|
17
|
+
*/
|
|
18
|
+
|
|
19
|
+
/**
|
|
20
|
+
* This function is used to mark string literals representing CSS class names
|
|
21
|
+
* so that they can be transformed statically. This allows for modularization
|
|
22
|
+
* and minification of CSS class names.
|
|
23
|
+
*
|
|
24
|
+
* In static_upstream, this function is actually implemented, but it should
|
|
25
|
+
* eventually be replaced with something more descriptive, and the transform
|
|
26
|
+
* that is used in the main stack should be ported for use elsewhere.
|
|
27
|
+
*
|
|
28
|
+
* @param string|object className to modularize, or an object of key/values.
|
|
29
|
+
* In the object case, the values are conditions that
|
|
30
|
+
* determine if the className keys should be included.
|
|
31
|
+
* @param [string ...] Variable list of classNames in the string case.
|
|
32
|
+
* @return string Renderable space-separated CSS className.
|
|
33
|
+
*/
|
|
34
|
+
function cx(classNames) {
|
|
35
|
+
if (typeof classNames == 'object') {
|
|
36
|
+
return Object.keys(classNames).map(function(className) {
|
|
37
|
+
return classNames[className] ? className : '';
|
|
38
|
+
}).join(' ');
|
|
39
|
+
} else {
|
|
40
|
+
return Array.prototype.join.call(arguments, ' ');
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
module.exports = cx;
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright 2013 Facebook, Inc.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*
|
|
16
|
+
* @providesModule dangerousStyleValue
|
|
17
|
+
* @typechecks static-only
|
|
18
|
+
*/
|
|
19
|
+
|
|
20
|
+
"use strict";
|
|
21
|
+
|
|
22
|
+
var CSSProperty = require("./CSSProperty");
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* Convert a value into the proper css writable value. The `styleName` name
|
|
26
|
+
* name should be logical (no hyphens), as specified
|
|
27
|
+
* in `CSSProperty.isUnitlessNumber`.
|
|
28
|
+
*
|
|
29
|
+
* @param {string} styleName CSS property name such as `topMargin`.
|
|
30
|
+
* @param {*} value CSS property value such as `10px`.
|
|
31
|
+
* @return {string} Normalized style value with dimensions applied.
|
|
32
|
+
*/
|
|
33
|
+
function dangerousStyleValue(styleName, value) {
|
|
34
|
+
// Note that we've removed escapeTextForBrowser() calls here since the
|
|
35
|
+
// whole string will be escaped when the attribute is injected into
|
|
36
|
+
// the markup. If you provide unsafe user data here they can inject
|
|
37
|
+
// arbitrary CSS which may be problematic (I couldn't repro this):
|
|
38
|
+
// https://www.owasp.org/index.php/XSS_Filter_Evasion_Cheat_Sheet
|
|
39
|
+
// http://www.thespanner.co.uk/2007/11/26/ultimate-xss-css-injection/
|
|
40
|
+
// This is not an XSS hole but instead a potential CSS injection issue
|
|
41
|
+
// which has lead to a greater discussion about how we're going to
|
|
42
|
+
// trust URLs moving forward. See #2115901
|
|
43
|
+
|
|
44
|
+
var isEmpty = value == null || typeof value === 'boolean' || value === '';
|
|
45
|
+
if (isEmpty) {
|
|
46
|
+
return '';
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
var isNonNumeric = isNaN(value);
|
|
50
|
+
if (isNonNumeric || value === 0 || CSSProperty.isUnitlessNumber[styleName]) {
|
|
51
|
+
return '' + value; // cast to string
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
return value + 'px';
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
module.exports = dangerousStyleValue;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright 2013 Facebook, Inc.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*
|
|
16
|
+
* @providesModule emptyFunction
|
|
17
|
+
*/
|
|
18
|
+
|
|
19
|
+
var copyProperties = require("./copyProperties");
|
|
20
|
+
|
|
21
|
+
function makeEmptyFunction(arg) {
|
|
22
|
+
return function() {
|
|
23
|
+
return arg;
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* This function accepts and discards inputs; it has no side effects. This is
|
|
29
|
+
* primarily useful idiomatically for overridable function endpoints which
|
|
30
|
+
* always need to be callable, since JS lacks a null-call idiom ala Cocoa.
|
|
31
|
+
*/
|
|
32
|
+
function emptyFunction() {}
|
|
33
|
+
|
|
34
|
+
copyProperties(emptyFunction, {
|
|
35
|
+
thatReturns: makeEmptyFunction,
|
|
36
|
+
thatReturnsFalse: makeEmptyFunction(false),
|
|
37
|
+
thatReturnsTrue: makeEmptyFunction(true),
|
|
38
|
+
thatReturnsNull: makeEmptyFunction(null),
|
|
39
|
+
thatReturnsThis: function() { return this; },
|
|
40
|
+
thatReturnsArgument: function(arg) { return arg; }
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
module.exports = emptyFunction;
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright 2013 Facebook, Inc.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*
|
|
16
|
+
* @providesModule escapeTextForBrowser
|
|
17
|
+
* @typechecks static-only
|
|
18
|
+
*/
|
|
19
|
+
|
|
20
|
+
"use strict";
|
|
21
|
+
|
|
22
|
+
var ESCAPE_LOOKUP = {
|
|
23
|
+
"&": "&",
|
|
24
|
+
">": ">",
|
|
25
|
+
"<": "<",
|
|
26
|
+
"\"": """,
|
|
27
|
+
"'": "'",
|
|
28
|
+
"/": "/"
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
var ESCAPE_REGEX = /[&><"'\/]/g;
|
|
32
|
+
|
|
33
|
+
function escaper(match) {
|
|
34
|
+
return ESCAPE_LOOKUP[match];
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* Escapes text to prevent scripting attacks.
|
|
39
|
+
*
|
|
40
|
+
* @param {*} text Text value to escape.
|
|
41
|
+
* @return {string} An escaped string.
|
|
42
|
+
*/
|
|
43
|
+
function escapeTextForBrowser(text) {
|
|
44
|
+
return ('' + text).replace(ESCAPE_REGEX, escaper);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
module.exports = escapeTextForBrowser;
|
package/lib/ex.js
ADDED
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright 2013 Facebook, Inc.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*
|
|
16
|
+
* @providesModule ex
|
|
17
|
+
* @typechecks
|
|
18
|
+
* @nostacktrace
|
|
19
|
+
*/
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* This function transforms error message with arguments into plain text error
|
|
23
|
+
* message, so that it can be passed to window.onerror without losing anything.
|
|
24
|
+
* It can then be transformed back by `erx()` function.
|
|
25
|
+
*
|
|
26
|
+
* Usage:
|
|
27
|
+
* throw new Error(ex('Error %s from %s', errorCode, userID));
|
|
28
|
+
*
|
|
29
|
+
* @param {string} errorMessage
|
|
30
|
+
*/
|
|
31
|
+
|
|
32
|
+
var ex = function(errorMessage/*, arg1, arg2, ...*/) {
|
|
33
|
+
var args = Array.prototype.slice.call(arguments).map(function(arg) {
|
|
34
|
+
return String(arg);
|
|
35
|
+
});
|
|
36
|
+
var expectedLength = errorMessage.split('%s').length - 1;
|
|
37
|
+
|
|
38
|
+
if (expectedLength !== args.length - 1) {
|
|
39
|
+
// something wrong with the formatting string
|
|
40
|
+
return ex('ex args number mismatch: %s', JSON.stringify(args));
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
return ex._prefix + JSON.stringify(args) + ex._suffix;
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
ex._prefix = '<![EX[';
|
|
47
|
+
ex._suffix = ']]>';
|
|
48
|
+
|
|
49
|
+
module.exports = ex;
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright 2013 Facebook, Inc.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*
|
|
16
|
+
* @providesModule filterAttributes
|
|
17
|
+
* @typechecks static-only
|
|
18
|
+
*/
|
|
19
|
+
|
|
20
|
+
/*jslint evil: true */
|
|
21
|
+
|
|
22
|
+
'use strict';
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* Like filter(), but for a DOM nodes attributes. Returns an array of
|
|
26
|
+
* the filter DOMAttribute objects. Does some perf related this like
|
|
27
|
+
* caching attributes.length.
|
|
28
|
+
*
|
|
29
|
+
* @param {DOMElement} node Node whose attributes you want to filter
|
|
30
|
+
* @return {array} array of DOM attribute objects.
|
|
31
|
+
*/
|
|
32
|
+
function filterAttributes(node, func, context) {
|
|
33
|
+
var attributes = node.attributes;
|
|
34
|
+
var numAttributes = attributes.length;
|
|
35
|
+
var accumulator = [];
|
|
36
|
+
for (var i = 0; i < numAttributes; i++) {
|
|
37
|
+
var attr = attributes.item(i);
|
|
38
|
+
if (func.call(context, attr)) {
|
|
39
|
+
accumulator.push(attr);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
return accumulator;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
module.exports = filterAttributes;
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright 2013 Facebook, Inc.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*
|
|
16
|
+
* @providesModule flattenChildren
|
|
17
|
+
*/
|
|
18
|
+
|
|
19
|
+
"use strict";
|
|
20
|
+
|
|
21
|
+
var invariant = require("./invariant");
|
|
22
|
+
var traverseAllChildren = require("./traverseAllChildren");
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* @param {function} traverseContext Context passed through traversal.
|
|
26
|
+
* @param {?ReactComponent} child React child component.
|
|
27
|
+
* @param {!string} name String name of key path to child.
|
|
28
|
+
*/
|
|
29
|
+
function flattenSingleChildIntoContext(traverseContext, child, name) {
|
|
30
|
+
// We found a component instance.
|
|
31
|
+
var result = traverseContext;
|
|
32
|
+
("production" !== process.env.NODE_ENV ? invariant(
|
|
33
|
+
!result.hasOwnProperty(name),
|
|
34
|
+
'flattenChildren(...): Encountered two children with the same key, `%s`. ' +
|
|
35
|
+
'Children keys must be unique.',
|
|
36
|
+
name
|
|
37
|
+
) : invariant(!result.hasOwnProperty(name)));
|
|
38
|
+
result[name] = child;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* Flattens children that are typically specified as `props.children`.
|
|
43
|
+
* @return {!object} flattened children keyed by name.
|
|
44
|
+
*/
|
|
45
|
+
function flattenChildren(children) {
|
|
46
|
+
if (children == null) {
|
|
47
|
+
return children;
|
|
48
|
+
}
|
|
49
|
+
var result = {};
|
|
50
|
+
traverseAllChildren(children, flattenSingleChildIntoContext, result);
|
|
51
|
+
return result;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
module.exports = flattenChildren;
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright 2013 Facebook, Inc.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*
|
|
16
|
+
* @providesModule forEachAccumulated
|
|
17
|
+
*/
|
|
18
|
+
|
|
19
|
+
"use strict";
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* @param {array} an "accumulation" of items which is either an Array or
|
|
23
|
+
* a single item. Useful when paired with the `accumulate` module. This is a
|
|
24
|
+
* simple utility that allows us to reason about a collection of items, but
|
|
25
|
+
* handling the case when there is exactly one item (and we do not need to
|
|
26
|
+
* allocate an array).
|
|
27
|
+
*/
|
|
28
|
+
var forEachAccumulated = function(arr, cb, scope) {
|
|
29
|
+
if (Array.isArray(arr)) {
|
|
30
|
+
arr.forEach(cb, scope);
|
|
31
|
+
} else if (arr) {
|
|
32
|
+
cb.call(scope, arr);
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
module.exports = forEachAccumulated;
|
package/lib/ge.js
ADDED
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright 2013 Facebook, Inc.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*
|
|
16
|
+
* @providesModule ge
|
|
17
|
+
*/
|
|
18
|
+
|
|
19
|
+
/**
|
|
20
|
+
* Find a node by ID. Optionally search a sub-tree outside of the document
|
|
21
|
+
*
|
|
22
|
+
* Use ge if you're not sure whether or not the element exists. You can test
|
|
23
|
+
* for existence yourself in your application code.
|
|
24
|
+
*
|
|
25
|
+
* If your application code depends on the existence of the element, use $
|
|
26
|
+
* instead, which will throw in DEV if the element doesn't exist.
|
|
27
|
+
*/
|
|
28
|
+
function ge(arg, root, tag) {
|
|
29
|
+
return typeof arg != 'string' ? arg :
|
|
30
|
+
!root ? document.getElementById(arg) :
|
|
31
|
+
_geFromSubtree(arg, root, tag);
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
function _geFromSubtree(id, root, tag) {
|
|
35
|
+
var elem, children, ii;
|
|
36
|
+
|
|
37
|
+
if (_getNodeID(root) == id) {
|
|
38
|
+
return root;
|
|
39
|
+
} else if (root.getElementsByTagName) {
|
|
40
|
+
// All Elements implement this, which does an iterative DFS, which is
|
|
41
|
+
// faster than recursion and doesn't run into stack depth issues.
|
|
42
|
+
children = root.getElementsByTagName(tag || '*');
|
|
43
|
+
for (ii = 0; ii < children.length; ii++) {
|
|
44
|
+
if (_getNodeID(children[ii]) == id) {
|
|
45
|
+
return children[ii];
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
} else {
|
|
49
|
+
// DocumentFragment does not implement getElementsByTagName, so
|
|
50
|
+
// recurse over its children. Its children must be Elements, so
|
|
51
|
+
// each child will use the getElementsByTagName case instead.
|
|
52
|
+
children = root.childNodes;
|
|
53
|
+
for (ii = 0; ii < children.length; ii++) {
|
|
54
|
+
elem = _geFromSubtree(id, children[ii]);
|
|
55
|
+
if (elem) {
|
|
56
|
+
return elem;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
return null;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
/**
|
|
65
|
+
* Return the ID value for a given node. This allows us to avoid issues
|
|
66
|
+
* with forms that contain inputs with name="id".
|
|
67
|
+
*
|
|
68
|
+
* @return string (null if attribute not set)
|
|
69
|
+
*/
|
|
70
|
+
function _getNodeID(node) {
|
|
71
|
+
// #document and #document-fragment do not have getAttributeNode.
|
|
72
|
+
var id = node.getAttributeNode && node.getAttributeNode('id');
|
|
73
|
+
return id ? id.value : null;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
module.exports = ge;
|