diff --git a/Libraries/Text/TextInput/RCTBaseTextInputView.m b/Libraries/Text/TextInput/RCTBaseTextInputView.m index bbee808e7ca5ca..fac75588340e52 100644 --- a/Libraries/Text/TextInput/RCTBaseTextInputView.m +++ b/Libraries/Text/TextInput/RCTBaseTextInputView.m @@ -404,18 +404,12 @@ - (BOOL)textInputShouldChangeTextInRange:(NSRange)range replacementText:(NSStrin } } - if (range.location + range.length > _predictedText.length) { - // _predictedText got out of sync in a bad way, so let's just force sync it. Haven't been able to repro this, but - // it's causing a real crash here: #6523822 + NSString *previousText = backedTextInputView.attributedText.string ?: @""; + + if (range.location + range.length > backedTextInputView.attributedText.string.length) { _predictedText = backedTextInputView.attributedText.string; - } - - NSString *previousText = [_predictedText substringWithRange:range] ?: @""; - - if (!_predictedText || backedTextInputView.attributedText.string.length == 0) { - _predictedText = text; } else { - _predictedText = [_predictedText stringByReplacingCharactersInRange:range withString:text]; + _predictedText = [backedTextInputView.attributedText.string stringByReplacingCharactersInRange:range withString:text]; } if (_onTextInput) { @@ -450,7 +444,6 @@ - (void)textInputDidChange [self textInputShouldChangeTextInRange:predictionRange replacementText:replacement]; // JS will assume the selection changed based on the location of our shouldChangeTextInRange, so reset it. [self textInputDidChangeSelection]; - _predictedText = backedTextInputView.attributedText.string; } _nativeEventCount++;