yeet
This commit is contained in:
563
node_modules/react-native/Libraries/Components/TextInput/AndroidTextInputNativeComponent.js
generated
vendored
Normal file
563
node_modules/react-native/Libraries/Components/TextInput/AndroidTextInputNativeComponent.js
generated
vendored
Normal file
@ -0,0 +1,563 @@
|
||||
/**
|
||||
* 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.
|
||||
*
|
||||
* @flow strict-local
|
||||
* @format
|
||||
*/
|
||||
|
||||
'use strict';
|
||||
|
||||
import type {ViewProps} from '../View/ViewPropTypes';
|
||||
import type {
|
||||
BubblingEventHandler,
|
||||
DirectEventHandler,
|
||||
Double,
|
||||
Float,
|
||||
Int32,
|
||||
WithDefault,
|
||||
} from '../../Types/CodegenTypes';
|
||||
import type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';
|
||||
import type {TextStyleProp, ViewStyleProp} from '../../StyleSheet/StyleSheet';
|
||||
import type {ColorValue} from '../../StyleSheet/StyleSheetTypes';
|
||||
import requireNativeComponent from '../../ReactNative/requireNativeComponent';
|
||||
import codegenNativeCommands from '../../Utilities/codegenNativeCommands';
|
||||
import type {TextInputNativeCommands} from './TextInputNativeCommands';
|
||||
import * as React from 'react';
|
||||
import AndroidTextInputViewConfig from './AndroidTextInputViewConfig';
|
||||
const ReactNativeViewConfigRegistry = require('../../Renderer/shims/ReactNativeViewConfigRegistry');
|
||||
|
||||
export type KeyboardType =
|
||||
// Cross Platform
|
||||
| 'default'
|
||||
| 'email-address'
|
||||
| 'numeric'
|
||||
| 'phone-pad'
|
||||
| 'number-pad'
|
||||
| 'decimal-pad'
|
||||
// iOS-only
|
||||
| 'ascii-capable'
|
||||
| 'numbers-and-punctuation'
|
||||
| 'url'
|
||||
| 'name-phone-pad'
|
||||
| 'twitter'
|
||||
| 'web-search'
|
||||
// Android-only
|
||||
| 'visible-password';
|
||||
|
||||
export type ReturnKeyType =
|
||||
// Cross Platform
|
||||
| 'done'
|
||||
| 'go'
|
||||
| 'next'
|
||||
| 'search'
|
||||
| 'send'
|
||||
// Android-only
|
||||
| 'none'
|
||||
| 'previous'
|
||||
// iOS-only
|
||||
| 'default'
|
||||
| 'emergency-call'
|
||||
| 'google'
|
||||
| 'join'
|
||||
| 'route'
|
||||
| 'yahoo';
|
||||
|
||||
export type NativeProps = $ReadOnly<{|
|
||||
// This allows us to inherit everything from ViewProps except for style (see below)
|
||||
// This must be commented for Fabric codegen to work.
|
||||
...$Diff<ViewProps, $ReadOnly<{|style: ?ViewStyleProp|}>>,
|
||||
|
||||
/**
|
||||
* Android props after this
|
||||
*/
|
||||
/**
|
||||
* Determines which content to suggest on auto complete, e.g.`username`.
|
||||
* To disable auto complete, use `off`.
|
||||
*
|
||||
* *Android Only*
|
||||
*
|
||||
* The following values work on Android only:
|
||||
*
|
||||
* - `username`
|
||||
* - `password`
|
||||
* - `email`
|
||||
* - `name`
|
||||
* - `tel`
|
||||
* - `street-address`
|
||||
* - `postal-code`
|
||||
* - `cc-number`
|
||||
* - `cc-csc`
|
||||
* - `cc-exp`
|
||||
* - `cc-exp-month`
|
||||
* - `cc-exp-year`
|
||||
* - `off`
|
||||
*
|
||||
* @platform android
|
||||
*/
|
||||
autoCompleteType?: WithDefault<
|
||||
| 'cc-csc'
|
||||
| 'cc-exp'
|
||||
| 'cc-exp-month'
|
||||
| 'cc-exp-year'
|
||||
| 'cc-number'
|
||||
| 'email'
|
||||
| 'name'
|
||||
| 'password'
|
||||
| 'postal-code'
|
||||
| 'street-address'
|
||||
| 'tel'
|
||||
| 'username'
|
||||
| 'off',
|
||||
'off',
|
||||
>,
|
||||
|
||||
/**
|
||||
* Sets the return key to the label. Use it instead of `returnKeyType`.
|
||||
* @platform android
|
||||
*/
|
||||
returnKeyLabel?: ?string,
|
||||
|
||||
/**
|
||||
* Sets the number of lines for a `TextInput`. Use it with multiline set to
|
||||
* `true` to be able to fill the lines.
|
||||
* @platform android
|
||||
*/
|
||||
numberOfLines?: ?Int32,
|
||||
|
||||
/**
|
||||
* When `false`, if there is a small amount of space available around a text input
|
||||
* (e.g. landscape orientation on a phone), the OS may choose to have the user edit
|
||||
* the text inside of a full screen text input mode. When `true`, this feature is
|
||||
* disabled and users will always edit the text directly inside of the text input.
|
||||
* Defaults to `false`.
|
||||
* @platform android
|
||||
*/
|
||||
disableFullscreenUI?: ?boolean,
|
||||
|
||||
/**
|
||||
* Set text break strategy on Android API Level 23+, possible values are `simple`, `highQuality`, `balanced`
|
||||
* The default value is `simple`.
|
||||
* @platform android
|
||||
*/
|
||||
textBreakStrategy?: WithDefault<
|
||||
'simple' | 'highQuality' | 'balanced',
|
||||
'simple',
|
||||
>,
|
||||
|
||||
/**
|
||||
* The color of the `TextInput` underline.
|
||||
* @platform android
|
||||
*/
|
||||
underlineColorAndroid?: ?ColorValue,
|
||||
|
||||
/**
|
||||
* If defined, the provided image resource will be rendered on the left.
|
||||
* The image resource must be inside `/android/app/src/main/res/drawable` and referenced
|
||||
* like
|
||||
* ```
|
||||
* <TextInput
|
||||
* inlineImageLeft='search_icon'
|
||||
* />
|
||||
* ```
|
||||
* @platform android
|
||||
*/
|
||||
inlineImageLeft?: ?string,
|
||||
|
||||
/**
|
||||
* Padding between the inline image, if any, and the text input itself.
|
||||
* @platform android
|
||||
*/
|
||||
inlineImagePadding?: ?Int32,
|
||||
|
||||
importantForAutofill?: string /*?(
|
||||
| 'auto'
|
||||
| 'no'
|
||||
| 'noExcludeDescendants'
|
||||
| 'yes'
|
||||
| 'yesExcludeDescendants'
|
||||
),*/,
|
||||
|
||||
/**
|
||||
* When `false`, it will prevent the soft keyboard from showing when the field is focused.
|
||||
* Defaults to `true`.
|
||||
* @platform android
|
||||
*/
|
||||
showSoftInputOnFocus?: ?boolean,
|
||||
|
||||
/**
|
||||
* TextInput props after this
|
||||
*/
|
||||
/**
|
||||
* Can tell `TextInput` to automatically capitalize certain characters.
|
||||
*
|
||||
* - `characters`: all characters.
|
||||
* - `words`: first letter of each word.
|
||||
* - `sentences`: first letter of each sentence (*default*).
|
||||
* - `none`: don't auto capitalize anything.
|
||||
*/
|
||||
autoCapitalize?: WithDefault<
|
||||
'none' | 'sentences' | 'words' | 'characters',
|
||||
'none',
|
||||
>,
|
||||
|
||||
/**
|
||||
* If `false`, disables auto-correct. The default value is `true`.
|
||||
*/
|
||||
autoCorrect?: ?boolean,
|
||||
|
||||
/**
|
||||
* If `true`, focuses the input on `componentDidMount`.
|
||||
* The default value is `false`.
|
||||
*/
|
||||
autoFocus?: ?boolean,
|
||||
|
||||
/**
|
||||
* Specifies whether fonts should scale to respect Text Size accessibility settings. The
|
||||
* default is `true`.
|
||||
*/
|
||||
allowFontScaling?: ?boolean,
|
||||
|
||||
/**
|
||||
* Specifies largest possible scale a font can reach when `allowFontScaling` is enabled.
|
||||
* Possible values:
|
||||
* `null/undefined` (default): inherit from the parent node or the global default (0)
|
||||
* `0`: no max, ignore parent/global default
|
||||
* `>= 1`: sets the maxFontSizeMultiplier of this node to this value
|
||||
*/
|
||||
maxFontSizeMultiplier?: ?Float,
|
||||
|
||||
/**
|
||||
* If `false`, text is not editable. The default value is `true`.
|
||||
*/
|
||||
editable?: ?boolean,
|
||||
|
||||
/**
|
||||
* Determines which keyboard to open, e.g.`numeric`.
|
||||
*
|
||||
* The following values work across platforms:
|
||||
*
|
||||
* - `default`
|
||||
* - `numeric`
|
||||
* - `number-pad`
|
||||
* - `decimal-pad`
|
||||
* - `email-address`
|
||||
* - `phone-pad`
|
||||
*
|
||||
* *Android Only*
|
||||
*
|
||||
* The following values work on Android only:
|
||||
*
|
||||
* - `visible-password`
|
||||
*/
|
||||
keyboardType?: WithDefault<KeyboardType, 'default'>,
|
||||
|
||||
/**
|
||||
* Determines how the return key should look. On Android you can also use
|
||||
* `returnKeyLabel`.
|
||||
*
|
||||
* *Cross platform*
|
||||
*
|
||||
* The following values work across platforms:
|
||||
*
|
||||
* - `done`
|
||||
* - `go`
|
||||
* - `next`
|
||||
* - `search`
|
||||
* - `send`
|
||||
*
|
||||
* *Android Only*
|
||||
*
|
||||
* The following values work on Android only:
|
||||
*
|
||||
* - `none`
|
||||
* - `previous`
|
||||
*/
|
||||
returnKeyType?: WithDefault<ReturnKeyType, 'done'>,
|
||||
|
||||
/**
|
||||
* Limits the maximum number of characters that can be entered. Use this
|
||||
* instead of implementing the logic in JS to avoid flicker.
|
||||
*/
|
||||
maxLength?: ?Int32,
|
||||
|
||||
/**
|
||||
* If `true`, the text input can be multiple lines.
|
||||
* The default value is `false`.
|
||||
*/
|
||||
multiline?: ?boolean,
|
||||
|
||||
/**
|
||||
* Callback that is called when the text input is blurred.
|
||||
* `target` is the reactTag of the element
|
||||
*/
|
||||
onBlur?: ?BubblingEventHandler<$ReadOnly<{|target: Int32|}>>,
|
||||
|
||||
/**
|
||||
* Callback that is called when the text input is focused.
|
||||
* `target` is the reactTag of the element
|
||||
*/
|
||||
onFocus?: ?BubblingEventHandler<$ReadOnly<{|target: Int32|}>>,
|
||||
|
||||
/**
|
||||
* Callback that is called when the text input's text changes.
|
||||
* `target` is the reactTag of the element
|
||||
* TODO: differentiate between onChange and onChangeText
|
||||
*/
|
||||
onChange?: ?BubblingEventHandler<
|
||||
$ReadOnly<{|target: Int32, eventCount: Int32, text: string|}>,
|
||||
>,
|
||||
|
||||
/**
|
||||
* Callback that is called when the text input's text changes.
|
||||
* Changed text is passed as an argument to the callback handler.
|
||||
* TODO: differentiate between onChange and onChangeText
|
||||
*/
|
||||
onChangeText?: ?BubblingEventHandler<
|
||||
$ReadOnly<{|target: Int32, eventCount: Int32, text: string|}>,
|
||||
>,
|
||||
|
||||
/**
|
||||
* Callback that is called when the text input's content size changes.
|
||||
* This will be called with
|
||||
* `{ nativeEvent: { contentSize: { width, height } } }`.
|
||||
*
|
||||
* Only called for multiline text inputs.
|
||||
*/
|
||||
onContentSizeChange?: ?DirectEventHandler<
|
||||
$ReadOnly<{|
|
||||
target: Int32,
|
||||
contentSize: $ReadOnly<{|width: Double, height: Double|}>,
|
||||
|}>,
|
||||
>,
|
||||
|
||||
onTextInput?: ?BubblingEventHandler<
|
||||
$ReadOnly<{|
|
||||
target: Int32,
|
||||
text: string,
|
||||
previousText: string,
|
||||
range: $ReadOnly<{|start: Double, end: Double|}>,
|
||||
|}>,
|
||||
>,
|
||||
|
||||
/**
|
||||
* Callback that is called when text input ends.
|
||||
*/
|
||||
onEndEditing?: ?BubblingEventHandler<
|
||||
$ReadOnly<{|target: Int32, text: string|}>,
|
||||
>,
|
||||
|
||||
/**
|
||||
* Callback that is called when the text input selection is changed.
|
||||
* This will be called with
|
||||
* `{ nativeEvent: { selection: { start, end } } }`.
|
||||
*/
|
||||
onSelectionChange?: ?DirectEventHandler<
|
||||
$ReadOnly<{|
|
||||
target: Int32,
|
||||
selection: $ReadOnly<{|start: Double, end: Double|}>,
|
||||
|}>,
|
||||
>,
|
||||
|
||||
/**
|
||||
* Callback that is called when the text input's submit button is pressed.
|
||||
* Invalid if `multiline={true}` is specified.
|
||||
*/
|
||||
onSubmitEditing?: ?BubblingEventHandler<
|
||||
$ReadOnly<{|target: Int32, text: string|}>,
|
||||
>,
|
||||
|
||||
/**
|
||||
* Callback that is called when a key is pressed.
|
||||
* This will be called with `{ nativeEvent: { key: keyValue } }`
|
||||
* where `keyValue` is `'Enter'` or `'Backspace'` for respective keys and
|
||||
* the typed-in character otherwise including `' '` for space.
|
||||
* Fires before `onChange` callbacks.
|
||||
*/
|
||||
onKeyPress?: ?BubblingEventHandler<$ReadOnly<{|target: Int32, key: string|}>>,
|
||||
|
||||
/**
|
||||
* Invoked on content scroll with `{ nativeEvent: { contentOffset: { x, y } } }`.
|
||||
* May also contain other properties from ScrollEvent but on Android contentSize
|
||||
* is not provided for performance reasons.
|
||||
*/
|
||||
onScroll?: ?DirectEventHandler<
|
||||
$ReadOnly<{|
|
||||
target: Int32,
|
||||
responderIgnoreScroll: boolean,
|
||||
contentInset: $ReadOnly<{|
|
||||
top: Double, // always 0 on Android
|
||||
bottom: Double, // always 0 on Android
|
||||
left: Double, // always 0 on Android
|
||||
right: Double, // always 0 on Android
|
||||
|}>,
|
||||
contentOffset: $ReadOnly<{|
|
||||
x: Double,
|
||||
y: Double,
|
||||
|}>,
|
||||
contentSize: $ReadOnly<{|
|
||||
width: Double, // always 0 on Android
|
||||
height: Double, // always 0 on Android
|
||||
|}>,
|
||||
layoutMeasurement: $ReadOnly<{|
|
||||
width: Double,
|
||||
height: Double,
|
||||
|}>,
|
||||
velocity: $ReadOnly<{|
|
||||
x: Double, // always 0 on Android
|
||||
y: Double, // always 0 on Android
|
||||
|}>,
|
||||
|}>,
|
||||
>,
|
||||
|
||||
/**
|
||||
* The string that will be rendered before text input has been entered.
|
||||
*/
|
||||
placeholder?: ?string,
|
||||
|
||||
/**
|
||||
* The text color of the placeholder string.
|
||||
*/
|
||||
placeholderTextColor?: ?ColorValue,
|
||||
|
||||
/**
|
||||
* If `true`, the text input obscures the text entered so that sensitive text
|
||||
* like passwords stay secure. The default value is `false`. Does not work with 'multiline={true}'.
|
||||
*/
|
||||
secureTextEntry?: ?boolean,
|
||||
|
||||
/**
|
||||
* The highlight and cursor color of the text input.
|
||||
*/
|
||||
selectionColor?: ?ColorValue,
|
||||
|
||||
/**
|
||||
* The start and end of the text input's selection. Set start and end to
|
||||
* the same value to position the cursor.
|
||||
*/
|
||||
selection?: ?$ReadOnly<{|
|
||||
start: Int32,
|
||||
end?: ?Int32,
|
||||
|}>,
|
||||
|
||||
/**
|
||||
* The value to show for the text input. `TextInput` is a controlled
|
||||
* component, which means the native value will be forced to match this
|
||||
* value prop if provided. For most uses, this works great, but in some
|
||||
* cases this may cause flickering - one common cause is preventing edits
|
||||
* by keeping value the same. In addition to simply setting the same value,
|
||||
* either set `editable={false}`, or set/update `maxLength` to prevent
|
||||
* unwanted edits without flicker.
|
||||
*/
|
||||
value?: ?string,
|
||||
|
||||
/**
|
||||
* Provides an initial value that will change when the user starts typing.
|
||||
* Useful for simple use-cases where you do not want to deal with listening
|
||||
* to events and updating the value prop to keep the controlled state in sync.
|
||||
*/
|
||||
defaultValue?: ?string,
|
||||
|
||||
/**
|
||||
* If `true`, all text will automatically be selected on focus.
|
||||
*/
|
||||
selectTextOnFocus?: ?boolean,
|
||||
|
||||
/**
|
||||
* If `true`, the text field will blur when submitted.
|
||||
* The default value is true for single-line fields and false for
|
||||
* multiline fields. Note that for multiline fields, setting `blurOnSubmit`
|
||||
* to `true` means that pressing return will blur the field and trigger the
|
||||
* `onSubmitEditing` event instead of inserting a newline into the field.
|
||||
*/
|
||||
blurOnSubmit?: ?boolean,
|
||||
|
||||
/**
|
||||
* Note that not all Text styles are supported, an incomplete list of what is not supported includes:
|
||||
*
|
||||
* - `borderLeftWidth`
|
||||
* - `borderTopWidth`
|
||||
* - `borderRightWidth`
|
||||
* - `borderBottomWidth`
|
||||
* - `borderTopLeftRadius`
|
||||
* - `borderTopRightRadius`
|
||||
* - `borderBottomRightRadius`
|
||||
* - `borderBottomLeftRadius`
|
||||
*
|
||||
* see [Issue#7070](https://github.com/facebook/react-native/issues/7070)
|
||||
* for more detail.
|
||||
*
|
||||
* [Styles](docs/style.html)
|
||||
*/
|
||||
// TODO: figure out what to do with this style prop for codegen/Fabric purposes
|
||||
// This must be commented for Fabric codegen to work; it's currently not possible
|
||||
// to override the default View style prop in codegen.
|
||||
style?: ?TextStyleProp,
|
||||
|
||||
/**
|
||||
* If `true`, caret is hidden. The default value is `false`.
|
||||
* This property is supported only for single-line TextInput component on iOS.
|
||||
*/
|
||||
caretHidden?: ?boolean,
|
||||
|
||||
/*
|
||||
* If `true`, contextMenuHidden is hidden. The default value is `false`.
|
||||
*/
|
||||
contextMenuHidden?: ?boolean,
|
||||
|
||||
/**
|
||||
* The following are props that `BaseTextShadowNode` takes. It is unclear if they
|
||||
* are used by TextInput.
|
||||
*/
|
||||
textShadowColor?: ?ColorValue,
|
||||
textShadowRadius?: ?Float,
|
||||
textDecorationLine?: ?string,
|
||||
fontStyle?: ?string,
|
||||
textShadowOffset?: ?$ReadOnly<{|width?: ?Double, height?: ?Double|}>,
|
||||
lineHeight?: ?Float,
|
||||
textTransform?: ?string,
|
||||
color?: ?Int32,
|
||||
letterSpacing?: ?Float,
|
||||
fontSize?: ?Float,
|
||||
textAlign?: ?string,
|
||||
includeFontPadding?: ?boolean,
|
||||
fontWeight?: ?string,
|
||||
fontFamily?: ?string,
|
||||
|
||||
/**
|
||||
* I cannot find where these are defined but JS complains without them.
|
||||
*/
|
||||
textAlignVertical?: ?string,
|
||||
cursorColor?: ?ColorValue,
|
||||
|
||||
/**
|
||||
* "Private" fields used by TextInput.js and not users of this component directly
|
||||
*/
|
||||
mostRecentEventCount: Int32,
|
||||
text?: ?string,
|
||||
|}>;
|
||||
|
||||
type NativeType = HostComponent<NativeProps>;
|
||||
|
||||
type NativeCommands = TextInputNativeCommands<NativeType>;
|
||||
|
||||
export const Commands: NativeCommands = codegenNativeCommands<NativeCommands>({
|
||||
supportedCommands: ['focus', 'blur', 'setTextAndSelection'],
|
||||
});
|
||||
|
||||
let AndroidTextInputNativeComponent;
|
||||
if (global.RN$Bridgeless) {
|
||||
ReactNativeViewConfigRegistry.register('AndroidTextInput', () => {
|
||||
return AndroidTextInputViewConfig;
|
||||
});
|
||||
AndroidTextInputNativeComponent = 'AndroidTextInput';
|
||||
} else {
|
||||
AndroidTextInputNativeComponent = requireNativeComponent<NativeProps>(
|
||||
'AndroidTextInput',
|
||||
);
|
||||
}
|
||||
|
||||
// flowlint-next-line unclear-type:off
|
||||
export default ((AndroidTextInputNativeComponent: any): HostComponent<NativeProps>);
|
84
node_modules/react-native/Libraries/Components/TextInput/AndroidTextInputViewConfig.js
generated
vendored
Normal file
84
node_modules/react-native/Libraries/Components/TextInput/AndroidTextInputViewConfig.js
generated
vendored
Normal file
@ -0,0 +1,84 @@
|
||||
/**
|
||||
* 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.
|
||||
*
|
||||
* @flow strict-local
|
||||
* @format
|
||||
*/
|
||||
|
||||
'use strict';
|
||||
|
||||
import ReactNativeViewViewConfig from '../../Components/View/ReactNativeViewViewConfig';
|
||||
import type {ReactNativeBaseComponentViewConfig} from '../../Renderer/shims/ReactNativeTypes';
|
||||
|
||||
const AndroidTextInputViewConfig = {
|
||||
uiViewClassName: 'AndroidTextInput',
|
||||
bubblingEventTypes: {
|
||||
topTextInput: {
|
||||
phasedRegistrationNames: {
|
||||
bubbled: 'onTextInput',
|
||||
captured: 'onTextInputCapture',
|
||||
},
|
||||
},
|
||||
},
|
||||
directEventTypes: {},
|
||||
validAttributes: {
|
||||
...ReactNativeViewViewConfig.validAttributes,
|
||||
|
||||
maxFontSizeMultiplier: true,
|
||||
placeholder: true,
|
||||
inlineImagePadding: true,
|
||||
contextMenuHidden: true,
|
||||
textShadowColor: {process: require('../../StyleSheet/processColor')},
|
||||
maxLength: true,
|
||||
selectTextOnFocus: true,
|
||||
textShadowRadius: true,
|
||||
underlineColorAndroid: {process: require('../../StyleSheet/processColor')},
|
||||
textDecorationLine: true,
|
||||
blurOnSubmit: true,
|
||||
textAlignVertical: true,
|
||||
fontStyle: true,
|
||||
textShadowOffset: true,
|
||||
selectionColor: {process: require('../../StyleSheet/processColor')},
|
||||
selection: true,
|
||||
placeholderTextColor: {process: require('../../StyleSheet/processColor')},
|
||||
importantForAutofill: true,
|
||||
lineHeight: true,
|
||||
textTransform: true,
|
||||
returnKeyType: true,
|
||||
keyboardType: true,
|
||||
multiline: true,
|
||||
color: true,
|
||||
autoCompleteType: true,
|
||||
numberOfLines: true,
|
||||
letterSpacing: true,
|
||||
returnKeyLabel: true,
|
||||
fontSize: true,
|
||||
onKeyPress: true,
|
||||
cursorColor: {process: require('../../StyleSheet/processColor')},
|
||||
text: true,
|
||||
showSoftInputOnFocus: true,
|
||||
textAlign: true,
|
||||
autoCapitalize: true,
|
||||
autoCorrect: true,
|
||||
caretHidden: true,
|
||||
secureTextEntry: true,
|
||||
textBreakStrategy: true,
|
||||
onScroll: true,
|
||||
onContentSizeChange: true,
|
||||
disableFullscreenUI: true,
|
||||
includeFontPadding: true,
|
||||
fontWeight: true,
|
||||
fontFamily: true,
|
||||
allowFontScaling: true,
|
||||
onSelectionChange: true,
|
||||
mostRecentEventCount: true,
|
||||
inlineImageLeft: true,
|
||||
editable: true,
|
||||
fontVariant: true,
|
||||
},
|
||||
};
|
||||
|
||||
module.exports = (AndroidTextInputViewConfig: ReactNativeBaseComponentViewConfig<>);
|
118
node_modules/react-native/Libraries/Components/TextInput/InputAccessoryView.js
generated
vendored
Normal file
118
node_modules/react-native/Libraries/Components/TextInput/InputAccessoryView.js
generated
vendored
Normal file
@ -0,0 +1,118 @@
|
||||
/**
|
||||
* 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.
|
||||
*
|
||||
* @flow
|
||||
* @format
|
||||
*/
|
||||
|
||||
'use strict';
|
||||
|
||||
const Platform = require('../../Utilities/Platform');
|
||||
const React = require('react');
|
||||
const StyleSheet = require('../../StyleSheet/StyleSheet');
|
||||
|
||||
import RCTInputAccessoryViewNativeComponent from './RCTInputAccessoryViewNativeComponent';
|
||||
|
||||
import type {ViewStyleProp} from '../../StyleSheet/StyleSheet';
|
||||
import type {ColorValue} from '../../StyleSheet/StyleSheetTypes';
|
||||
|
||||
/**
|
||||
* Note: iOS only
|
||||
*
|
||||
* A component which enables customization of the keyboard input accessory view.
|
||||
* The input accessory view is displayed above the keyboard whenever a TextInput
|
||||
* has focus. This component can be used to create custom toolbars.
|
||||
*
|
||||
* To use this component wrap your custom toolbar with the
|
||||
* InputAccessoryView component, and set a nativeID. Then, pass that nativeID
|
||||
* as the inputAccessoryViewID of whatever TextInput you desire. A simple
|
||||
* example:
|
||||
*
|
||||
* ```ReactNativeWebPlayer
|
||||
* import React, { Component } from 'react';
|
||||
* import { AppRegistry, TextInput, InputAccessoryView, Button } from 'react-native';
|
||||
*
|
||||
* export default class UselessTextInput extends Component {
|
||||
* constructor(props) {
|
||||
* super(props);
|
||||
* this.state = {text: 'Placeholder Text'};
|
||||
* }
|
||||
*
|
||||
* render() {
|
||||
* const inputAccessoryViewID = "uniqueID";
|
||||
* return (
|
||||
* <View>
|
||||
* <ScrollView keyboardDismissMode="interactive">
|
||||
* <TextInput
|
||||
* style={{
|
||||
* padding: 10,
|
||||
* paddingTop: 50,
|
||||
* }}
|
||||
* inputAccessoryViewID=inputAccessoryViewID
|
||||
* onChangeText={text => this.setState({text})}
|
||||
* value={this.state.text}
|
||||
* />
|
||||
* </ScrollView>
|
||||
* <InputAccessoryView nativeID=inputAccessoryViewID>
|
||||
* <Button
|
||||
* onPress={() => this.setState({text: 'Placeholder Text'})}
|
||||
* title="Reset Text"
|
||||
* />
|
||||
* </InputAccessoryView>
|
||||
* </View>
|
||||
* );
|
||||
* }
|
||||
* }
|
||||
*
|
||||
* // skip this line if using Create React Native App
|
||||
* AppRegistry.registerComponent('AwesomeProject', () => UselessTextInput);
|
||||
* ```
|
||||
*
|
||||
* This component can also be used to create sticky text inputs (text inputs
|
||||
* which are anchored to the top of the keyboard). To do this, wrap a
|
||||
* TextInput with the InputAccessoryView component, and don't set a nativeID.
|
||||
* For an example, look at InputAccessoryViewExample.js in RNTester.
|
||||
*/
|
||||
|
||||
type Props = $ReadOnly<{|
|
||||
+children: React.Node,
|
||||
/**
|
||||
* An ID which is used to associate this `InputAccessoryView` to
|
||||
* specified TextInput(s).
|
||||
*/
|
||||
nativeID?: ?string,
|
||||
style?: ?ViewStyleProp,
|
||||
backgroundColor?: ?ColorValue,
|
||||
|}>;
|
||||
|
||||
class InputAccessoryView extends React.Component<Props> {
|
||||
render(): React.Node {
|
||||
if (Platform.OS !== 'ios') {
|
||||
console.warn('<InputAccessoryView> is only supported on iOS.');
|
||||
}
|
||||
|
||||
if (React.Children.count(this.props.children) === 0) {
|
||||
return null;
|
||||
}
|
||||
|
||||
return (
|
||||
<RCTInputAccessoryViewNativeComponent
|
||||
style={[this.props.style, styles.container]}
|
||||
nativeID={this.props.nativeID}
|
||||
backgroundColor={this.props.backgroundColor}>
|
||||
{this.props.children}
|
||||
</RCTInputAccessoryViewNativeComponent>
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
const styles = StyleSheet.create({
|
||||
container: {
|
||||
position: 'absolute',
|
||||
},
|
||||
});
|
||||
|
||||
module.exports = InputAccessoryView;
|
26
node_modules/react-native/Libraries/Components/TextInput/RCTInputAccessoryViewNativeComponent.js
generated
vendored
Normal file
26
node_modules/react-native/Libraries/Components/TextInput/RCTInputAccessoryViewNativeComponent.js
generated
vendored
Normal file
@ -0,0 +1,26 @@
|
||||
/**
|
||||
* 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.
|
||||
*
|
||||
* @flow strict-local
|
||||
* @format
|
||||
*/
|
||||
|
||||
'use strict';
|
||||
|
||||
import type {ColorValue} from '../../StyleSheet/StyleSheetTypes';
|
||||
import type {ViewProps} from '../View/ViewPropTypes';
|
||||
|
||||
import codegenNativeComponent from '../../Utilities/codegenNativeComponent';
|
||||
import type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';
|
||||
|
||||
type NativeProps = $ReadOnly<{|
|
||||
...ViewProps,
|
||||
backgroundColor?: ?ColorValue,
|
||||
|}>;
|
||||
|
||||
export default (codegenNativeComponent<NativeProps>(
|
||||
'RCTInputAccessoryView',
|
||||
): HostComponent<NativeProps>);
|
32
node_modules/react-native/Libraries/Components/TextInput/RCTMultilineTextInputNativeComponent.js
generated
vendored
Normal file
32
node_modules/react-native/Libraries/Components/TextInput/RCTMultilineTextInputNativeComponent.js
generated
vendored
Normal file
@ -0,0 +1,32 @@
|
||||
/**
|
||||
* 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.
|
||||
*
|
||||
* @flow strict-local
|
||||
* @format
|
||||
*/
|
||||
|
||||
'use strict';
|
||||
|
||||
import type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';
|
||||
import requireNativeComponent from '../../ReactNative/requireNativeComponent';
|
||||
import codegenNativeCommands from '../../Utilities/codegenNativeCommands';
|
||||
import type {Int32} from '../../Types/CodegenTypes';
|
||||
import type {TextInputNativeCommands} from './TextInputNativeCommands';
|
||||
import * as React from 'react';
|
||||
|
||||
type NativeType = HostComponent<mixed>;
|
||||
|
||||
type NativeCommands = TextInputNativeCommands<NativeType>;
|
||||
|
||||
export const Commands: NativeCommands = codegenNativeCommands<NativeCommands>({
|
||||
supportedCommands: ['focus', 'blur', 'setTextAndSelection'],
|
||||
});
|
||||
|
||||
const SinglelineTextInputNativeComponent: HostComponent<mixed> = requireNativeComponent<mixed>(
|
||||
'RCTMultilineTextInputView',
|
||||
);
|
||||
|
||||
export default SinglelineTextInputNativeComponent;
|
43
node_modules/react-native/Libraries/Components/TextInput/RCTSingelineTextInputNativeComponent.js
generated
vendored
Normal file
43
node_modules/react-native/Libraries/Components/TextInput/RCTSingelineTextInputNativeComponent.js
generated
vendored
Normal file
@ -0,0 +1,43 @@
|
||||
/**
|
||||
* 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.
|
||||
*
|
||||
* @flow strict-local
|
||||
* @format
|
||||
*/
|
||||
|
||||
'use strict';
|
||||
|
||||
import type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';
|
||||
import requireNativeComponent from '../../ReactNative/requireNativeComponent';
|
||||
import codegenNativeCommands from '../../Utilities/codegenNativeCommands';
|
||||
import type {Int32} from '../../Types/CodegenTypes';
|
||||
import * as React from 'react';
|
||||
import type {TextInputNativeCommands} from './TextInputNativeCommands';
|
||||
import RCTSinglelineTextInputViewConfig from './RCTSinglelineTextInputViewConfig';
|
||||
const ReactNativeViewConfigRegistry = require('../../Renderer/shims/ReactNativeViewConfigRegistry');
|
||||
|
||||
type NativeType = HostComponent<mixed>;
|
||||
|
||||
type NativeCommands = TextInputNativeCommands<NativeType>;
|
||||
|
||||
export const Commands: NativeCommands = codegenNativeCommands<NativeCommands>({
|
||||
supportedCommands: ['focus', 'blur', 'setTextAndSelection'],
|
||||
});
|
||||
|
||||
let SinglelineTextInputNativeComponent;
|
||||
if (global.RN$Bridgeless) {
|
||||
ReactNativeViewConfigRegistry.register('RCTSinglelineTextInputView', () => {
|
||||
return RCTSinglelineTextInputViewConfig;
|
||||
});
|
||||
SinglelineTextInputNativeComponent = 'RCTSinglelineTextInputView';
|
||||
} else {
|
||||
SinglelineTextInputNativeComponent = requireNativeComponent<mixed>(
|
||||
'RCTSinglelineTextInputView',
|
||||
);
|
||||
}
|
||||
|
||||
// flowlint-next-line unclear-type:off
|
||||
export default ((SinglelineTextInputNativeComponent: any): HostComponent<mixed>);
|
134
node_modules/react-native/Libraries/Components/TextInput/RCTSinglelineTextInputViewConfig.js
generated
vendored
Normal file
134
node_modules/react-native/Libraries/Components/TextInput/RCTSinglelineTextInputViewConfig.js
generated
vendored
Normal file
@ -0,0 +1,134 @@
|
||||
/**
|
||||
* 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.
|
||||
*
|
||||
* @flow strict-local
|
||||
* @format
|
||||
*/
|
||||
|
||||
'use strict';
|
||||
|
||||
import ReactNativeViewViewConfig from '../../Components/View/ReactNativeViewViewConfig';
|
||||
import type {ReactNativeBaseComponentViewConfig} from '../../Renderer/shims/ReactNativeTypes';
|
||||
|
||||
const RCTSinglelineTextInputViewConfig = {
|
||||
uiViewClassName: 'RCTSinglelineTextInputView',
|
||||
bubblingEventTypes: {
|
||||
topBlur: {
|
||||
phasedRegistrationNames: {
|
||||
bubbled: 'onBlur',
|
||||
captured: 'onBlurCapture',
|
||||
},
|
||||
},
|
||||
topChange: {
|
||||
phasedRegistrationNames: {
|
||||
bubbled: 'onChange',
|
||||
captured: 'onChangeCapture',
|
||||
},
|
||||
},
|
||||
topEndEditing: {
|
||||
phasedRegistrationNames: {
|
||||
bubbled: 'onEndEditing',
|
||||
captured: 'onEndEditingCapture',
|
||||
},
|
||||
},
|
||||
topFocus: {
|
||||
phasedRegistrationNames: {
|
||||
bubbled: 'onFocus',
|
||||
captured: 'onFocusCapture',
|
||||
},
|
||||
},
|
||||
topKeyPress: {
|
||||
phasedRegistrationNames: {
|
||||
bubbled: 'onKeyPress',
|
||||
captured: 'onKeyPressCapture',
|
||||
},
|
||||
},
|
||||
topSubmitEditing: {
|
||||
phasedRegistrationNames: {
|
||||
bubbled: 'onSubmitEditing',
|
||||
captured: 'onSubmitEditingCapture',
|
||||
},
|
||||
},
|
||||
topTouchCancel: {
|
||||
phasedRegistrationNames: {
|
||||
bubbled: 'onTouchCancel',
|
||||
captured: 'onTouchCancelCapture',
|
||||
},
|
||||
},
|
||||
topTouchEnd: {
|
||||
phasedRegistrationNames: {
|
||||
bubbled: 'onTouchEnd',
|
||||
captured: 'onTouchEndCapture',
|
||||
},
|
||||
},
|
||||
|
||||
topTouchMove: {
|
||||
phasedRegistrationNames: {
|
||||
bubbled: 'onTouchMove',
|
||||
captured: 'onTouchMoveCapture',
|
||||
},
|
||||
},
|
||||
},
|
||||
directEventTypes: {},
|
||||
validAttributes: {
|
||||
...ReactNativeViewViewConfig.validAttributes,
|
||||
fontSize: true,
|
||||
fontWeight: true,
|
||||
fontVariant: true,
|
||||
// flowlint-next-line untyped-import:off
|
||||
textShadowOffset: {diff: require('../../Utilities/differ/sizesDiffer')},
|
||||
allowFontScaling: true,
|
||||
fontStyle: true,
|
||||
textTransform: true,
|
||||
textAlign: true,
|
||||
fontFamily: true,
|
||||
lineHeight: true,
|
||||
isHighlighted: true,
|
||||
writingDirection: true,
|
||||
textDecorationLine: true,
|
||||
textShadowRadius: true,
|
||||
letterSpacing: true,
|
||||
textDecorationStyle: true,
|
||||
textDecorationColor: {process: require('../../StyleSheet/processColor')},
|
||||
color: {process: require('../../StyleSheet/processColor')},
|
||||
maxFontSizeMultiplier: true,
|
||||
textShadowColor: {process: require('../../StyleSheet/processColor')},
|
||||
editable: true,
|
||||
inputAccessoryViewID: true,
|
||||
caretHidden: true,
|
||||
enablesReturnKeyAutomatically: true,
|
||||
placeholderTextColor: {process: require('../../StyleSheet/processColor')},
|
||||
onSelectionChange: true,
|
||||
clearButtonMode: true,
|
||||
onContentSizeChange: true,
|
||||
keyboardType: true,
|
||||
selection: true,
|
||||
returnKeyType: true,
|
||||
blurOnSubmit: true,
|
||||
mostRecentEventCount: true,
|
||||
onChange: true,
|
||||
scrollEnabled: true,
|
||||
selectionColor: {process: require('../../StyleSheet/processColor')},
|
||||
contextMenuHidden: true,
|
||||
secureTextEntry: true,
|
||||
onTextInput: true,
|
||||
placeholder: true,
|
||||
autoCorrect: true,
|
||||
onScroll: true,
|
||||
multiline: true,
|
||||
textContentType: true,
|
||||
maxLength: true,
|
||||
autoCapitalize: true,
|
||||
keyboardAppearance: true,
|
||||
passwordRules: true,
|
||||
spellCheck: true,
|
||||
selectTextOnFocus: true,
|
||||
text: true,
|
||||
clearTextOnFocus: true,
|
||||
},
|
||||
};
|
||||
|
||||
module.exports = (RCTSinglelineTextInputViewConfig: ReactNativeBaseComponentViewConfig<>);
|
1208
node_modules/react-native/Libraries/Components/TextInput/TextInput.js
generated
vendored
Normal file
1208
node_modules/react-native/Libraries/Components/TextInput/TextInput.js
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
31
node_modules/react-native/Libraries/Components/TextInput/TextInputNativeCommands.js
generated
vendored
Normal file
31
node_modules/react-native/Libraries/Components/TextInput/TextInputNativeCommands.js
generated
vendored
Normal file
@ -0,0 +1,31 @@
|
||||
/**
|
||||
* 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.
|
||||
*
|
||||
* @flow strict-local
|
||||
* @format
|
||||
*/
|
||||
|
||||
'use strict';
|
||||
|
||||
import * as React from 'react';
|
||||
|
||||
import type {Int32} from '../../Types/CodegenTypes';
|
||||
|
||||
export interface TextInputNativeCommands<T> {
|
||||
+focus: (viewRef: React.ElementRef<T>) => void;
|
||||
+blur: (viewRef: React.ElementRef<T>) => void;
|
||||
+setTextAndSelection: (
|
||||
viewRef: React.ElementRef<T>,
|
||||
mostRecentEventCount: Int32,
|
||||
value: ?string, // in theory this is nullable
|
||||
start: Int32,
|
||||
end: Int32,
|
||||
) => void;
|
||||
}
|
||||
|
||||
const supportedCommands = ['focus', 'blur', 'setTextAndSelection'];
|
||||
|
||||
export default supportedCommands;
|
191
node_modules/react-native/Libraries/Components/TextInput/TextInputState.js
generated
vendored
Normal file
191
node_modules/react-native/Libraries/Components/TextInput/TextInputState.js
generated
vendored
Normal file
@ -0,0 +1,191 @@
|
||||
/**
|
||||
* 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.
|
||||
*
|
||||
* @format
|
||||
* @flow strict-local
|
||||
*/
|
||||
|
||||
// This class is responsible for coordinating the "focused" state for
|
||||
// TextInputs. All calls relating to the keyboard should be funneled
|
||||
// through here.
|
||||
|
||||
'use strict';
|
||||
|
||||
const React = require('react');
|
||||
const Platform = require('../../Utilities/Platform');
|
||||
const {findNodeHandle} = require('../../Renderer/shims/ReactNative');
|
||||
import {Commands as AndroidTextInputCommands} from '../../Components/TextInput/AndroidTextInputNativeComponent';
|
||||
import {Commands as iOSTextInputCommands} from '../../Components/TextInput/RCTSingelineTextInputNativeComponent';
|
||||
|
||||
import type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';
|
||||
type ComponentRef = React.ElementRef<HostComponent<mixed>>;
|
||||
|
||||
let currentlyFocusedInputRef: ?ComponentRef = null;
|
||||
const inputs = new Set();
|
||||
|
||||
function currentlyFocusedInput(): ?ComponentRef {
|
||||
return currentlyFocusedInputRef;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the ID of the currently focused text field, if one exists
|
||||
* If no text field is focused it returns null
|
||||
*/
|
||||
function currentlyFocusedField(): ?number {
|
||||
if (__DEV__) {
|
||||
console.error(
|
||||
'currentlyFocusedField is deprecated and will be removed in a future release. Use currentlyFocusedInput',
|
||||
);
|
||||
}
|
||||
|
||||
return findNodeHandle(currentlyFocusedInputRef);
|
||||
}
|
||||
|
||||
function focusInput(textField: ?ComponentRef): void {
|
||||
if (currentlyFocusedInputRef !== textField && textField != null) {
|
||||
currentlyFocusedInputRef = textField;
|
||||
}
|
||||
}
|
||||
|
||||
function blurInput(textField: ?ComponentRef): void {
|
||||
if (currentlyFocusedInputRef === textField && textField != null) {
|
||||
currentlyFocusedInputRef = null;
|
||||
}
|
||||
}
|
||||
|
||||
function focusField(textFieldID: ?number): void {
|
||||
if (__DEV__) {
|
||||
console.error('focusField no longer works. Use focusInput');
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
function blurField(textFieldID: ?number) {
|
||||
if (__DEV__) {
|
||||
console.error('blurField no longer works. Use blurInput');
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {number} TextInputID id of the text field to focus
|
||||
* Focuses the specified text field
|
||||
* noop if the text field was already focused
|
||||
*/
|
||||
function focusTextInput(textField: ?ComponentRef) {
|
||||
if (typeof textField === 'number') {
|
||||
if (__DEV__) {
|
||||
console.error(
|
||||
'focusTextInput must be called with a host component. Passing a react tag is deprecated.',
|
||||
);
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
if (currentlyFocusedInputRef !== textField && textField != null) {
|
||||
focusInput(textField);
|
||||
if (Platform.OS === 'ios') {
|
||||
// This isn't necessarily a single line text input
|
||||
// But commands don't actually care as long as the thing being passed in
|
||||
// actually has a command with that name. So this should work with single
|
||||
// and multiline text inputs. Ideally we'll merge them into one component
|
||||
// in the future.
|
||||
iOSTextInputCommands.focus(textField);
|
||||
} else if (Platform.OS === 'android') {
|
||||
AndroidTextInputCommands.focus(textField);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {number} textFieldID id of the text field to unfocus
|
||||
* Unfocuses the specified text field
|
||||
* noop if it wasn't focused
|
||||
*/
|
||||
function blurTextInput(textField: ?ComponentRef) {
|
||||
if (typeof textField === 'number') {
|
||||
if (__DEV__) {
|
||||
console.error(
|
||||
'focusTextInput must be called with a host component. Passing a react tag is deprecated.',
|
||||
);
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
if (currentlyFocusedInputRef === textField && textField != null) {
|
||||
blurInput(textField);
|
||||
if (Platform.OS === 'ios') {
|
||||
// This isn't necessarily a single line text input
|
||||
// But commands don't actually care as long as the thing being passed in
|
||||
// actually has a command with that name. So this should work with single
|
||||
// and multiline text inputs. Ideally we'll merge them into one component
|
||||
// in the future.
|
||||
iOSTextInputCommands.blur(textField);
|
||||
} else if (Platform.OS === 'android') {
|
||||
AndroidTextInputCommands.blur(textField);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function registerInput(textField: ComponentRef) {
|
||||
if (typeof textField === 'number') {
|
||||
if (__DEV__) {
|
||||
console.error(
|
||||
'registerInput must be called with a host component. Passing a react tag is deprecated.',
|
||||
);
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
inputs.add(textField);
|
||||
}
|
||||
|
||||
function unregisterInput(textField: ComponentRef) {
|
||||
if (typeof textField === 'number') {
|
||||
if (__DEV__) {
|
||||
console.error(
|
||||
'unregisterInput must be called with a host component. Passing a react tag is deprecated.',
|
||||
);
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
inputs.delete(textField);
|
||||
}
|
||||
|
||||
function isTextInput(textField: ComponentRef): boolean {
|
||||
if (typeof textField === 'number') {
|
||||
if (__DEV__) {
|
||||
console.error(
|
||||
'isTextInput must be called with a host component. Passing a react tag is deprecated.',
|
||||
);
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
return inputs.has(textField);
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
currentlyFocusedInput,
|
||||
focusInput,
|
||||
blurInput,
|
||||
|
||||
currentlyFocusedField,
|
||||
focusField,
|
||||
blurField,
|
||||
focusTextInput,
|
||||
blurTextInput,
|
||||
registerInput,
|
||||
unregisterInput,
|
||||
isTextInput,
|
||||
};
|
Reference in New Issue
Block a user