react 0.7.1 → 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.
Files changed (203) hide show
  1. package/README.md +15 -228
  2. package/ReactJSErrors.js +40 -0
  3. package/addons.js +4 -0
  4. package/lib/$.js +46 -0
  5. package/lib/CSSCore.js +114 -0
  6. package/lib/CSSProperty.js +90 -0
  7. package/lib/CSSPropertyOperations.js +97 -0
  8. package/lib/CallbackRegistry.js +91 -0
  9. package/lib/ChangeEventPlugin.js +365 -0
  10. package/lib/CompositionEventPlugin.js +212 -0
  11. package/lib/DOMChildrenOperations.js +135 -0
  12. package/lib/DOMProperty.js +266 -0
  13. package/lib/DOMPropertyOperations.js +168 -0
  14. package/lib/Danger.js +186 -0
  15. package/lib/DefaultDOMPropertyConfig.js +187 -0
  16. package/lib/DefaultEventPluginOrder.js +44 -0
  17. package/lib/EnterLeaveEventPlugin.js +112 -0
  18. package/lib/EventConstants.js +73 -0
  19. package/lib/EventListener.js +61 -0
  20. package/lib/EventPluginHub.js +190 -0
  21. package/lib/EventPluginRegistry.js +237 -0
  22. package/lib/EventPluginUtils.js +185 -0
  23. package/lib/EventPropagators.js +179 -0
  24. package/lib/ExecutionEnvironment.js +41 -0
  25. package/lib/LinkedStateMixin.js +46 -0
  26. package/lib/LinkedValueMixin.js +68 -0
  27. package/lib/MobileSafariClickEventPlugin.js +63 -0
  28. package/lib/PooledClass.js +113 -0
  29. package/lib/React.js +71 -0
  30. package/lib/ReactChildren.js +132 -0
  31. package/lib/ReactComponent.js +515 -0
  32. package/lib/ReactComponentBrowserEnvironment.js +140 -0
  33. package/lib/ReactComponentEnvironment.js +24 -0
  34. package/lib/ReactCompositeComponent.js +1020 -0
  35. package/lib/ReactCurrentOwner.js +39 -0
  36. package/lib/ReactDOM.js +194 -0
  37. package/lib/ReactDOMButton.js +64 -0
  38. package/lib/ReactDOMComponent.js +374 -0
  39. package/lib/ReactDOMForm.js +52 -0
  40. package/lib/ReactDOMIDOperations.js +173 -0
  41. package/lib/ReactDOMInput.js +169 -0
  42. package/lib/ReactDOMOption.js +50 -0
  43. package/lib/ReactDOMSelect.js +160 -0
  44. package/lib/ReactDOMSelection.js +189 -0
  45. package/lib/ReactDOMTextarea.js +136 -0
  46. package/lib/ReactDefaultBatchingStrategy.js +75 -0
  47. package/lib/ReactDefaultInjection.js +91 -0
  48. package/lib/ReactDefaultPerf.js +407 -0
  49. package/lib/ReactErrorUtils.js +46 -0
  50. package/lib/ReactEventEmitter.js +341 -0
  51. package/lib/ReactEventEmitterMixin.js +89 -0
  52. package/lib/ReactEventTopLevelCallback.js +89 -0
  53. package/lib/ReactInputSelection.js +140 -0
  54. package/lib/ReactInstanceHandles.js +322 -0
  55. package/lib/ReactLink.js +54 -0
  56. package/lib/ReactMarkupChecksum.js +53 -0
  57. package/lib/ReactMount.js +617 -0
  58. package/lib/ReactMountReady.js +95 -0
  59. package/lib/ReactMultiChild.js +441 -0
  60. package/lib/ReactMultiChildUpdateTypes.js +36 -0
  61. package/lib/ReactOwner.js +146 -0
  62. package/lib/ReactPerf.js +88 -0
  63. package/lib/ReactPropTransferer.js +128 -0
  64. package/lib/ReactPropTypes.js +158 -0
  65. package/lib/ReactReconcileTransaction.js +161 -0
  66. package/lib/ReactServerRendering.js +62 -0
  67. package/lib/ReactStateSetters.js +111 -0
  68. package/lib/ReactTextComponent.js +94 -0
  69. package/lib/ReactTransitionEvents.js +97 -0
  70. package/lib/ReactTransitionGroup.js +112 -0
  71. package/lib/ReactTransitionKeySet.js +111 -0
  72. package/lib/ReactTransitionableChild.js +152 -0
  73. package/lib/ReactUpdates.js +145 -0
  74. package/lib/ReactWithAddons.js +41 -0
  75. package/lib/SelectEventPlugin.js +217 -0
  76. package/lib/SimpleEventPlugin.js +365 -0
  77. package/lib/SyntheticClipboardEvent.js +45 -0
  78. package/lib/SyntheticCompositionEvent.js +51 -0
  79. package/lib/SyntheticEvent.js +163 -0
  80. package/lib/SyntheticFocusEvent.js +44 -0
  81. package/lib/SyntheticKeyboardEvent.js +56 -0
  82. package/lib/SyntheticMouseEvent.js +85 -0
  83. package/lib/SyntheticTouchEvent.js +50 -0
  84. package/lib/SyntheticUIEvent.js +45 -0
  85. package/lib/SyntheticWheelEvent.js +63 -0
  86. package/lib/Transaction.js +251 -0
  87. package/lib/ViewportMetrics.js +37 -0
  88. package/lib/accumulate.js +54 -0
  89. package/lib/adler32.js +39 -0
  90. package/lib/containsNode.js +49 -0
  91. package/lib/copyProperties.js +54 -0
  92. package/lib/createArrayFrom.js +94 -0
  93. package/lib/createNodesFromMarkup.js +93 -0
  94. package/lib/createObjectFrom.js +61 -0
  95. package/lib/cx.js +44 -0
  96. package/lib/dangerousStyleValue.js +57 -0
  97. package/lib/emptyFunction.js +43 -0
  98. package/lib/escapeTextForBrowser.js +47 -0
  99. package/lib/ex.js +49 -0
  100. package/lib/filterAttributes.js +45 -0
  101. package/lib/flattenChildren.js +54 -0
  102. package/lib/forEachAccumulated.js +36 -0
  103. package/lib/ge.js +76 -0
  104. package/lib/getActiveElement.js +33 -0
  105. package/lib/getEventTarget.js +36 -0
  106. package/lib/getMarkupWrap.js +108 -0
  107. package/lib/getNodeForCharacterOffset.js +80 -0
  108. package/lib/getReactRootElementInContainer.js +40 -0
  109. package/lib/getTextContentAccessor.js +40 -0
  110. package/lib/getUnboundedScrollPosition.js +45 -0
  111. package/lib/hyphenate.js +35 -0
  112. package/lib/invariant.js +54 -0
  113. package/lib/isEventSupported.js +74 -0
  114. package/lib/isNode.js +33 -0
  115. package/lib/isTextInputElement.js +49 -0
  116. package/lib/isTextNode.js +30 -0
  117. package/lib/joinClasses.js +44 -0
  118. package/lib/keyMirror.js +58 -0
  119. package/lib/keyOf.js +41 -0
  120. package/lib/memoizeStringOnly.js +39 -0
  121. package/lib/merge.js +37 -0
  122. package/lib/mergeHelpers.js +137 -0
  123. package/lib/mergeInto.js +45 -0
  124. package/lib/mixInto.js +34 -0
  125. package/lib/mutateHTMLNodeWithMarkup.js +100 -0
  126. package/lib/objMap.js +47 -0
  127. package/lib/objMapKeyVal.js +47 -0
  128. package/lib/performanceNow.js +42 -0
  129. package/lib/shallowEqual.js +49 -0
  130. package/lib/traverseAllChildren.js +127 -0
  131. package/package.json +33 -31
  132. package/react.js +4 -0
  133. package/.npmignore +0 -7
  134. package/.travis.yml +0 -7
  135. package/Jakefile.js +0 -39
  136. package/LICENSE +0 -19
  137. package/browser-test/dist.html +0 -90
  138. package/browser-test/index.html +0 -86
  139. package/browser-test/min.html +0 -90
  140. package/dist/react.js +0 -3141
  141. package/dist/react.min.js +0 -22
  142. package/doc/advanced.md +0 -175
  143. package/doc/color-def.graffle +0 -938
  144. package/doc/color-def.png +0 -0
  145. package/doc/simple.dot +0 -25
  146. package/doc/simple.png +0 -0
  147. package/examples/longer-example.js +0 -41
  148. package/examples/simple.js +0 -45
  149. package/examples/using-ast-directly.js +0 -30
  150. package/examples/using-events1.js +0 -79
  151. package/examples/using-log-events.js +0 -43
  152. package/lib/base-task.js +0 -120
  153. package/lib/cb-task.js +0 -84
  154. package/lib/core.js +0 -138
  155. package/lib/dsl.js +0 -138
  156. package/lib/error.js +0 -55
  157. package/lib/event-collector.js +0 -81
  158. package/lib/event-manager.js +0 -89
  159. package/lib/eventemitter.js +0 -20
  160. package/lib/finalcb-first-task.js +0 -68
  161. package/lib/finalcb-task.js +0 -65
  162. package/lib/id.js +0 -22
  163. package/lib/input-parser.js +0 -56
  164. package/lib/log-events.js +0 -101
  165. package/lib/parse.js +0 -41
  166. package/lib/promise-resolve.js +0 -50
  167. package/lib/promise-task.js +0 -93
  168. package/lib/react.js +0 -59
  169. package/lib/ret-task.js +0 -71
  170. package/lib/sprintf.js +0 -18
  171. package/lib/status.js +0 -14
  172. package/lib/task.js +0 -251
  173. package/lib/track-tasks.js +0 -74
  174. package/lib/validate.js +0 -159
  175. package/lib/vcon.js +0 -113
  176. package/lib/when-task.js +0 -84
  177. package/src/dist.build.requirejs +0 -20
  178. package/test/ast.mocha.js +0 -136
  179. package/test/cb-task.mocha.js +0 -220
  180. package/test/core-deferred.mocha.js +0 -143
  181. package/test/core-when.mocha.js +0 -96
  182. package/test/core.mocha.js +0 -589
  183. package/test/dsl.mocha.js +0 -352
  184. package/test/event-manager.mocha.js +0 -119
  185. package/test/exec-options.mocha.js +0 -48
  186. package/test/finalcb-task.mocha.js +0 -58
  187. package/test/input-parser.mocha.js +0 -86
  188. package/test/log-events.mocha.js +0 -88
  189. package/test/mocha.opts +0 -2
  190. package/test/module-use.mocha.js +0 -164
  191. package/test/promise-auto-resolve.mocha.js +0 -68
  192. package/test/ret-task.mocha.js +0 -220
  193. package/test/task.mocha.js +0 -42
  194. package/test/validate-cb-task.mocha.js +0 -100
  195. package/test/validate-ret-task.mocha.js +0 -110
  196. package/test/validate.mocha.js +0 -324
  197. package/test/vcon.mocha.js +0 -193
  198. package/vendor/chai/chai.js +0 -4251
  199. package/vendor/jquery/jquery-1.7.1.js +0 -9266
  200. package/vendor/jquery/jquery-1.7.1.min.js +0 -4
  201. package/vendor/node/util.js +0 -531
  202. package/vendor/requirejs/require.js +0 -2045
  203. package/vendor/requirejs/require.min.js +0 -36
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
+ "<": "&lt;",
26
+ "\"": "&quot;",
27
+ "'": "&#x27;",
28
+ "/": "&#x2f;"
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;