UNPKG

@qte/react-native-gifted-chat

Version:

Performant fork of react-native-gifted-chat with FlashList support

45 lines 1.75 kB
import React from 'react'; import { ActivityIndicator, Platform, StyleSheet, Text, TouchableOpacity, View, } from 'react-native'; import Color from './Color'; import stylesCommon from './styles'; const styles = StyleSheet.create({ container: { alignItems: 'center', marginTop: 5, marginBottom: 10, }, wrapper: { backgroundColor: Color.defaultColor, borderRadius: 15, height: 30, paddingLeft: 10, paddingRight: 10, }, text: { backgroundColor: Color.backgroundTransparent, color: Color.white, fontSize: 12, }, activityIndicator: { marginTop: Platform.select({ ios: -14, android: -16, default: -15, }), }, }); export function LoadEarlier({ isLoadingEarlier = false, onLoadEarlier = () => { }, label = 'Load earlier messages', containerStyle, wrapperStyle, textStyle, activityIndicatorColor = 'white', activityIndicatorSize = 'small', activityIndicatorStyle, }) { return (<TouchableOpacity style={[styles.container, containerStyle]} onPress={onLoadEarlier} disabled={isLoadingEarlier} accessibilityRole='button'> <View style={[stylesCommon.centerItems, styles.wrapper, wrapperStyle]}> {isLoadingEarlier ? (<View> <Text style={[styles.text, textStyle, { opacity: 0 }]}> {label} </Text> <ActivityIndicator color={activityIndicatorColor} size={activityIndicatorSize} style={[styles.activityIndicator, activityIndicatorStyle]}/> </View>) : (<Text style={[styles.text, textStyle]}>{label}</Text>)} </View> </TouchableOpacity>); } //# sourceMappingURL=LoadEarlier.js.map