react 0.7.1 → 0.10.0-rc1

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 (223) hide show
  1. package/README.md +10 -231
  2. package/addons.js +1 -0
  3. package/lib/AutoFocusMixin.js +32 -0
  4. package/lib/CSSCore.js +115 -0
  5. package/lib/CSSProperty.js +121 -0
  6. package/lib/CSSPropertyOperations.js +97 -0
  7. package/lib/ChangeEventPlugin.js +387 -0
  8. package/lib/ClientReactRootIndex.js +30 -0
  9. package/lib/CompositionEventPlugin.js +260 -0
  10. package/lib/DOMChildrenOperations.js +171 -0
  11. package/lib/DOMProperty.js +270 -0
  12. package/lib/DOMPropertyOperations.js +181 -0
  13. package/lib/Danger.js +187 -0
  14. package/lib/DefaultDOMPropertyConfig.js +196 -0
  15. package/lib/DefaultEventPluginOrder.js +44 -0
  16. package/lib/EnterLeaveEventPlugin.js +145 -0
  17. package/lib/EventConstants.js +76 -0
  18. package/lib/EventListener.js +69 -0
  19. package/lib/EventPluginHub.js +295 -0
  20. package/lib/EventPluginRegistry.js +281 -0
  21. package/lib/EventPluginUtils.js +214 -0
  22. package/lib/EventPropagators.js +143 -0
  23. package/lib/ExecutionEnvironment.js +44 -0
  24. package/lib/LinkedStateMixin.js +46 -0
  25. package/lib/LinkedValueUtils.js +160 -0
  26. package/lib/MobileSafariClickEventPlugin.js +63 -0
  27. package/lib/PooledClass.js +119 -0
  28. package/lib/React.js +97 -0
  29. package/lib/ReactBrowserComponentMixin.js +42 -0
  30. package/lib/ReactCSSTransitionGroup.js +65 -0
  31. package/lib/ReactCSSTransitionGroupChild.js +138 -0
  32. package/lib/ReactChildren.js +132 -0
  33. package/lib/ReactComponent.js +595 -0
  34. package/lib/ReactComponentBrowserEnvironment.js +124 -0
  35. package/lib/ReactCompositeComponent.js +1587 -0
  36. package/lib/ReactContext.js +67 -0
  37. package/lib/ReactCurrentOwner.js +39 -0
  38. package/lib/ReactDOM.js +207 -0
  39. package/lib/ReactDOMButton.js +69 -0
  40. package/lib/ReactDOMComponent.js +416 -0
  41. package/lib/ReactDOMForm.js +62 -0
  42. package/lib/ReactDOMIDOperations.js +218 -0
  43. package/lib/ReactDOMImg.js +61 -0
  44. package/lib/ReactDOMInput.js +182 -0
  45. package/lib/ReactDOMOption.js +55 -0
  46. package/lib/ReactDOMSelect.js +180 -0
  47. package/lib/ReactDOMSelection.js +189 -0
  48. package/lib/ReactDOMTextarea.js +144 -0
  49. package/lib/ReactDefaultBatchingStrategy.js +75 -0
  50. package/lib/ReactDefaultInjection.js +125 -0
  51. package/lib/ReactDefaultPerf.js +244 -0
  52. package/lib/ReactDefaultPerfAnalysis.js +199 -0
  53. package/lib/ReactErrorUtils.js +37 -0
  54. package/lib/ReactEventEmitter.js +339 -0
  55. package/lib/ReactEventEmitterMixin.js +57 -0
  56. package/lib/ReactEventTopLevelCallback.js +149 -0
  57. package/lib/ReactInjection.js +43 -0
  58. package/lib/ReactInputSelection.js +141 -0
  59. package/lib/ReactInstanceHandles.js +338 -0
  60. package/lib/ReactLink.js +54 -0
  61. package/lib/ReactMarkupChecksum.js +53 -0
  62. package/lib/ReactMount.js +649 -0
  63. package/lib/ReactMountReady.js +95 -0
  64. package/lib/ReactMultiChild.js +432 -0
  65. package/lib/ReactMultiChildUpdateTypes.js +38 -0
  66. package/lib/ReactOwner.js +159 -0
  67. package/lib/ReactPerf.js +85 -0
  68. package/lib/ReactPropTransferer.js +147 -0
  69. package/lib/ReactPropTypeLocationNames.js +31 -0
  70. package/lib/ReactPropTypeLocations.js +29 -0
  71. package/lib/ReactPropTypes.js +359 -0
  72. package/lib/ReactPutListenerQueue.js +61 -0
  73. package/lib/ReactReconcileTransaction.js +182 -0
  74. package/lib/ReactRootIndex.js +36 -0
  75. package/lib/ReactServerRendering.js +89 -0
  76. package/lib/ReactServerRenderingTransaction.js +116 -0
  77. package/lib/ReactStateSetters.js +111 -0
  78. package/lib/ReactTestUtils.js +394 -0
  79. package/lib/ReactTextComponent.js +121 -0
  80. package/lib/ReactTransitionChildMapping.js +106 -0
  81. package/lib/ReactTransitionEvents.js +97 -0
  82. package/lib/ReactTransitionGroup.js +187 -0
  83. package/lib/ReactUpdates.js +148 -0
  84. package/lib/ReactWithAddons.js +53 -0
  85. package/lib/SelectEventPlugin.js +200 -0
  86. package/lib/ServerReactRootIndex.js +36 -0
  87. package/lib/SimpleEventPlugin.js +413 -0
  88. package/lib/SyntheticClipboardEvent.js +51 -0
  89. package/lib/SyntheticCompositionEvent.js +51 -0
  90. package/lib/SyntheticDragEvent.js +44 -0
  91. package/lib/SyntheticEvent.js +164 -0
  92. package/lib/SyntheticFocusEvent.js +44 -0
  93. package/lib/SyntheticKeyboardEvent.js +58 -0
  94. package/lib/SyntheticMouseEvent.js +85 -0
  95. package/lib/SyntheticTouchEvent.js +50 -0
  96. package/lib/SyntheticUIEvent.js +45 -0
  97. package/lib/SyntheticWheelEvent.js +66 -0
  98. package/lib/Transaction.js +276 -0
  99. package/lib/ViewportMetrics.js +37 -0
  100. package/lib/accumulate.js +54 -0
  101. package/lib/adler32.js +39 -0
  102. package/lib/cloneWithProps.js +59 -0
  103. package/lib/containsNode.js +49 -0
  104. package/lib/copyProperties.js +54 -0
  105. package/lib/createArrayFrom.js +91 -0
  106. package/lib/createFullPageComponent.js +63 -0
  107. package/lib/createNodesFromMarkup.js +93 -0
  108. package/lib/createObjectFrom.js +61 -0
  109. package/lib/cx.js +44 -0
  110. package/lib/dangerousStyleValue.js +57 -0
  111. package/lib/emptyFunction.js +43 -0
  112. package/lib/emptyObject.js +27 -0
  113. package/lib/escapeTextForBrowser.js +47 -0
  114. package/lib/flattenChildren.js +57 -0
  115. package/lib/focusNode.js +33 -0
  116. package/lib/forEachAccumulated.js +36 -0
  117. package/lib/getActiveElement.js +34 -0
  118. package/lib/getEventKey.js +85 -0
  119. package/lib/getEventTarget.js +36 -0
  120. package/lib/getMarkupWrap.js +118 -0
  121. package/lib/getNodeForCharacterOffset.js +80 -0
  122. package/lib/getReactRootElementInContainer.js +40 -0
  123. package/lib/getTextContentAccessor.js +42 -0
  124. package/lib/getUnboundedScrollPosition.js +45 -0
  125. package/lib/hyphenate.js +35 -0
  126. package/lib/instantiateReactComponent.js +70 -0
  127. package/lib/invariant.js +62 -0
  128. package/lib/isEventSupported.js +70 -0
  129. package/lib/isNode.js +33 -0
  130. package/lib/isTextInputElement.js +49 -0
  131. package/lib/isTextNode.js +30 -0
  132. package/lib/joinClasses.js +44 -0
  133. package/lib/keyMirror.js +58 -0
  134. package/lib/keyOf.js +41 -0
  135. package/lib/memoizeStringOnly.js +39 -0
  136. package/lib/merge.js +37 -0
  137. package/lib/mergeHelpers.js +136 -0
  138. package/lib/mergeInto.js +45 -0
  139. package/lib/mixInto.js +34 -0
  140. package/lib/monitorCodeUse.js +37 -0
  141. package/lib/objMap.js +47 -0
  142. package/lib/objMapKeyVal.js +47 -0
  143. package/lib/onlyChild.js +43 -0
  144. package/lib/performanceNow.js +42 -0
  145. package/lib/shallowEqual.js +49 -0
  146. package/lib/shouldUpdateReactComponent.js +61 -0
  147. package/lib/toArray.js +75 -0
  148. package/lib/traverseAllChildren.js +190 -0
  149. package/lib/update.js +159 -0
  150. package/lib/warning.js +48 -0
  151. package/package.json +33 -31
  152. package/react.js +1 -0
  153. package/.npmignore +0 -7
  154. package/.travis.yml +0 -7
  155. package/Jakefile.js +0 -39
  156. package/LICENSE +0 -19
  157. package/browser-test/dist.html +0 -90
  158. package/browser-test/index.html +0 -86
  159. package/browser-test/min.html +0 -90
  160. package/dist/react.js +0 -3141
  161. package/dist/react.min.js +0 -22
  162. package/doc/advanced.md +0 -175
  163. package/doc/color-def.graffle +0 -938
  164. package/doc/color-def.png +0 -0
  165. package/doc/simple.dot +0 -25
  166. package/doc/simple.png +0 -0
  167. package/examples/longer-example.js +0 -41
  168. package/examples/simple.js +0 -45
  169. package/examples/using-ast-directly.js +0 -30
  170. package/examples/using-events1.js +0 -79
  171. package/examples/using-log-events.js +0 -43
  172. package/lib/base-task.js +0 -120
  173. package/lib/cb-task.js +0 -84
  174. package/lib/core.js +0 -138
  175. package/lib/dsl.js +0 -138
  176. package/lib/error.js +0 -55
  177. package/lib/event-collector.js +0 -81
  178. package/lib/event-manager.js +0 -89
  179. package/lib/eventemitter.js +0 -20
  180. package/lib/finalcb-first-task.js +0 -68
  181. package/lib/finalcb-task.js +0 -65
  182. package/lib/id.js +0 -22
  183. package/lib/input-parser.js +0 -56
  184. package/lib/log-events.js +0 -101
  185. package/lib/parse.js +0 -41
  186. package/lib/promise-resolve.js +0 -50
  187. package/lib/promise-task.js +0 -93
  188. package/lib/react.js +0 -59
  189. package/lib/ret-task.js +0 -71
  190. package/lib/sprintf.js +0 -18
  191. package/lib/status.js +0 -14
  192. package/lib/task.js +0 -251
  193. package/lib/track-tasks.js +0 -74
  194. package/lib/validate.js +0 -159
  195. package/lib/vcon.js +0 -113
  196. package/lib/when-task.js +0 -84
  197. package/src/dist.build.requirejs +0 -20
  198. package/test/ast.mocha.js +0 -136
  199. package/test/cb-task.mocha.js +0 -220
  200. package/test/core-deferred.mocha.js +0 -143
  201. package/test/core-when.mocha.js +0 -96
  202. package/test/core.mocha.js +0 -589
  203. package/test/dsl.mocha.js +0 -352
  204. package/test/event-manager.mocha.js +0 -119
  205. package/test/exec-options.mocha.js +0 -48
  206. package/test/finalcb-task.mocha.js +0 -58
  207. package/test/input-parser.mocha.js +0 -86
  208. package/test/log-events.mocha.js +0 -88
  209. package/test/mocha.opts +0 -2
  210. package/test/module-use.mocha.js +0 -164
  211. package/test/promise-auto-resolve.mocha.js +0 -68
  212. package/test/ret-task.mocha.js +0 -220
  213. package/test/task.mocha.js +0 -42
  214. package/test/validate-cb-task.mocha.js +0 -100
  215. package/test/validate-ret-task.mocha.js +0 -110
  216. package/test/validate.mocha.js +0 -324
  217. package/test/vcon.mocha.js +0 -193
  218. package/vendor/chai/chai.js +0 -4251
  219. package/vendor/jquery/jquery-1.7.1.js +0 -9266
  220. package/vendor/jquery/jquery-1.7.1.min.js +0 -4
  221. package/vendor/node/util.js +0 -531
  222. package/vendor/requirejs/require.js +0 -2045
  223. package/vendor/requirejs/require.min.js +0 -36
