代码拉取完成,页面将自动刷新
同步操作将从 张翔/react-native-yusha-customKeyboard 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
import React, { Component } from 'react';
import PropTypes from 'prop-types'
import {
Keyboard,
Platform,
NativeAppEventEmitter,
NativeModules,
TextInput,
findNodeHandle,
AppRegistry,
DeviceInfo,
AppState,
} from 'react-native';
import CustomKeyBoardView from './CustomKeyBoardView'
const { CustomKeyboard} = NativeModules;
const {
install, uninstall,
insertText, backSpace, doDelete,
moveLeft, moveRight,
switchSystemKeyboard,
clearAll,
} = CustomKeyboard;
export {
install, uninstall,
insertText, backSpace, doDelete,
moveLeft, moveRight,
switchSystemKeyboard,
clearAll,
};
const keyboardTypeRegistry = {};
export const currentHeight = DeviceInfo.isIPhoneX_deprecated ? 286 : 252
export function onConfirm(func) {
func()
};
export function addKeyBoardShowListener(listener) {
if(Platform.OS === 'android') {
return NativeAppEventEmitter.addListener('showCustomKeyboard', (data) => {
listener(data)
})
} else {
Keyboard.addListener('keyboardDidShow', () => {
listener()
});
return 'keyboardDidShow'
}
}
export function addKeyBoardHideListener(listener) {
if(Platform.OS === 'android') {
return NativeAppEventEmitter.addListener('hideCustomKeyboard', (data) => {
listener(data)
})
} else {
Keyboard.addListener('keyboardDidHide', () => {
listener()
});
return 'keyboardDidHide'
}
}
export function removeKeyBoardListener(subscribtion) {
if(Platform.OS === 'android') {
NativeAppEventEmitter.removeSubscription(subscribtion)
} else {
Keyboard.removeListener(subscribtion)
}
}
export function register(type, factory) {
keyboardTypeRegistry[type] = factory;
}
export function clearFocus(tag) {
TextInput.State.blurTextInput(tag)
}
class CustomKeyboardContainer extends Component {
render() {
const {tag, type} = this.props;
const factory = keyboardTypeRegistry[type];
if (!factory) {
console.warn(`Custom keyboard type ${type} not registered.`);
return null;
}
const Comp = factory();
return <Comp tag={tag} />;
}
}
AppRegistry.registerComponent("CustomKeyboard", ()=>CustomKeyboardContainer);
export class CustomTextInput extends Component {
static propTypes = {
...TextInput.propTypes,
customKeyboardType: PropTypes.string,
};
constructor() {
super(...arguments);
this.state = {text: this.props.defaultValue || ''}
}
componentDidMount() {
this.installTime = setTimeout(()=>{
install(findNodeHandle(this.input), this.props.customKeyboardType);
if(Platform.OS === 'android') {
this.showSub = addKeyBoardShowListener(this._showKeyboard);
this.hideSub = addKeyBoardHideListener(this._hideKeyboard);
}
AppState.addEventListener('change', this._handleAppStateChange);
}, 300)
}
componentWillUnmount() {
this.showSub && removeKeyBoardListener(this.showSub);
this.hideSub && removeKeyBoardListener(this.hideSub);
this.installTime && clearTimeout(this.installTime)
AppState.removeEventListener('change', this._handleAppStateChange);
}
_handleAppStateChange = (nextAppState: string) => {
if (nextAppState === 'background') {
//检查键盘
if (TextInput.State.currentlyFocusedField() === findNodeHandle(this.input)) {
TextInput.State.blurTextInput(TextInput.State.currentlyFocusedField())
return true
}
}
}
componentWillReceiveProps(newProps) {
if (newProps.customKeyboardType !== this.props.customKeyboardType) {
install(findNodeHandle(this.input), newProps.customKeyboardType);
}
if (newProps.value !== null && newProps.value !== undefined && newProps.value !== this.state.text) {
this.setState({text: newProps.value})
}
}
onRef = ref => {
this.input = ref;
this.props.textInputRef && this.props.textInputRef(ref)
};
_showKeyboard = (data) => {
if(data.tag !== findNodeHandle(this.input)) return ;
this.props.onFocus && this.props.onFocus()
}
_hideKeyboard = (data) => {
if(data.tag !== findNodeHandle(this.input)) return ;
this.props.onBlur && this.props.onBlur()
if (this.props.onEndEditing) {
this.props.onEndEditing({nativeEvent:{text: this.props.value}});
}
}
_onChangeText = (text) => {
this.setState({text})
this.props.onChangeText && this.props.onChangeText(text)
}
render() {
const { customKeyboardType, ...others } = this.props;
return <TextInput {...others}
ref={this.onRef}
onChangeText={this._onChangeText}
value={this.props.value}
/>;
}
}
export function keyBoardAPI(keyBoardName) {
return function(KeyBoardView) {
class KeyBoard extends Component {
render() {
return (
<CustomKeyBoardView
insertText = {insertText}
clearFocus = {clearFocus}
onConfirm = {onConfirm}
clearAll = {clearAll}
backSpace = {backSpace}
KeyBoardView = {KeyBoardView}
{...this.props}
/>
)
}
}
register(keyBoardName, ()=>KeyBoard);
return KeyBoard
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。