mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
d54113d8c4
Summary: `showSoftInputOnFocus` was added in https://github.com/facebook/react-native/issues/25028, but it was only added for Android. There was a lot of discussion on the original issue being addressed (https://github.com/facebook/react-native/issues/14045), that there is a need for this on iOS as well. The issue with iOS was brought up again on https://github.com/facebook/react-native/issues/27243. On a related note, when searching this repo's issues for `showSoftInputOnFocus`, it appears that there are several closed issues that claim that the Android implementation doesn't work (https://github.com/facebook/react-native/issues/25685, https://github.com/facebook/react-native/issues/25687, https://github.com/facebook/react-native/issues/26643). So perhaps the Android implementation needs to be looked at as well (I myself have not gotten around to confirming whether it works or not) ## Changelog [iOS] [Added] - Add showSoftInputOnFocus to TextInput Pull Request resolved: https://github.com/facebook/react-native/pull/28834 Test Plan: You'd use this just like you would in the Android implementation: ```jsx <TextInput showSoftInputOnFocus={false} /> ``` ## GIFs ### Before change  ### After change  Differential Revision: D21418763 Pulled By: shergin fbshipit-source-id: 561e72fc2cf16b30446132f6b96b8aa2b4a92daf
50 lines
2.3 KiB
Objective-C
50 lines
2.3 KiB
Objective-C
/*
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*/
|
|
|
|
#import <UIKit/UIKit.h>
|
|
|
|
@protocol RCTBackedTextInputDelegate;
|
|
@class RCTTextAttributes;
|
|
|
|
NS_ASSUME_NONNULL_BEGIN
|
|
|
|
@protocol RCTBackedTextInputViewProtocol <UITextInput>
|
|
|
|
@property (nonatomic, copy, nullable) NSAttributedString *attributedText;
|
|
@property (nonatomic, copy, nullable) NSString *placeholder;
|
|
@property (nonatomic, strong, nullable) UIColor *placeholderColor;
|
|
@property (nonatomic, assign, readonly) BOOL textWasPasted;
|
|
@property (nonatomic, assign) UIEdgeInsets textContainerInset;
|
|
@property (nonatomic, strong, nullable) UIView *inputAccessoryView;
|
|
@property (nonatomic, strong, nullable) UIView *inputView;
|
|
@property (nonatomic, weak, nullable) id<RCTBackedTextInputDelegate> textInputDelegate;
|
|
@property (nonatomic, readonly) CGSize contentSize;
|
|
@property (nonatomic, strong, nullable) NSDictionary<NSAttributedStringKey,id> *defaultTextAttributes;
|
|
@property (nonatomic, assign) BOOL contextMenuHidden;
|
|
@property (nonatomic, assign, getter=isEditable) BOOL editable;
|
|
@property (nonatomic, assign) BOOL caretHidden;
|
|
@property (nonatomic, assign) BOOL enablesReturnKeyAutomatically;
|
|
@property (nonatomic, assign) UITextFieldViewMode clearButtonMode;
|
|
@property (nonatomic, getter=isScrollEnabled) BOOL scrollEnabled;
|
|
|
|
// This protocol disallows direct access to `selectedTextRange` property because
|
|
// unwise usage of it can break the `delegate` behavior. So, we always have to
|
|
// explicitly specify should `delegate` be notified about the change or not.
|
|
// If the change was initiated programmatically, we must NOT notify the delegate.
|
|
// If the change was a result of user actions (like typing or touches), we MUST notify the delegate.
|
|
- (void)setSelectedTextRange:(nullable UITextRange *)selectedTextRange NS_UNAVAILABLE;
|
|
- (void)setSelectedTextRange:(nullable UITextRange *)selectedTextRange notifyDelegate:(BOOL)notifyDelegate;
|
|
|
|
// This protocol disallows direct access to `text` property because
|
|
// unwise usage of it can break the `attributeText` behavior.
|
|
// Use `attributedText.string` instead.
|
|
@property (nonatomic, copy, nullable) NSString *text NS_UNAVAILABLE;
|
|
|
|
@end
|
|
|
|
NS_ASSUME_NONNULL_END
|