@@ -0,0 +1,30 @@
1
+ /**
2
+ * Copyright 2013-2014 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 ClientReactRootIndex
17
+ * @typechecks
18
+ */
19
+
20
+ "use strict";
21
+
22
+ var nextReactRootIndex = 0;
23
+
24
+ var ClientReactRootIndex = {
25
+ createReactRootIndex: function() {
26
+ return nextReactRootIndex++;
27
+ }
28
+ };
29
+
30
+ module.exports = ClientReactRootIndex;
@@ -0,0 +1,260 @@
1
+ /**
2
+ * Copyright 2013-2014 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 CompositionEventPlugin
17
+ * @typechecks static-only
18
+ */
19
+
20
+ "use strict";
21
+
22
+ var EventConstants = require("./EventConstants");
23
+ var EventPropagators = require("./EventPropagators");
24
+ var ExecutionEnvironment = require("./ExecutionEnvironment");
25
+ var ReactInputSelection = require("./ReactInputSelection");
26
+ var SyntheticCompositionEvent = require("./SyntheticCompositionEvent");
27
+
28
+ var getTextContentAccessor = require("./getTextContentAccessor");
29
+ var keyOf = require("./keyOf");
30
+
31
+ var END_KEYCODES = [9, 13, 27, 32]; // Tab, Return, Esc, Space
32
+ var START_KEYCODE = 229;
33
+
34
+ var useCompositionEvent = (
35
+ ExecutionEnvironment.canUseDOM &&
36
+ 'CompositionEvent' in window
37
+ );
38
+
39
+ // In IE9+, we have access to composition events, but the data supplied
40
+ // by the native compositionend event may be incorrect. In Korean, for example,
41
+ // the compositionend event contains only one character regardless of
42
+ // how many characters have been composed since compositionstart.
43
+ // We therefore use the fallback data while still using the native
44
+ // events as triggers.
45
+ var useFallbackData = (
46
+ !useCompositionEvent ||
47
+ 'documentMode' in document && document.documentMode > 8
48
+ );
49
+
50
+ var topLevelTypes = EventConstants.topLevelTypes;
51
+ var currentComposition = null;
52
+
53
+ // Events and their corresponding property names.
54
+ var eventTypes = {
55
+ compositionEnd: {
56
+ phasedRegistrationNames: {
57
+ bubbled: keyOf({onCompositionEnd: null}),
58
+ captured: keyOf({onCompositionEndCapture: null})
59
+ },
60
+ dependencies: [
61
+ topLevelTypes.topBlur,
62
+ topLevelTypes.topCompositionEnd,
63
+ topLevelTypes.topKeyDown,
64
+ topLevelTypes.topKeyPress,
65
+ topLevelTypes.topKeyUp,
66
+ topLevelTypes.topMouseDown
67
+ ]
68
+ },
69
+ compositionStart: {
70
+ phasedRegistrationNames: {
71
+ bubbled: keyOf({onCompositionStart: null}),
72
+ captured: keyOf({onCompositionStartCapture: null})
73
+ },
74
+ dependencies: [
75
+ topLevelTypes.topBlur,
76
+ topLevelTypes.topCompositionStart,
77
+ topLevelTypes.topKeyDown,
78
+ topLevelTypes.topKeyPress,
79
+ topLevelTypes.topKeyUp,
80
+ topLevelTypes.topMouseDown
81
+ ]
82
+ },
83
+ compositionUpdate: {
84
+ phasedRegistrationNames: {
85
+ bubbled: keyOf({onCompositionUpdate: null}),
86
+ captured: keyOf({onCompositionUpdateCapture: null})
87
+ },
88
+ dependencies: [
89
+ topLevelTypes.topBlur,
90
+ topLevelTypes.topCompositionUpdate,
91
+ topLevelTypes.topKeyDown,
92
+ topLevelTypes.topKeyPress,
93
+ topLevelTypes.topKeyUp,
94
+ topLevelTypes.topMouseDown
95
+ ]
96
+ }
97
+ };
98
+
99
+ /**
100
+ * Translate native top level events into event types.
101
+ *
102
+ * @param {string} topLevelType
103
+ * @return {object}
104
+ */
105
+ function getCompositionEventType(topLevelType) {
106
+ switch (topLevelType) {
107
+ case topLevelTypes.topCompositionStart:
108
+ return eventTypes.compositionStart;
109
+ case topLevelTypes.topCompositionEnd:
110
+ return eventTypes.compositionEnd;
111
+ case topLevelTypes.topCompositionUpdate:
112
+ return eventTypes.compositionUpdate;
113
+ }
114
+ }
115
+
116
+ /**
117
+ * Does our fallback best-guess model think this event signifies that
118
+ * composition has begun?
119
+ *
120
+ * @param {string} topLevelType
121
+ * @param {object} nativeEvent
122
+ * @return {boolean}
123
+ */
124
+ function isFallbackStart(topLevelType, nativeEvent) {
125
+ return (
126
+ topLevelType === topLevelTypes.topKeyDown &&
127
+ nativeEvent.keyCode === START_KEYCODE
128
+ );
129
+ }
130
+
131
+ /**
132
+ * Does our fallback mode think that this event is the end of composition?
133
+ *
134
+ * @param {string} topLevelType
135
+ * @param {object} nativeEvent
136
+ * @return {boolean}
137
+ */
138
+ function isFallbackEnd(topLevelType, nativeEvent) {
139
+ switch (topLevelType) {
140
+ case topLevelTypes.topKeyUp:
141
+ // Command keys insert or clear IME input.
142
+ return (END_KEYCODES.indexOf(nativeEvent.keyCode) !== -1);
143
+ case topLevelTypes.topKeyDown:
144
+ // Expect IME keyCode on each keydown. If we get any other
145
+ // code we must have exited earlier.
146
+ return (nativeEvent.keyCode !== START_KEYCODE);
147
+ case topLevelTypes.topKeyPress:
148
+ case topLevelTypes.topMouseDown:
149
+ case topLevelTypes.topBlur:
150
+ // Events are not possible without cancelling IME.
151
+ return true;
152
+ default:
153
+ return false;
154
+ }
155
+ }
156
+
157
+ /**
158
+ * Helper class stores information about selection and document state
159
+ * so we can figure out what changed at a later date.
160
+ *
161
+ * @param {DOMEventTarget} root
162
+ */
163
+ function FallbackCompositionState(root) {
164
+ this.root = root;
165
+ this.startSelection = ReactInputSelection.getSelection(root);
166
+ this.startValue = this.getText();
167
+ }
168
+
169
+ /**
170
+ * Get current text of input.
171
+ *
172
+ * @return {string}
173
+ */
174
+ FallbackCompositionState.prototype.getText = function() {
175
+ return this.root.value || this.root[getTextContentAccessor()];
176
+ };
177
+
178
+ /**
179
+ * Text that has changed since the start of composition.
180
+ *
181
+ * @return {string}
182
+ */
183
+ FallbackCompositionState.prototype.getData = function() {
184
+ var endValue = this.getText();
185
+ var prefixLength = this.startSelection.start;
186
+ var suffixLength = this.startValue.length - this.startSelection.end;
187
+
188
+ return endValue.substr(
189
+ prefixLength,
190
+ endValue.length - suffixLength - prefixLength
191
+ );
192
+ };
193
+
194
+ /**
195
+ * This plugin creates `onCompositionStart`, `onCompositionUpdate` and
196
+ * `onCompositionEnd` events on inputs, textareas and contentEditable
197
+ * nodes.
198
+ */
199
+ var CompositionEventPlugin = {
200
+
201
+ eventTypes: eventTypes,
202
+
203
+ /**
204
+ * @param {string} topLevelType Record from `EventConstants`.
205
+ * @param {DOMEventTarget} topLevelTarget The listening component root node.
206
+ * @param {string} topLevelTargetID ID of `topLevelTarget`.
207
+ * @param {object} nativeEvent Native browser event.
208
+ * @return {*} An accumulation of synthetic events.
209
+ * @see {EventPluginHub.extractEvents}
210
+ */
211
+ extractEvents: function(
212
+ topLevelType,
213
+ topLevelTarget,
214
+ topLevelTargetID,
215
+ nativeEvent) {
216
+
217
+ var eventType;
218
+ var data;
219
+
220
+ if (useCompositionEvent) {
221
+ eventType = getCompositionEventType(topLevelType);
222
+ } else if (!currentComposition) {
223
+ if (isFallbackStart(topLevelType, nativeEvent)) {
224
+ eventType = eventTypes.compositionStart;
225
+ }
226
+ } else if (isFallbackEnd(topLevelType, nativeEvent)) {
227
+ eventType = eventTypes.compositionEnd;
228
+ }
229
+
230
+ if (useFallbackData) {
231
+ // The current composition is stored statically and must not be
232
+ // overwritten while composition continues.
233
+ if (!currentComposition && eventType === eventTypes.compositionStart) {
234
+ currentComposition = new FallbackCompositionState(topLevelTarget);
235
+ } else if (eventType === eventTypes.compositionEnd) {
236
+ if (currentComposition) {
237
+ data = currentComposition.getData();
238
+ currentComposition = null;
239
+ }
240
+ }
241
+ }
242
+
243
+ if (eventType) {
244
+ var event = SyntheticCompositionEvent.getPooled(
245
+ eventType,
246
+ topLevelTargetID,
247
+ nativeEvent
248
+ );
249
+ if (data) {
250
+ // Inject data generated from fallback path into the synthetic event.
251
+ // This matches the property of native CompositionEventInterface.
252
+ event.data = data;
253
+ }
254
+ EventPropagators.accumulateTwoPhaseDispatches(event);
255
+ return event;
256
+ }
257
+ }
258
+ };
259
+
260
+ module.exports = CompositionEventPlugin;
@@ -0,0 +1,171 @@
1
+ /**
2
+ * Copyright 2013-2014 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 DOMChildrenOperations
17
+ * @typechecks static-only
18
+ */
19
+
20
+ "use strict";
21
+
22
+ var Danger = require("./Danger");
23
+ var ReactMultiChildUpdateTypes = require("./ReactMultiChildUpdateTypes");
24
+
25
+ var getTextContentAccessor = require("./getTextContentAccessor");
26
+
27
+ /**
28
+ * The DOM property to use when setting text content.
29
+ *
30
+ * @type {string}
31
+ * @private
32
+ */
33
+ var textContentAccessor = getTextContentAccessor();
34
+
35
+ /**
36
+ * Inserts `childNode` as a child of `parentNode` at the `index`.
37
+ *
38
+ * @param {DOMElement} parentNode Parent node in which to insert.
39
+ * @param {DOMElement} childNode Child node to insert.
40
+ * @param {number} index Index at which to insert the child.
41
+ * @internal
42
+ */
43
+ function insertChildAt(parentNode, childNode, index) {
44
+ var childNodes = parentNode.childNodes;
45
+ if (childNodes[index] === childNode) {
46
+ return;
47
+ }
48
+ // If `childNode` is already a child of `parentNode`, remove it so that
49
+ // computing `childNodes[index]` takes into account the removal.
50
+ if (childNode.parentNode === parentNode) {
51
+ parentNode.removeChild(childNode);
52
+ }
53
+ if (index >= childNodes.length) {
54
+ parentNode.appendChild(childNode);
55
+ } else {
56
+ parentNode.insertBefore(childNode, childNodes[index]);
57
+ }
58
+ }
59
+
60
+ var updateTextContent;
61
+ if (textContentAccessor === 'textContent') {
62
+ /**
63
+ * Sets the text content of `node` to `text`.
64
+ *
65
+ * @param {DOMElement} node Node to change
66
+ * @param {string} text New text content
67
+ */
68
+ updateTextContent = function(node, text) {
69
+ node.textContent = text;
70
+ };
71
+ } else {
72
+ /**
73
+ * Sets the text content of `node` to `text`.
74
+ *
75
+ * @param {DOMElement} node Node to change
76
+ * @param {string} text New text content
77
+ */
78
+ updateTextContent = function(node, text) {
79
+ // In order to preserve newlines correctly, we can't use .innerText to set
80
+ // the contents (see #1080), so we empty the element then append a text node
81
+ while (node.firstChild) {
82
+ node.removeChild(node.firstChild);
83
+ }
84
+ if (text) {
85
+ var doc = node.ownerDocument || document;
86
+ node.appendChild(doc.createTextNode(text));
87
+ }
88
+ };
89
+ }
90
+
91
+ /**
92
+ * Operations for updating with DOM children.
93
+ */
94
+ var DOMChildrenOperations = {
95
+
96
+ dangerouslyReplaceNodeWithMarkup: Danger.dangerouslyReplaceNodeWithMarkup,
97
+
98
+ updateTextContent: updateTextContent,
99
+
100
+ /**
101
+ * Updates a component's children by processing a series of updates. The
102
+ * update configurations are each expected to have a `parentNode` property.
103
+ *
104
+ * @param {array<object>} updates List of update configurations.
105
+ * @param {array<string>} markupList List of markup strings.
106
+ * @internal
107
+ */
108
+ processUpdates: function(updates, markupList) {
109
+ var update;
110
+ // Mapping from parent IDs to initial child orderings.
111
+ var initialChildren = null;
112
+ // List of children that will be moved or removed.
113
+ var updatedChildren = null;
114
+
115
+ for (var i = 0; update = updates[i]; i++) {
116
+ if (update.type === ReactMultiChildUpdateTypes.MOVE_EXISTING ||
117
+ update.type === ReactMultiChildUpdateTypes.REMOVE_NODE) {
118
+ var updatedIndex = update.fromIndex;
119
+ var updatedChild = update.parentNode.childNodes[updatedIndex];
120
+ var parentID = update.parentID;
121
+
122
+ initialChildren = initialChildren || {};
123
+ initialChildren[parentID] = initialChildren[parentID] || [];
124
+ initialChildren[parentID][updatedIndex] = updatedChild;
125
+
126
+ updatedChildren = updatedChildren || [];
127
+ updatedChildren.push(updatedChild);
128
+ }
129
+ }
130
+
131
+ var renderedMarkup = Danger.dangerouslyRenderMarkup(markupList);
132
+
133
+ // Remove updated children first so that `toIndex` is consistent.
134
+ if (updatedChildren) {
135
+ for (var j = 0; j < updatedChildren.length; j++) {
136
+ updatedChildren[j].parentNode.removeChild(updatedChildren[j]);
137
+ }
138
+ }
139
+
140
+ for (var k = 0; update = updates[k]; k++) {
141
+ switch (update.type) {
142
+ case ReactMultiChildUpdateTypes.INSERT_MARKUP:
143
+ insertChildAt(
144
+ update.parentNode,
145
+ renderedMarkup[update.markupIndex],
146
+ update.toIndex
147
+ );
148
+ break;
149
+ case ReactMultiChildUpdateTypes.MOVE_EXISTING:
150
+ insertChildAt(
151
+ update.parentNode,
152
+ initialChildren[update.parentID][update.fromIndex],
153
+ update.toIndex
154
+ );
155
+ break;
156
+ case ReactMultiChildUpdateTypes.TEXT_CONTENT:
157
+ updateTextContent(
158
+ update.parentNode,
159
+ update.textContent
160
+ );
161
+ break;
162
+ case ReactMultiChildUpdateTypes.REMOVE_NODE:
163
+ // Already removed by the for-loop above.
164
+ break;
165
+ }
166
+ }
167
+ }
168
+
169
+ };
170
+
171
+ module.exports = DOMChildrenOperations;