forked from Ivasoft/mattermost-mobile
* Refactor channel swiper * Feedback review * clean up * another feedback review * Remove unnecessary props * clean up initialState
255 lines
7.7 KiB
JavaScript
255 lines
7.7 KiB
JavaScript
// Copyright (c) 2017-present Mattermost, Inc. All Rights Reserved.
|
|
// See License.txt for license information.
|
|
import React, {PureComponent} from 'react';
|
|
import PropTypes from 'prop-types';
|
|
import {
|
|
InteractionManager,
|
|
Keyboard,
|
|
TextInput,
|
|
StyleSheet,
|
|
View,
|
|
TouchableWithoutFeedback
|
|
} from 'react-native';
|
|
import Icon from 'react-native-vector-icons/MaterialIcons';
|
|
|
|
import {changeOpacity} from 'app/utils/theme';
|
|
|
|
export default class SearchBarAndroid extends PureComponent {
|
|
static propTypes = {
|
|
autoFocus: PropTypes.bool,
|
|
backArrowSize: PropTypes.number,
|
|
deleteIconSize: PropTypes.number,
|
|
searchIconSize: PropTypes.number,
|
|
onCancelButtonPress: PropTypes.func,
|
|
onChangeText: PropTypes.func,
|
|
onFocus: PropTypes.func,
|
|
onBlur: PropTypes.func,
|
|
onSearchButtonPress: PropTypes.func,
|
|
onSelectionChange: PropTypes.func,
|
|
backgroundColor: PropTypes.string,
|
|
selectionColor: PropTypes.string,
|
|
placeholderTextColor: PropTypes.string,
|
|
titleCancelColor: PropTypes.string,
|
|
tintColorSearch: PropTypes.string,
|
|
tintColorDelete: PropTypes.string,
|
|
inputStyle: PropTypes.oneOfType([
|
|
PropTypes.number,
|
|
PropTypes.object
|
|
]),
|
|
placeholder: PropTypes.string,
|
|
returnKeyType: PropTypes.string,
|
|
keyboardType: PropTypes.string,
|
|
autoCapitalize: PropTypes.string,
|
|
inputHeight: PropTypes.number,
|
|
inputBorderRadius: PropTypes.number,
|
|
blurOnSubmit: PropTypes.bool,
|
|
value: PropTypes.string,
|
|
containerStyle: PropTypes.object
|
|
};
|
|
|
|
static defaultProps = {
|
|
backArrowSize: 24,
|
|
deleteIconSize: 16,
|
|
searchIconSize: 16,
|
|
blurOnSubmit: true,
|
|
placeholder: 'Search',
|
|
showCancelButton: true,
|
|
placeholderTextColor: changeOpacity('#000', 0.5),
|
|
containerStyle: {},
|
|
onSearchButtonPress: () => true,
|
|
onCancelButtonPress: () => true,
|
|
onChangeText: () => true,
|
|
onFocus: () => true,
|
|
onBlur: () => true,
|
|
onSelectionChange: () => true,
|
|
value: ''
|
|
};
|
|
|
|
constructor(props) {
|
|
super(props);
|
|
this.state = {
|
|
isFocused: false
|
|
};
|
|
}
|
|
|
|
cancel = () => {
|
|
this.onCancelButtonPress();
|
|
};
|
|
|
|
onBlur = () => {
|
|
this.props.onBlur();
|
|
};
|
|
|
|
onSearchButtonPress = () => {
|
|
const {value} = this.props;
|
|
|
|
if (value) {
|
|
this.props.onSearchButtonPress(value);
|
|
}
|
|
};
|
|
|
|
onCancelButtonPress = () => {
|
|
Keyboard.dismiss();
|
|
InteractionManager.runAfterInteractions(() => {
|
|
this.setState({
|
|
isFocused: false
|
|
}, () => {
|
|
this.props.onCancelButtonPress();
|
|
});
|
|
});
|
|
};
|
|
|
|
onChangeText = (value) => {
|
|
this.props.onChangeText(value);
|
|
};
|
|
|
|
onSelectionChange = (event) => {
|
|
this.props.onSelectionChange(event);
|
|
};
|
|
|
|
onFocus = () => {
|
|
this.setState({isFocused: true});
|
|
this.props.onFocus();
|
|
};
|
|
|
|
blur = () => {
|
|
this.refs.input.blur();
|
|
};
|
|
|
|
focus = () => {
|
|
this.refs.input.focus();
|
|
};
|
|
|
|
render() {
|
|
const {
|
|
autoCapitalize,
|
|
backArrowSize,
|
|
deleteIconSize,
|
|
searchIconSize,
|
|
backgroundColor,
|
|
blurOnSubmit,
|
|
inputHeight,
|
|
inputStyle,
|
|
keyboardType,
|
|
placeholder,
|
|
placeholderTextColor,
|
|
selectionColor,
|
|
returnKeyType,
|
|
titleCancelColor,
|
|
tintColorDelete,
|
|
tintColorSearch,
|
|
containerStyle,
|
|
value
|
|
} = this.props;
|
|
const {isFocused} = this.state;
|
|
|
|
const inputNoBackground = {
|
|
...inputStyle
|
|
};
|
|
Reflect.deleteProperty(inputNoBackground, 'backgroundColor');
|
|
|
|
let inputColor = styles.searchBarInput.backgroundColor;
|
|
if (inputStyle) {
|
|
inputColor = inputStyle.backgroundColor;
|
|
} else {
|
|
inputNoBackground.backgroundColor = '#fff';
|
|
}
|
|
|
|
return (
|
|
<View
|
|
style={[
|
|
styles.container,
|
|
containerStyle,
|
|
{height: inputHeight},
|
|
backgroundColor && {backgroundColor}
|
|
]}
|
|
>
|
|
<View
|
|
style={[
|
|
styles.searchBar,
|
|
{
|
|
backgroundColor: inputColor,
|
|
height: inputHeight,
|
|
paddingLeft: isFocused ? 0 : inputHeight * 0.25
|
|
}
|
|
]}
|
|
>
|
|
{isFocused ?
|
|
<TouchableWithoutFeedback
|
|
onPress={this.onCancelButtonPress}
|
|
style={{paddingRight: 15}}
|
|
>
|
|
<Icon
|
|
name='arrow-back'
|
|
size={backArrowSize}
|
|
color={titleCancelColor || placeholderTextColor}
|
|
/>
|
|
</TouchableWithoutFeedback> :
|
|
<Icon
|
|
name={'search'}
|
|
size={searchIconSize}
|
|
color={tintColorSearch || placeholderTextColor}
|
|
/>
|
|
}
|
|
<TextInput
|
|
ref='input'
|
|
blurOnSubmit={blurOnSubmit}
|
|
value={value}
|
|
autoCapitalize={autoCapitalize}
|
|
autoCorrect={false}
|
|
returnKeyType={returnKeyType || 'search'}
|
|
keyboardType={keyboardType || 'default'}
|
|
onFocus={this.onFocus}
|
|
onBlur={this.onBlur}
|
|
onChangeText={this.onChangeText}
|
|
onSubmitEditing={this.onSearchButtonPress}
|
|
onSelectionChange={this.onSelectionChange}
|
|
placeholder={placeholder}
|
|
placeholderTextColor={placeholderTextColor}
|
|
selectionColor={selectionColor}
|
|
underlineColorAndroid='transparent'
|
|
disableFullscreenUI={true}
|
|
style={[
|
|
styles.searchBarInput,
|
|
inputNoBackground,
|
|
{height: this.props.inputHeight}
|
|
]}
|
|
/>
|
|
{isFocused && value ?
|
|
<TouchableWithoutFeedback onPress={() => this.onChangeText('')}>
|
|
<Icon
|
|
style={[{paddingRight: (inputHeight * 0.2)}]}
|
|
name='close'
|
|
size={deleteIconSize}
|
|
color={tintColorDelete || placeholderTextColor}
|
|
/>
|
|
</TouchableWithoutFeedback> : null
|
|
}
|
|
</View>
|
|
</View>
|
|
);
|
|
}
|
|
}
|
|
|
|
const styles = StyleSheet.create({
|
|
container: {
|
|
backgroundColor: 'grey',
|
|
flexDirection: 'row',
|
|
justifyContent: 'flex-start',
|
|
alignItems: 'center',
|
|
padding: 5
|
|
},
|
|
searchBar: {
|
|
flex: 1,
|
|
flexDirection: 'row',
|
|
alignItems: 'center'
|
|
},
|
|
searchBarInput: {
|
|
flex: 1,
|
|
fontWeight: 'normal',
|
|
textAlignVertical: 'center',
|
|
padding: 0,
|
|
includeFontPadding: false
|
|
}
|
|
});
|