From 6bffa6c8a8a06bfdb7ecf2d4fb73d1a55877d375 Mon Sep 17 00:00:00 2001 From: Christopher Chedeau Date: Fri, 29 May 2015 15:24:00 -0700 Subject: [PATCH 1/8] [ReactNative] Unbreak flow errors --- Libraries/Components/TextInput/TextInput.js | 2 +- Libraries/Text/Text.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/Libraries/Components/TextInput/TextInput.js b/Libraries/Components/TextInput/TextInput.js index 5d9f63d6b..03f374b67 100644 --- a/Libraries/Components/TextInput/TextInput.js +++ b/Libraries/Components/TextInput/TextInput.js @@ -407,7 +407,7 @@ var TextInput = React.createClass({ } }, - getChildContext: function() { + getChildContext: function(): Object { return {isInAParentText: true}; }, diff --git a/Libraries/Text/Text.js b/Libraries/Text/Text.js index 55b38907a..7ff16c5d9 100644 --- a/Libraries/Text/Text.js +++ b/Libraries/Text/Text.js @@ -179,7 +179,7 @@ var Text = React.createClass({ return PRESS_RECT_OFFSET; }, - getChildContext: function() { + getChildContext: function(): Object { return {isInAParentText: true}; }, From f8b3c98bc6513fa42439a7ac29f910071527ddbb Mon Sep 17 00:00:00 2001 From: Tadeu Zagallo Date: Fri, 29 May 2015 22:18:57 -0100 Subject: [PATCH 2/8] [ReactNative] Remove AnimationUtils tests --- .../__tests__/AnimationUtils-test.js | 54 ------------------- 1 file changed, 54 deletions(-) delete mode 100644 Libraries/Animation/__tests__/AnimationUtils-test.js diff --git a/Libraries/Animation/__tests__/AnimationUtils-test.js b/Libraries/Animation/__tests__/AnimationUtils-test.js deleted file mode 100644 index 32c73ec60..000000000 --- a/Libraries/Animation/__tests__/AnimationUtils-test.js +++ /dev/null @@ -1,54 +0,0 @@ -/** - * Copyright (c) 2015-present, Facebook, Inc. - * All rights reserved. - * - * This source code is licensed under the BSD-style license found in the - * LICENSE file in the root directory of this source tree. An additional grant - * of patent rights can be found in the PATENTS file in the same directory. - */ -'use strict'; - -jest.autoMockOff(); - -var AnimationUtils = require('AnimationUtils'); - -describe('AnimationUtils', function() { - var DURATION = 300; - - var Samples = { - easeInQuad: [0,0.0030864197530864196,0.012345679012345678,0.027777777777777776,0.04938271604938271,0.0771604938271605,0.1111111111111111,0.15123456790123457,0.19753086419753085,0.25,0.308641975308642,0.37345679012345684,0.4444444444444444,0.5216049382716049,0.6049382716049383,0.6944444444444445,0.7901234567901234,0.8919753086419753,1], - easeOutQuad: [0,0.10802469135802469,0.20987654320987653,0.3055555555555555,0.3950617283950617,0.47839506172839513,0.5555555555555556,0.6265432098765432,0.691358024691358,0.75,0.8024691358024691,0.8487654320987654,0.888888888888889,0.9228395061728394,0.9506172839506174,0.9722222222222221,0.9876543209876543,0.9969135802469136,1], - easeInOutQuad: [0,0.006172839506172839,0.024691358024691357,0.05555555555555555,0.09876543209876543,0.154320987654321,0.2222222222222222,0.30246913580246915,0.3950617283950617,0.5,0.6049382716049383,0.697530864197531,0.7777777777777777,0.845679012345679,0.9012345679012346,0.9444444444444444,0.9753086419753086,0.9938271604938271,1], - easeInCubic: [0,0.00017146776406035664,0.0013717421124828531,0.004629629629629629,0.010973936899862825,0.021433470507544586,0.037037037037037035,0.05881344307270234,0.0877914951989026,0.125,0.1714677640603567,0.22822359396433475,0.2962962962962963,0.37671467764060357,0.4705075445816187,0.5787037037037038,0.7023319615912208,0.8424211248285322,1], - easeOutCubic: [0,0.15757887517146785,0.2976680384087792,0.42129629629629617,0.5294924554183813,0.6232853223593964,0.7037037037037036,0.7717764060356652,0.8285322359396433,0.875,0.9122085048010974,0.9411865569272977,0.9629629629629629,0.9785665294924554,0.9890260631001372,0.9953703703703703,0.9986282578875172,0.9998285322359396,1], - easeInOutCubic: [0,0.0006858710562414266,0.0054869684499314125,0.018518518518518517,0.0438957475994513,0.08573388203017834,0.14814814814814814,0.23525377229080935,0.3511659807956104,0.5,0.6488340192043895,0.7647462277091908,0.8518518518518519,0.9142661179698217,0.9561042524005487,0.9814814814814815,0.9945130315500685,0.9993141289437586,1], - easeInQuart: [0,0.000009525986892242035,0.00015241579027587256,0.0007716049382716049,0.002438652644413961,0.005953741807651274,0.012345679012345678,0.02287189452827313,0.039018442310623375,0.0625,0.09525986892242039,0.1394699740893157,0.19753086419753085,0.2720717116293248,0.3659503124523701,0.48225308641975323,0.624295076969974,0.7956199512269471,1], - easeOutQuart: [0,0.20438004877305294,0.375704923030026,0.5177469135802468,0.6340496875476299,0.7279282883706752,0.802469135802469,0.8605300259106843,0.9047401310775796,0.9375,0.9609815576893767,0.9771281054717269,0.9876543209876543,0.9940462581923487,0.997561347355586,0.9992283950617284,0.9998475842097241,0.9999904740131078,1], - easeInOutQuart: [0,0.00007620789513793628,0.0012193263222069805,0.006172839506172839,0.019509221155311687,0.047629934461210194,0.09876543209876543,0.18297515622618504,0.312147538484987,0.5,0.687852461515013,0.8170248437738151,0.9012345679012346,0.9523700655387898,0.9804907788446883,0.9938271604938271,0.998780673677793,0.999923792104862,1], - easeInQuint: [0,5.292214940134463e-7,0.000016935087808430282,0.00012860082304526747,0.000541922809869769,0.0016538171687920206,0.004115226337448559,0.008894625649883995,0.01734152991583261,0.03125,0.05292214940134466,0.08523165083235959,0.1316872427983539,0.1964962361767346,0.28462802079628785,0.401877572016461,0.5549289573066435,0.75141884282545,1], - easeOutQuint: [0,0.24858115717454998,0.4450710426933565,0.598122427983539,0.7153719792037121,0.8035037638232654,0.868312757201646,0.9147683491676404,0.9470778505986553,0.96875,0.9826584700841674,0.991105374350116,0.9958847736625515,0.998346182831208,0.9994580771901302,0.9998713991769548,0.9999830649121916,0.999999470778506,1], - easeInOutQuint: [0,0.000008467543904215141,0.0002709614049348845,0.0020576131687242796,0.008670764957916305,0.02646107470067233,0.06584362139917695,0.14231401039814393,0.27746447865332174,0.5,0.7225355213466782,0.8576859896018563,0.934156378600823,0.9735389252993276,0.9913292350420837,0.9979423868312757,0.9997290385950651,0.9999915324560957,1], - easeInSine: [0,0.003805301908254455,0.01519224698779198,0.03407417371093169,0.06030737921409157,0.09369221296335006,0.1339745962155613,0.1808479557110082,0.233955556881022,0.2928932188134524,0.35721239031346064,0.42642356364895384,0.4999999999999999,0.5773817382593005,0.6579798566743311,0.7411809548974793,0.8263518223330696,0.9128442572523416,0.9999999999999999], - easeOutSine: [0,0.08715574274765817,0.17364817766693033,0.25881904510252074,0.3420201433256687,0.42261826174069944,0.49999999999999994,0.573576436351046,0.6427876096865393,0.7071067811865475,0.766044443118978,0.8191520442889918,0.8660254037844386,0.9063077870366499,0.9396926207859083,0.9659258262890683,0.984807753012208,0.9961946980917455,1], - easeInOutSine: [0,0.00759612349389599,0.030153689607045786,0.06698729810778065,0.116977778440511,0.17860619515673032,0.24999999999999994,0.32898992833716556,0.4131759111665348,0.49999999999999994,0.5868240888334652,0.6710100716628343,0.7499999999999999,0.8213938048432696,0.883022221559489,0.9330127018922194,0.9698463103929542,0.9924038765061041,1], - easeInExpo: [0,0.0014352875901128893,0.002109491677524035,0.0031003926796253885,0.004556754060844206,0.006697218616039631,0.009843133202303688,0.014466792379488908,0.021262343752724643,0.03125,0.045929202883612456,0.06750373368076916,0.09921256574801243,0.1458161299470146,0.2143109957132682,0.31498026247371835,0.46293735614364506,0.6803950000871883,1], - easeOutExpo: [0,0.31960499991281155,0.5370626438563548,0.6850197375262816,0.7856890042867318,0.8541838700529854,0.9007874342519875,0.9324962663192309,0.9540707971163875,0.96875,0.9787376562472754,0.9855332076205111,0.9901568667976963,0.9933027813839603,0.9954432459391558,0.9968996073203746,0.9978905083224759,0.9985647124098871,1], - easeInOutExpo: [0,0.0010547458387620175,0.002278377030422103,0.004921566601151844,0.010631171876362321,0.022964601441806228,0.049606282874006216,0.1071554978566341,0.23146867807182253,0.5,0.7685313219281775,0.892844502143366,0.9503937171259937,0.9770353985581938,0.9893688281236377,0.9950784333988482,0.9977216229695779,0.998945254161238,1], - easeInCirc: [0,0.0015444024660317135,0.006192010000093506,0.013986702816730645,0.025003956956430873,0.03935464078941209,0.057190958417936644,0.07871533601238889,0.10419358352238339,0.1339745962155614,0.1685205807169019,0.20845517506805522,0.2546440075000701,0.3083389112228482,0.37146063894529113,0.4472292016074334,0.5418771527091488,0.6713289009389102,1], - easeOutCirc: [0,0.3286710990610898,0.45812284729085123,0.5527707983925666,0.6285393610547089,0.6916610887771518,0.7453559924999298,0.7915448249319448,0.8314794192830981,0.8660254037844386,0.8958064164776166,0.9212846639876111,0.9428090415820634,0.9606453592105879,0.9749960430435691,0.9860132971832694,0.9938079899999065,0.9984555975339683,1], - easeInOutCirc: [0,0.003096005000046753,0.012501978478215436,0.028595479208968322,0.052096791761191696,0.08426029035845095,0.12732200375003505,0.18573031947264557,0.2709385763545744,0.5,0.7290614236454256,0.8142696805273546,0.8726779962499649,0.915739709641549,0.9479032082388084,0.9714045207910317,0.9874980215217846,0.9969039949999532,1], - easeInElastic: [0,0.0008570943160003016,0.0020526300563455885,0.0005383775388688477,-0.003807112477441741,-0.005595444524068916,0.0017092421431128787,0.014076838118604966,0.012696991251677569,-0.015625000000000045,-0.045618646044515744,-0.01936028903971309,0.07600123467884114,0.13030605320629246,-0.012461076179381799,-0.29598462833976175,-0.3176868895106366,0.2694906924487451,1], - easeOutElastic: [0,0.7305093075512543,1.3176868895106364,1.2959846283397618,1.0124610761793817,0.8696939467937076,0.9239987653211588,1.019360289039713,1.0456186460445158,1.015625,0.9873030087483224,0.9859231618813951,0.9982907578568871,1.005595444524069,1.0038071124774417,0.9994616224611311,0.9979473699436544,0.9991429056839997,1], - easeInOutElastic: [0,0.0010420781824747765,-0.0003083357248478688,-0.004888288728445655,0.0010292130059457788,0.022895545534212507,-0.0028843488305936938,-0.10707491183281304,0.004488485931276091,0.5,0.995511514068724,1.107074911832813,1.0028843488305939,0.9771044544657875,0.9989707869940542,1.0048882887284456,1.000308335724848,0.9989579218175252,1], - easeInBack: [0,-0.004788556241426612,-0.017301289437585736,-0.0347587962962963,-0.05438167352537723,-0.07339051783264748,-0.08900592592592595,-0.09844849451303156,-0.0989388203017833,-0.08769750000000004,-0.06194513031550073,-0.018902307956104283,0.044210370370370254,0.13017230795610413,0.2417629080932785,0.3817615740740742,0.5529477091906719,0.7581007167352535,0.9999999999999998], - easeOutBack: [2.220446049250313e-16,0.24189928326474652,0.44705229080932807,0.6182384259259258,0.7582370919067215,0.8698276920438959,0.9557896296296297,1.0189023079561044,1.0619451303155008,1.0876975,1.0989388203017834,1.0984484945130315,1.089005925925926,1.0733905178326475,1.0543816735253773,1.0347587962962963,1.0173012894375857,1.0047885562414267,1], - easeInOutBack: [0,-0.01355231550068587,-0.04434668449931412,-0.07758924074074074,-0.09848611796982167,-0.0922434499314129,-0.0440673703703704,0.060835986968449905,0.237260488340192,0.5,0.762739511659808,0.9391640130315503,1.0440673703703702,1.0922434499314129,1.0984861179698218,1.0775892407407408,1.0443466844993141,1.0135523155006858,1], - }; - - Object.keys(Samples).forEach(function(type) { - it('should interpolate ' + type, function() { - expect(AnimationUtils.evaluateEasingFunction(DURATION, type)) - .toEqual(Samples[type]); - }); - }); -}); From 1c692e2eb68e2006964b4397a07bb3c2a5ed4505 Mon Sep 17 00:00:00 2001 From: Tadeu Zagallo Date: Sat, 30 May 2015 13:21:42 -0700 Subject: [PATCH 3/8] [ReactNative] Use JSValueIsUndefined instead of comparing with JSValueMakeUndefined Summary: @public Use JSValueIsUndefined instead of caching an JSValueMakeUndefined to compare with as suggested in https://github.com/facebook/react-native/pull/1432#commitcomment-11437434 Test Plan: Run the RCTContextExecutor tests --- React/Executors/RCTContextExecutor.m | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/React/Executors/RCTContextExecutor.m b/React/Executors/RCTContextExecutor.m index f585edc10..3a2208739 100644 --- a/React/Executors/RCTContextExecutor.m +++ b/React/Executors/RCTContextExecutor.m @@ -66,7 +66,6 @@ { RCTJavaScriptContext *_context; NSThread *_javaScriptThread; - JSValueRef _undefined; } /** @@ -238,9 +237,6 @@ static NSError *RCTNSErrorFromJSError(JSContextRef context, JSValueRef jsError) JSContextGroupRelease(group); } - // Constant value used for comparison - _undefined = JSValueMakeUndefined(ctx); - strongSelf->_context = [[RCTJavaScriptContext alloc] initWithJSContext:ctx]; [strongSelf _addNativeHook:RCTNativeLoggingHook withName:"nativeLoggingHook"]; [strongSelf _addNativeHook:RCTNoop withName:"noop"]; @@ -312,7 +308,7 @@ static NSError *RCTNSErrorFromJSError(JSContextRef context, JSValueRef jsError) JSValueRef requireJSRef = JSObjectGetProperty(contextJSRef, globalObjectJSRef, requireNameJSStringRef, &errorJSRef); JSStringRelease(requireNameJSStringRef); - if (requireJSRef != NULL && requireJSRef != _undefined && errorJSRef == NULL) { + if (requireJSRef != NULL && !JSValueIsUndefined(contextJSRef, requireJSRef) && errorJSRef == NULL) { // get module JSStringRef moduleNameJSStringRef = JSStringCreateWithCFString((__bridge CFStringRef)name); From 09cef03cd35f8ceb90ced1ffd709a3242ede6c23 Mon Sep 17 00:00:00 2001 From: Nick Lockwood Date: Sun, 31 May 2015 11:30:27 -0700 Subject: [PATCH 4/8] revert D2087892 --- Libraries/JavaScriptAppEngine/System/JSTimers/JSTimers.js | 8 ++------ 1 file changed, 2 insertions(+), 6 deletions(-) diff --git a/Libraries/JavaScriptAppEngine/System/JSTimers/JSTimers.js b/Libraries/JavaScriptAppEngine/System/JSTimers/JSTimers.js index 6434541bb..72e75f813 100644 --- a/Libraries/JavaScriptAppEngine/System/JSTimers/JSTimers.js +++ b/Libraries/JavaScriptAppEngine/System/JSTimers/JSTimers.js @@ -60,14 +60,10 @@ var JSTimers = { var freeIndex = JSTimers._getFreeIndex(); JSTimersExecution.timerIDs[freeIndex] = newID; JSTimersExecution.callbacks[freeIndex] = function() { - var startTime = Date.now(); - var ret = func.apply(undefined, args); - var endTime = Date.now(); - RCTTiming.createTimer(newID, Math.max(0, duration - (endTime - startTime)), endTime, false); - return ret; + return func.apply(undefined, args); }; JSTimersExecution.types[freeIndex] = JSTimersExecution.Type.setInterval; - RCTTiming.createTimer(newID, duration, Date.now(), /** recurring */ false); + RCTTiming.createTimer(newID, duration, Date.now(), /** recurring */ true); return newID; }, From c37509727fe220f0276da3343108675d2a8fd43d Mon Sep 17 00:00:00 2001 From: Ben Alpert Date: Sun, 31 May 2015 12:44:18 -0700 Subject: [PATCH 5/8] Set constructor properly in createReactNativeComponentClass Summary: Without this, the displayName property wasn't found when looking at `.constructor` on a component instance. Fixes facebook/react-devtools#92. Closes https://github.com/facebook/react-native/pull/1471 Github Author: Ben Alpert Test Plan: Used devtools on MoviesApp and saw RCTView instead of Unknown: {F22491590} --- Libraries/ReactNative/createReactNativeComponentClass.js | 1 + 1 file changed, 1 insertion(+) diff --git a/Libraries/ReactNative/createReactNativeComponentClass.js b/Libraries/ReactNative/createReactNativeComponentClass.js index c821cfa75..65af58d5e 100644 --- a/Libraries/ReactNative/createReactNativeComponentClass.js +++ b/Libraries/ReactNative/createReactNativeComponentClass.js @@ -36,6 +36,7 @@ var createReactNativeComponentClass = function( }; Constructor.displayName = viewConfig.uiViewClassName; Constructor.prototype = new ReactNativeBaseComponent(viewConfig); + Constructor.prototype.constructor = Constructor; return Constructor; }; From 595eae8b67ccc33ce121a16ffdd90b8a9e3987ab Mon Sep 17 00:00:00 2001 From: Peter Cottle Date: Sun, 31 May 2015 12:53:54 -0700 Subject: [PATCH 6/8] [ErrorMessage] Change error message when app is not registered Summary: So when I first started porting JS files over from LearnGitBranching into a react native project, I some had require errors (for whatever reason) and I hit this error message a decent amount. I eventually understood it had nothing to do with failing to register the component (which btw sounds like some sign-up process, not actually an internal concept) but I figured we could expand on this message and describe why it might be happening. I'm not 100% sure on what the second half should be, but open to feedback on this Closes https://github.com/facebook/react-native/pull/826 Github Author: Peter Cottle Test Plan: Imported from GitHub, without a `Test Plan:` line. --- Libraries/AppRegistry/AppRegistry.js | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/Libraries/AppRegistry/AppRegistry.js b/Libraries/AppRegistry/AppRegistry.js index f36f88132..157cbaa37 100644 --- a/Libraries/AppRegistry/AppRegistry.js +++ b/Libraries/AppRegistry/AppRegistry.js @@ -74,7 +74,9 @@ var AppRegistry = { ); invariant( runnables[appKey] && runnables[appKey].run, - 'Application ' + appKey + ' has not been registered.' + 'Application ' + appKey + ' has not been registered. This ' + + 'is either due to a require() error during initialization ' + + 'or failure to call AppRegistry.registerComponent.' ); runnables[appKey].run(appParameters); }, From df58789f222b90e0261e4608060bca0a3df41f27 Mon Sep 17 00:00:00 2001 From: Jiajie Zhu Date: Sun, 31 May 2015 14:33:59 -0700 Subject: [PATCH 7/8] [RN] fix duplicate observe --- React/Modules/RCTAppState.m | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/React/Modules/RCTAppState.m b/React/Modules/RCTAppState.m index 8c46655c6..cf8f95910 100644 --- a/React/Modules/RCTAppState.m +++ b/React/Modules/RCTAppState.m @@ -48,17 +48,16 @@ RCT_EXPORT_MODULE() for (NSString *name in @[UIApplicationDidBecomeActiveNotification, UIApplicationDidEnterBackgroundNotification, UIApplicationDidFinishLaunchingNotification]) { - [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(handleAppStateDidChange) name:name object:nil]; - - [[NSNotificationCenter defaultCenter] addObserver:self - selector:@selector(handleMemoryWarning) - name:UIApplicationDidReceiveMemoryWarningNotification - object:nil]; } + + [[NSNotificationCenter defaultCenter] addObserver:self + selector:@selector(handleMemoryWarning) + name:UIApplicationDidReceiveMemoryWarningNotification + object:nil]; } return self; } From b03446e27e99e2d6117190c08ffff1bb5f3495a3 Mon Sep 17 00:00:00 2001 From: Tadeu Zagallo Date: Mon, 1 Jun 2015 03:01:55 -0700 Subject: [PATCH 8/8] [ReactNative] Stop traversing the whole view hierarchy every frame Summary: @public `RCTUIManager` would traverse the whole view hierarchy every time there was any call from JS to Native to call `reactBridgeDidFinishTransaction` on the views that would respond to it. This is a deprecated method that is only implemented by 3 classes, so for now we keep track of these views as they're created and just iterate through them on updates. Test Plan: > NOTE: I tested this on UIExplorer, since the internally none of the classes are used I tried to keep it simple, so I added the following to the old code: ``` __block NSUInteger count = 0; UIView *rootView = _viewRegistry[rootViewTag]; RCTTraverseViewNodes(rootView, ^(id view) { count ++; if ([view respondsToSelector:@selector(reactBridgeDidFinishTransaction)]) { [view reactBridgeDidFinishTransaction]; } }); NSLog(@"Views iterated: %zd", count); ``` The output after scrolling 20 sections of the ` - Paging` example was ``` 2015-06-01 00:47:07.351 UIExplorer[67675:1709506] Views iterated: 1549 ``` *every frame* After the change ``` for (id node in _bridgeTransactionListeners) { [node reactBridgeDidFinishTransaction]; } NSLog(@"Views iterated: %zd", _bridgeTransactionListeners.count); ``` ``` 2015-06-01 00:51:23.715 UIExplorer[70355:1716465] Views iterated: 3 ``` No matter how many pages are loaded, the output is always 3. --- React/Modules/RCTUIManager.m | 30 +++++++++++++++++------------- 1 file changed, 17 insertions(+), 13 deletions(-) diff --git a/React/Modules/RCTUIManager.m b/React/Modules/RCTUIManager.m index 636df0406..127cbd9fc 100644 --- a/React/Modules/RCTUIManager.m +++ b/React/Modules/RCTUIManager.m @@ -197,7 +197,8 @@ static UIViewAnimationCurve UIViewAnimationCurveFromRCTAnimationType(RCTAnimatio NSMutableDictionary *_defaultViews; // Main thread only NSDictionary *_viewManagers; NSDictionary *_viewConfigs; - NSUInteger _rootTag; + + NSMutableSet *_bridgeTransactionListeners; } @synthesize bridge = _bridge; @@ -263,7 +264,8 @@ static NSDictionary *RCTViewConfigForModule(Class managerClass, NSString *viewNa // Internal resources _pendingUIBlocks = [[NSMutableArray alloc] init]; _rootViewTags = [[NSMutableSet alloc] init]; - _rootTag = 1; + + _bridgeTransactionListeners = [[NSMutableSet alloc] init]; } return self; } @@ -287,6 +289,7 @@ static NSDictionary *RCTViewConfigForModule(Class managerClass, NSString *viewNa _rootViewTags = nil; _shadowViewRegistry = nil; _viewRegistry = nil; + _bridgeTransactionListeners = nil; _bridge = nil; [_pendingUIBlocksLock lock]; @@ -397,6 +400,10 @@ static NSDictionary *RCTViewConfigForModule(Class managerClass, NSString *viewNa [(id)subview invalidate]; } registry[subview.reactTag] = nil; + + if (registry == _viewRegistry) { + [_bridgeTransactionListeners removeObject:subview]; + } }); } } @@ -482,7 +489,6 @@ static NSDictionary *RCTViewConfigForModule(Class managerClass, NSString *viewNa } // Perform layout (possibly animated) - NSNumber *rootViewTag = rootShadowView.reactTag; return ^(RCTUIManager *uiManager, RCTSparseArray *viewRegistry) { RCTResponseSenderBlock callback = self->_layoutAnimation.callback; __block NSInteger completionsCalled = 0; @@ -547,17 +553,11 @@ static NSDictionary *RCTViewConfigForModule(Class managerClass, NSString *viewNa } /** - * Enumerate all active (attached to a parent) views and call - * reactBridgeDidFinishTransaction on them if they implement it. - * TODO: this is quite inefficient. If this was handled via the - * ViewManager instead, it could be done more efficiently. + * TODO(tadeu): Remove it once and for all */ - UIView *rootView = _viewRegistry[rootViewTag]; - RCTTraverseViewNodes(rootView, ^(id view) { - if ([view respondsToSelector:@selector(reactBridgeDidFinishTransaction)]) { - [view reactBridgeDidFinishTransaction]; - } - }); + for (id node in _bridgeTransactionListeners) { + [node reactBridgeDidFinishTransaction]; + } }; } @@ -844,6 +844,10 @@ RCT_EXPORT_METHOD(createView:(NSNumber *)reactTag view.layer.allowsGroupOpacity = YES; // required for touch handling } RCTSetViewProps(props, view, uiManager->_defaultViews[viewName], manager); + + if ([view respondsToSelector:@selector(reactBridgeDidFinishTransaction)]) { + [uiManager->_bridgeTransactionListeners addObject:view]; + } } viewRegistry[reactTag] = view; }];