react-native#ImageBackground TypeScript Examples
The following examples show how to use
react-native#ImageBackground.
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example #1
Source File: Carousel.tsx From sellflow with MIT License | 6 votes |
export default function Carousel(props: Props) {
let { width: dimensionsWidth } = useDimensions();
let { data, width = dimensionsWidth, height } = props;
let [activeIndex, setActiveIndex] = useState(0);
return (
<View style={[styles.carouselContainer, { height }]}>
<SnapCarousel
data={data}
renderItem={({ item }) => (
<TouchableWithoutFeedback onPress={item.onItemPress}>
<ImageBackground
source={{ uri: item.image }}
style={[styles.itemContainer, { height }]}
>
{item.render && item.render()}
</ImageBackground>
</TouchableWithoutFeedback>
)}
sliderWidth={width}
itemWidth={width}
inactiveSlideScale={1}
onSnapToItem={(slideIndex: number) => setActiveIndex(slideIndex)}
/>
<Pagination
dotsLength={data.length}
activeDotIndex={activeIndex}
containerStyle={styles.pagination}
dotStyle={styles.activeDotStyle}
inactiveDotStyle={styles.inactiveDotStyle}
inactiveDotOpacity={0.4}
dotContainerStyle={styles.dotContainerStyle}
/>
</View>
);
}
Example #2
Source File: index.tsx From nlw-02-omnistack with MIT License | 6 votes |
function GiveClasses() {
const { goBack } = useNavigation();
function handleNavigateBack() {
goBack();
}
return (
<View style={styles.container}>
<ImageBackground
resizeMode="contain"
source={giveClassesBgImage}
style={styles.content}
>
<Text style={styles.title}>Quer ser um Proffy?</Text>
<Text style={styles.description}>
Para começar, você precisa se cadastrar como professor na nossa plataforma web.
</Text>
</ImageBackground>
<RectButton onPress={handleNavigateBack} style={styles.okButton}>
<Text style={styles.okButtonText}>Tudo bem</Text>
</RectButton>
</View>
);
}
Example #3
Source File: WebviewHeader.tsx From hamagen-react-native with MIT License | 6 votes |
WebviewHeader = ({ hideClose, closeModal }: Props) => {
return (
<ImageBackground
source={require('../../assets/main/headerBG.png')}
style={styles.headerContainer}
resizeMode="cover"
resizeMethod="resize"
>
{
!hideClose && (
<HeaderButton type="close" onPress={closeModal} />
)
}
<View style={styles.headerSubContainer} />
</ImageBackground>
);
}
Example #4
Source File: MyBackground.tsx From SQUID with MIT License | 6 votes |
MyBackground = ({ children, variant = 'dark' }: Props) => {
return (
<ImageBackground
source={MAP[variant]}
style={{
height: undefined,
width: undefined,
flex: 1,
}}
imageStyle={{
resizeMode: 'cover',
}}
>
{children}
</ImageBackground>
)
}
Example #5
Source File: Messages.tsx From tinder-expo with MIT License | 6 votes |
Messages = () => (
<ImageBackground
source={require("../assets/images/bg.png")}
style={styles.bg}
>
<View style={styles.containerMessages}>
<View style={styles.top}>
<Text style={styles.title}>Messages</Text>
<TouchableOpacity>
<Icon name="ellipsis-vertical" color={DARK_GRAY} size={20} />
</TouchableOpacity>
</View>
<FlatList
data={DEMO}
keyExtractor={(item, index) => index.toString()}
renderItem={({ item }) => (
<TouchableOpacity>
<Message
image={item.image}
name={item.name}
lastMessage={item.message}
/>
</TouchableOpacity>
)}
/>
</View>
</ImageBackground>
)
Example #6
Source File: Matches.tsx From tinder-expo with MIT License | 6 votes |
Matches = () => (
<ImageBackground
source={require("../assets/images/bg.png")}
style={styles.bg}
>
<View style={styles.containerMatches}>
<View style={styles.top}>
<Text style={styles.title}>Matches</Text>
<TouchableOpacity>
<Icon name="ellipsis-vertical" color={DARK_GRAY} size={20} />
</TouchableOpacity>
</View>
<FlatList
numColumns={2}
data={DEMO}
keyExtractor={(item, index) => index.toString()}
renderItem={({ item }) => (
<TouchableOpacity>
<CardItem
image={item.image}
name={item.name}
isOnline={item.isOnline}
hasVariant
/>
</TouchableOpacity>
)}
/>
</View>
</ImageBackground>
)
Example #7
Source File: index.tsx From nlw2-proffy with MIT License | 6 votes |
function GiveClasses() {
const {goBack} = useNavigation();
function handleNavigateBack() {
goBack();
}
return (
<View style={styles.container}>
<ImageBackground resizeMode="contain" source={giveClassesBgImage} style={styles.content}>
<Text style={styles.title}>
Quer ser um Proffy?
</Text>
<Text style={styles.description}>
Para começar, você precisa se cadastrar como um professor na nossa plataforma web.
</Text>
</ImageBackground>
<RectButton onPress={handleNavigateBack} style={styles.okButton}>
<Text style={styles.okButtonText}>Tudo bem</Text>
</RectButton>
</View>
);
}
Example #8
Source File: Home.tsx From tinder-expo with MIT License | 6 votes |
Home = () => {
const [swiper, setSwiper] = useState<CardStack | null>(null);
return (
<ImageBackground
source={require("../assets/images/bg.png")}
style={styles.bg}
>
<View style={styles.containerHome}>
<View style={styles.top}>
<City />
<Filters />
</View>
<CardStack
loop
verticalSwipe={false}
renderNoMoreCards={() => null}
ref={(newSwiper): void => setSwiper(newSwiper)}
>
{DEMO.map((item) => (
<Card key={item.id}>
<CardItem
hasActions
image={item.image}
name={item.name}
description={item.description}
matches={item.match}
/>
</Card>
))}
</CardStack>
</View>
</ImageBackground>
);
}
Example #9
Source File: CategoryList.tsx From sellflow with MIT License | 5 votes |
export default function CategoryList(props: Props) {
let {
containerStyle,
textStyle,
categories,
onSelect,
...otherprops
} = props;
return (
<FlatList
showsHorizontalScrollIndicator={false}
horizontal={true}
data={categories}
renderItem={({ item }) => (
<TouchableOpacity
style={[
styles.categoryItemContainer,
styles.borderRadius,
!item.image && styles.color,
containerStyle,
]}
onPress={() => onSelect(item)}
>
{item.image ? (
<ImageBackground
source={{ uri: item.image }}
imageStyle={styles.borderRadius}
style={styles.categoryItemContainer}
>
<Text
weight="medium"
style={[styles.categoryItemText, textStyle]}
>
{item.title}
</Text>
</ImageBackground>
) : (
<Text weight="medium" style={[styles.categoryItemText, textStyle]}>
{item.title}
</Text>
)}
</TouchableOpacity>
)}
ItemSeparatorComponent={Separator}
keyExtractor={(item) => item.id}
contentContainerStyle={styles.flatlistContainer}
{...otherprops}
/>
);
}
Example #10
Source File: ProductItem.tsx From sellflow with MIT License | 5 votes |
export default function ProductItem(props: Props) {
let {
product: { title, images, price, discount, availableForSale },
onPress,
containerStyle,
imageStyle,
} = props;
let afterDiscount = priceAfterDiscount(price, discount || 0);
let formatCurrency = useCurrencyFormatter();
let renderImage = () => {
return availableForSale ? (
<View style={styles.imageContainer}>
<Image style={[styles.image, imageStyle]} source={{ uri: images[0] }} />
</View>
) : (
<View style={styles.imageContainer}>
<ImageBackground
style={[styles.image, imageStyle]}
source={{ uri: images[0] }}
>
<View style={styles.oosBackground}>
<Text style={styles.oosText} weight="medium">
{t('Out of Stock')}
</Text>
</View>
</ImageBackground>
</View>
);
};
return (
<TouchableOpacity
style={[styles.container, containerStyle]}
onPress={onPress}
>
{renderImage()}
{discount && discount > 0 ? (
<DiscountBadge value={discount} containerStyle={styles.discountBox} />
) : null}
<Text numberOfLines={1} style={styles.nameText}>
{title}
</Text>
<View style={styles.priceContainer}>
<Text style={styles.priceText} weight="bold">
{discount && discount > 0
? formatCurrency(afterDiscount)
: formatCurrency(price)}
</Text>
{discount && discount > 0 ? (
<Text style={styles.discountedPrice}>{formatCurrency(price)}</Text>
) : null}
</View>
</TouchableOpacity>
);
}
Example #11
Source File: index.tsx From nlw-01-omnistack with MIT License | 5 votes |
Home = () => {
const [uf, setUf] = useState('');
const [city, setCity] = useState('');
const navigation = useNavigation();
function handleNavigateToPoints() {
navigation.navigate('Points', {
uf,
city,
});
}
return (
<KeyboardAvoidingView
style={{ flex: 1 }}
behavior={Platform.OS === 'ios' ? 'padding' : undefined}
>
<ImageBackground
source={require('../../assets/home-background.png')}
style={styles.container}
imageStyle={{ width: 274, height: 368 }}
>
<View style={styles.main}>
<Image source={require('../../assets/logo.png')} />
<View>
<Text style={styles.title}>Seu marketplace de coleta de resíduos</Text>
<Text style={styles.description}>Ajudamos pessoas a encontrarem pontos de coleta de forma eficiente.</Text>
</View>
</View>
<View style={styles.footer}>
<TextInput
style={styles.input}
placeholder="Digite a UF"
value={uf}
maxLength={2}
autoCapitalize="characters"
autoCorrect={false}
onChangeText={setUf}
/>
<TextInput
style={styles.input}
placeholder="Digite a cidade"
value={city}
autoCorrect={false}
onChangeText={setCity}
/>
<RectButton style={styles.button} onPress={handleNavigateToPoints}>
<View style={styles.buttonIcon}>
<Text>
<Icon name="arrow-right" color="#FFF" size={24} />
</Text>
</View>
<Text style={styles.buttonText}>
Entrar
</Text>
</RectButton>
</View>
</ImageBackground>
</KeyboardAvoidingView>
);
}
Example #12
Source File: index.tsx From react-native-better-image with MIT License | 5 votes |
AnimatedImageBackground = createAnimatedComponent(ImageBackground)
Example #13
Source File: ProfilePicture.tsx From orangehrm-os-mobile with GNU General Public License v3.0 | 5 votes |
ProfilePicture = (props: ProfilePictureProps) => {
const {theme, imageSource, name, jobTitle} = props;
return (
<View>
<ImageBackground
source={imageSource ? imageSource : require('images/default-photo.png')}
style={styles.backgroundImageWidth}
imageStyle={styles.backgroundImage}>
<View>
<View style={styles.thumbnailContainer}>
<Thumbnail
large
source={
imageSource ? imageSource : require('images/default-photo.png')
}
style={{margin: theme.spacing * 4}}
/>
</View>
<View
style={{
marginLeft: theme.spacing * 4,
marginBottom: theme.spacing * 4,
}}>
{name === undefined ? null : (
<Text
style={[styles.nameText, {color: theme.typography.darkColor}]}>
{name}
</Text>
)}
{jobTitle === undefined || jobTitle === null ? null : (
<Text style={{color: theme.typography.darkColor}}>
{jobTitle}
</Text>
)}
</View>
</View>
</ImageBackground>
</View>
);
}
Example #14
Source File: index.tsx From nlw-ecoleta with MIT License | 5 votes |
Home = () => {
const [uf, setUf] = useState('');
const [city, setCity] = useState('');
const navigation = useNavigation();
function handleNavigateToPoints() {
navigation.navigate('Points', { uf, city });
}
return (
<KeyboardAvoidingView style={{ flex: 1}} behavior={Platform.OS === 'ios' ? 'padding' : undefined}>
<ImageBackground
source={require('../../assets/home-background.png')}
style={styles.container}
imageStyle={{ width: 274, height: 368 }}
>
<View style={styles.main}>
<Image source={require('../../assets/logo.png')} />
<View>
<Text style={styles.title}>Seu marketplace de coleta de resíduos</Text>
<Text style={styles.description}>Ajudamos pessoas a encontrarem pontos de coleta de forma eficiente</Text>
</View>
</View>
<View style={styles.footer}>
<TextInput
style={styles.input}
placeholder="Digite a UF"
value={uf}
maxLength={2}
autoCapitalize="characters"
autoCorrect={false}
onChangeText={setUf}
/>
<TextInput
style={styles.input}
placeholder="Digite a cidade"
value={city}
autoCorrect={false}
onChangeText={setCity}
/>
<RectButton style={styles.button} onPress={handleNavigateToPoints}>
<View style={styles.buttonIcon}>
<Text>
<Icon name='arrow-right' color='#FFF' size={24} />
</Text>
</View>
<Text style={styles.buttonText}> Entrar </Text>
</RectButton>
</View>
</ImageBackground>
</KeyboardAvoidingView>
);
}
Example #15
Source File: PostImagePreview.tsx From lexicon with MIT License | 5 votes |
export default function PostImagePreview() {
const styles = useStyles();
const { colors } = useTheme();
const { navigate, goBack } = useNavigation<
RootStackNavProp<'PostImagePreview'>
>();
const {
params: { imageUri, prevScreen },
} = useRoute<RootStackRouteProp<'PostImagePreview'>>();
const uploading = () => {
navigate(prevScreen, { imageUri });
};
return (
<View style={styles.container}>
<StatusBar style={'light'} />
<SafeAreaView style={styles.fullContainer}>
<ImageBackground
source={{ uri: imageUri }}
resizeMode="contain"
style={styles.fullContainer}
>
<View
style={{ flexDirection: 'row', justifyContent: 'space-between' }}
>
<Icon
name="Close"
color={colors.pureWhite}
onPress={goBack}
style={styles.iconContainer}
/>
<Icon
name="Add"
color={colors.pureWhite}
onPress={uploading}
style={styles.iconContainer}
/>
</View>
</ImageBackground>
</SafeAreaView>
</View>
);
}
Example #16
Source File: index.tsx From NLW-1.0 with MIT License | 5 votes |
Home: React.FC = () => {
const [uf, setUf] = useState("");
const [city, setCity] = useState("");
const navigation = useNavigation();
function handleNavigateToPoints() {
navigation.navigate("Points", {
uf,
city,
});
}
return (
<KeyboardAvoidingView
style={{ flex: 1 }}
behavior={Platform.OS === "ios" ? "padding" : undefined}
>
<ImageBackground
source={require("../../assets/home-background.png")}
style={styles.container}
imageStyle={{
width: 274,
height: 368,
}}
>
<View style={styles.main}>
<Image source={require("../../assets/logo.png")} />
<View>
<Text style={styles.title}>
Seu marketplace de coleta de resíduos
</Text>
<Text style={styles.description}>
Ajudamos pessoas a encontrarem pontos de coleta de forma
eficiente.
</Text>
</View>
</View>
<View style={styles.footer}>
<TextInput
style={styles.input}
value={uf}
onChangeText={setUf}
maxLength={2}
autoCapitalize="characters"
autoCorrect={false}
placeholder="Digite a UF"
/>
<TextInput
style={styles.input}
placeholder="Digite a cidade"
value={city}
autoCorrect={false}
onChangeText={setCity}
/>
<RectButton
style={styles.button}
onPress={() => handleNavigateToPoints()}
>
<View style={styles.buttonIcon}>
<Icon name="arrow-right" color="#fff" size={24} />
</View>
<Text style={styles.buttonText}>Entrar</Text>
</RectButton>
</View>
</ImageBackground>
</KeyboardAvoidingView>
);
}
Example #17
Source File: CustomImage.tsx From lexicon with MIT License | 5 votes |
export function CustomImage(props: Props) {
const styles = useStyles();
const {
src,
size = 'm',
square = false,
style,
defaultImage = DEFAULT_IMAGE,
...otherProps
} = props;
const [show, setShow] = useState(false);
const [error, setError] = useState(false);
const sizeStyle = {
height: variantSize[size],
...(square && { width: variantSize[size] }),
};
const imgSource = { uri: src };
const hideImage = src === '' || error;
const onPress = () => {
if (show) {
setShow(false);
}
setTimeout(() => setShow(true), 50);
};
const onPressCancel = () => {
if (!show) {
setShow(true);
}
setTimeout(() => setShow(false), 50);
};
const content = (
<ImageBackground
source={defaultImage}
style={[styles.image, sizeStyle]}
resizeMode="cover"
{...otherProps}
>
<CachedImage
source={imgSource}
style={[styles.image, sizeStyle]}
resizeMode="cover"
onError={() => setError(true)}
{...otherProps}
/>
</ImageBackground>
);
return !hideImage ? (
<>
<TouchableOpacity
delayPressIn={100}
style={[styles.container, style]}
onPress={onPress}
>
{content}
</TouchableOpacity>
{show && (
<ShowImageModal
show={show}
userImage={imgSource}
onPressCancel={onPressCancel}
/>
)}
</>
) : (
<View style={styles.noContent} />
);
}
Example #18
Source File: index.tsx From lexicon with MIT License | 5 votes |
export function Avatar(props: Props) {
const styles = useStyles();
const { colors } = useTheme();
const {
src = '',
size = 's',
color = colors.textLighter,
style,
label = '',
onPress,
...otherProps
} = props;
const [error, setError] = useState(false);
const [loading, setLoading] = useState(true);
const finalSize = AVATAR_ICON_SIZES[size];
const fontSize = AVATAR_LETTER_SIZES[size];
const loadChild = src === '' || error;
const imgSource = { uri: src };
const letterAvatar = (
<LetterAvatar
size={finalSize}
color={color}
label={label}
style={style}
fontSize={fontSize}
/>
);
return (
<TouchableOpacity onPress={onPress}>
{src === '' && loading ? (
letterAvatar
) : (
<ImageBackground
source={imgSource}
style={[{ width: finalSize, height: finalSize }, style]}
imageStyle={styles.circle}
onError={() => setError(true)}
// TODO: Decide what to display onLoading
onLoadEnd={() => setLoading(false)}
{...otherProps}
>
{loadChild && letterAvatar}
</ImageBackground>
)}
</TouchableOpacity>
);
}
Example #19
Source File: Profile.tsx From tinder-expo with MIT License | 5 votes |
Profile = () => {
const {
age,
image,
info1,
info2,
info3,
info4,
location,
match,
name,
} = DEMO[7];
return (
<ImageBackground
source={require("../assets/images/bg.png")}
style={styles.bg}
>
<ScrollView style={styles.containerProfile}>
<ImageBackground source={image} style={styles.photo}>
<View style={styles.top}>
<TouchableOpacity>
<Icon
name="chevron-back"
size={20}
color={WHITE}
style={styles.topIconLeft}
/>
</TouchableOpacity>
<TouchableOpacity>
<Icon
name="ellipsis-vertical"
size={20}
color={WHITE}
style={styles.topIconRight}
/>
</TouchableOpacity>
</View>
</ImageBackground>
<ProfileItem
matches={match}
name={name}
age={age}
location={location}
info1={info1}
info2={info2}
info3={info3}
info4={info4}
/>
<View style={styles.actionsProfile}>
<TouchableOpacity style={styles.circledButton}>
<Icon name="ellipsis-horizontal" size={20} color={WHITE} />
</TouchableOpacity>
<TouchableOpacity style={styles.roundedButton}>
<Icon name="chatbubble" size={20} color={WHITE} />
<Text style={styles.textButton}>Start chatting</Text>
</TouchableOpacity>
</View>
</ScrollView>
</ImageBackground>
);
}
Example #20
Source File: index.tsx From ecoleta with MIT License | 5 votes |
Home = () => {
const navigation = useNavigation();
const [uf, setUf] = useState('');
const [city, setCity] = useState('');
function handleNavigateToPoints() {
navigation.navigate('Points', {
uf,
city,
});
}
return (
<KeyboardAvoidingView
style={{ flex: 1, marginBottom: 25 }}
behavior={Platform.OS === 'ios' ? 'padding' : undefined}
>
<ImageBackground
style={styles.container}
source={require('../../assets/home-background.png')}
imageStyle={{ width: 274, height: 368 }}
>
<View style={styles.main}>
<Image source={require('../../assets/logo.png')} />
<View>
<Text style={styles.title}>
Seu marketplace de coleta de resíduos
</Text>
<Text style={styles.description}>
Ajudamos pessoas a encontrarem pontos de coleta de forma
eficiente.
</Text>
</View>
</View>
<View style={styles.footer}>
<TextInput
style={styles.input}
placeholder="Digite a UF"
value={uf}
onChangeText={setUf}
maxLength={2}
autoCorrect={false}
autoCapitalize="characters"
/>
<TextInput
style={styles.input}
placeholder="Digite a cidade"
value={city}
onChangeText={setCity}
autoCorrect={false}
/>
<RectButton style={styles.button} onPress={handleNavigateToPoints}>
<View style={styles.buttonIcon}>
<Feather name="arrow-right" color="#fff" size={24} />
</View>
<Text style={styles.buttonText}>Entrar</Text>
</RectButton>
</View>
</ImageBackground>
</KeyboardAvoidingView>
);
}
Example #21
Source File: InfoModal.tsx From hamagen-react-native with MIT License | 5 votes |
InfoModal = ({ strings, firstPointDate, closeModal, showModal }: InfoModalProps) => {
const {
scanHome: {
noExposures: {
infoModal: {
textBodyPt1,
textBodyPt2
}
}
}
} = strings;
return (
<Modal
animationType="fade"
onRequestClose={closeModal}
visible={showModal}
>
<TouchableWithoutFeedback onPress={closeModal}>
<ImageBackground
resizeMode="cover"
style={styles.imageContainer}
source={require('../../../assets/main/infoModalBG.png')}
>
<View style={[styles.container]}>
<TouchableOpacity style={styles.closeBtnContainer} hitSlop={HIT_SLOP} onPress={closeModal}>
<Icon source={require('../../../assets/onboarding/close.png')} width={19} />
</TouchableOpacity>
<Icon
source={require('../../../assets/main/moreInfoBig.png')}
width={31}
customStyles={styles.infoIcon}
/>
<Text>
<Text style={styles.infoText}>{textBodyPt1.trim()}</Text>
<Text style={styles.infoText} bold>{` ${firstPointDate} `}</Text>
<Text style={styles.infoText}>{textBodyPt2.trim()}</Text>
</Text>
</View>
</ImageBackground>
</TouchableWithoutFeedback>
</Modal>
);
}
Example #22
Source File: DrawerContent.tsx From hamagen-react-native with MIT License | 5 votes |
DrawerContent = ({ navigation }: Props) => {
const { locale: { strings: { general: { versionNumber } }, isRTL } } = useSelector<Store, Store>(state => state);
const [showSettings, setShowSettings] = useState(false);
const isDrawerOpen = useIsDrawerOpen();
useEffect(() => {
if (!isDrawerOpen) {
setShowSettings(false);
}
}, [isDrawerOpen]);
return (
<ImageBackground
style={{ flex: 1, }}
source={require('../../assets/main/menuBG.png')}
>
<TouchableOpacity
style={[styles.close, { [isRTL ? 'left' : 'right']: 20 }]}
hitSlop={HIT_SLOP}
onPress={navigation.closeDrawer}
>
<Icon source={require('../../assets/main/menuClose.png')} width={12} height={18} />
</TouchableOpacity>
<View style={{ flex: 1, flexDirection: isRTL ? 'row-reverse' : 'row' }}>
{showSettings
? (
<SettingsDrawerContent
navigation={navigation}
goToMainDrawer={() => setShowSettings(false)}
/>
)
: (
<HomeDrawerContent
navigation={navigation}
showSettings={() => setShowSettings(true)}
/>
)
}
</View>
<View style={[styles.footerContainer, { alignSelf: isRTL ? 'flex-end' : 'flex-start' }]}>
<Text style={styles.versionText}>{`${versionNumber} ${VERSION_NAME}`}</Text>
</View>
</ImageBackground>
);
}
Example #23
Source File: CachedImage.tsx From companion-kit with MIT License | 5 votes |
export function CachedImage(this: void, props: CachedImageProps) {
const [imgURI, setImgURI] = React.useState('');
const state = React.useMemo(() => ({ loading: false, mounted: false }), []);
const safeCall = React.useCallback((cb: () => any) => {
if (state.mounted) {
cb();
}
}, [state]);
const loadImage = async (filesystemURI: string, remoteURI: string) => {
try {
// Use the cached image if it exists
const metadata = await FileSystem.getInfoAsync(filesystemURI);
if (metadata.exists) {
safeCall(() => setImgURI(filesystemURI));
return;
}
// otherwise download to cache
const imageObject = await FileSystem.downloadAsync(
remoteURI,
filesystemURI,
);
safeCall(() => setImgURI(imageObject.uri));
} catch (err) {
console.log('Image loading error:', err);
safeCall(() => setImgURI(remoteURI));
}
};
React.useEffect(() => {
state.mounted = true;
(async () => {
const uri = (props.source as ImageURISource).uri;
if (uri) {
const filesystemURI = await getImageFilesystemKey(uri);
if (imgURI !== uri && imgURI !== filesystemURI) {
await loadImage(filesystemURI, uri);
}
}
})();
return () => {
state.mounted = false;
};
}, [(props.source as ImageURISource).uri]);
let source: ImageProps['source'] = imgURI ? { uri: imgURI } : null;
if (!source && props.source) {
source = props.source;
}
if (props.isBackground) {
return (
<ImageBackground
{...props}
source={source}
>
{props.children}
</ImageBackground>
);
} else {
return (
<Image
{...props}
source={source}
/>
);
}
}
Example #24
Source File: index.tsx From ecoleta with MIT License | 5 votes |
Home = () => {
const [uf, setUf] = useState('');
const [city, setCity] = useState('');
const navigation = useNavigation();
function handleNavigateToPoints() {
navigation.navigate('Points', {
uf,
city
});
}
return (
<KeyboardAvoidingView style={{ flex: 1 }} behavior={Platform.OS === 'ios' ? 'padding' : undefined}>
<ImageBackground
source={require('../../assets/home-background.png')}
style={styles.container}
imageStyle={{ width: 274, height: 368 }}
>
<View style={styles.main}>
<Image source={require('../../assets/logo.png')} />
<View>
<Text style={styles.title}>Seu maketplace de coleta de resíduos.</Text>
<Text style={styles.description}>Ajudamos pessoas a encontrarem pontos de coleta de forma eficiente.</Text>
</View>
</View>
<View style={styles.footer}>
<TextInput
style={styles.input}
placeholder="Digite a UF"
value={uf}
maxLength={2}
autoCapitalize="characters"
autoCorrect={false}
onChangeText={setUf}
/>
<TextInput
style={styles.input}
placeholder="Digite a Cidade"
value={city}
autoCorrect={false}
onChangeText={setCity}
/>
<RectButton style={styles.button} onPress={handleNavigateToPoints}>
<View style={styles.buttonIcon}>
<Text>
<Icon name="arrow-right" color="#FFF" size={24} />
</Text>
</View>
<Text style={styles.buttonText}>
Entrar
</Text>
</RectButton>
</View>
</ImageBackground>
</KeyboardAvoidingView>
);
}
Example #25
Source File: ImagePreview.tsx From lexicon with MIT License | 4 votes |
export default function ImagePreview() {
const styles = useStyles();
const { colors } = useTheme();
const { navigate, goBack } = useNavigation<StackNavProp<'ImagePreview'>>();
const { params } = useRoute<StackRouteProp<'ImagePreview'>>();
const { topicId, imageUri, postPointer, message } = params;
const [loading, setLoading] = useState(false);
const [imageMessage, setImageMessage] = useState(message);
const [cursorPosition, setCursorPosition] = useState<CursorPosition>({
start: 0,
end: 0,
});
const [showUserList, setShowUserList] = useState(false);
const [mentionLoading, setMentionLoading] = useState(false);
const [mentionKeyword, setMentionKeyword] = useState('');
const messageRef = useRef<TextInputType>(null);
const user = useStorage().getItem('user');
const { reply } = useReplyPost({
onCompleted: () => {
navigate('MessageDetail', {
id: topicId,
postPointer: postPointer + 1,
emptied: true,
hyperlinkUrl: '',
hyperlinkTitle: '',
});
},
onError: (error) => {
setLoading(false);
errorHandlerAlert(error);
},
});
const { mentionMembers } = useMention(
mentionKeyword,
showUserList,
setMentionLoading,
);
const reactNativeFile = createReactNativeFile(imageUri);
const postToServer = (caption: string) => {
setLoading(true);
reply({
variables: {
replyInput: {
topicId,
raw: caption,
},
file: reactNativeFile,
userId: user?.id,
type: UploadTypeEnum.composer,
},
});
};
const onPressCancel = () => {
goBack();
};
const footer = (
<View>
<MentionList
showUserList={showUserList}
members={mentionMembers}
mentionLoading={mentionLoading}
rawText={imageMessage}
textRef={messageRef}
setRawText={setImageMessage}
setShowUserList={setShowUserList}
viewStyle={styles.mentionList}
fontStyle={styles.mentionText}
/>
<View style={styles.inputContainer}>
<ReplyInputField
inputRef={messageRef}
onSelectedChange={(cursor) => {
setCursorPosition(cursor);
}}
onChangeValue={(imageMessage: string) => {
mentionHelper(
imageMessage,
cursorPosition,
setShowUserList,
setMentionLoading,
setMentionKeyword,
);
setImageMessage(imageMessage);
}}
showButton
inputPlaceholder={t('Write your caption here')}
loading={loading}
disabled={loading}
onPressSend={postToServer}
style={styles.inputField}
message={imageMessage}
setMessage={setImageMessage}
/>
</View>
</View>
);
return (
<View style={styles.container}>
<StatusBar style={'light'} />
<SafeAreaView style={styles.fullContainer}>
<ImageBackground
source={{ uri: imageUri }}
resizeMode="contain"
style={styles.fullContainer}
>
<Icon
name="Close"
color={colors.pureWhite}
onPress={onPressCancel}
disabled={loading}
style={styles.iconContainer}
/>
</ImageBackground>
<KeyboardAccessoryView
androidAdjustResize
inSafeAreaView
alwaysVisible
style={styles.inputViewContainer}
>
{footer}
</KeyboardAccessoryView>
</SafeAreaView>
</View>
);
}
Example #26
Source File: RecentlyViewed.tsx From RNChallenge_2 with MIT License | 4 votes |
RecentlyViewed = ({furniture, index}: Props) => {
const {width, height} = useWindowDimensions();
return (
<View
style={[
styles.container,
{
width: width * 0.55,
height: height * 0.17,
backgroundColor: `${colors[`furniture${index % 4}`]}45`,
},
]}>
<ImageBackground
resizeMode={'stretch'}
style={{
width: width * 0.45,
height: height * 0.1,
opacity: 0.7,
}}
source={furniture.images[0]}></ImageBackground>
<View
style={[
styles.banner,
{
height: height * 0.07,
},
]}>
<View style={[styles.row]}>
<View
style={[
styles.column,
{
width: '60%',
},
]}>
<Text numberOfLines={2} style={[styles.name]}>
{furniture.name}
</Text>
<Text numberOfLines={2} style={[styles.desc]}>
{furniture.desc}
</Text>
</View>
<View
style={[
styles.column,
{
paddingLeft: 20,
alignItems: 'flex-end',
},
]}>
<Text style={[styles.name]}>{furniture.price} $</Text>
<View
style={{
flexDirection: 'row',
justifyContent: 'space-between',
}}>
<TouchableOpacity
style={[
styles.likeBtn,
{
marginRight: 5,
},
]}>
<Image
style={{
width: 10,
height: 10,
}}
source={require('../Assets/Icons/cart.png')}
/>
</TouchableOpacity>
<TouchableOpacity style={[styles.likeBtn]}>
<Image
style={{
width: 10,
height: 10,
}}
source={require('../Assets/Icons/like.png')}
/>
</TouchableOpacity>
</View>
</View>
</View>
</View>
</View>
);
}
Example #27
Source File: Container.tsx From react-native-jigsaw with MIT License | 4 votes |
Container: React.FC<Props> = ({
useThemeGutterPadding,
borderColor,
borderWidth,
backgroundColor,
backgroundImage,
backgroundImageResizeMode,
elevation,
style,
children,
theme, // eslint-disable-line @typescript-eslint/no-unused-vars
...rest
}) => {
const {
flex,
flexGrow,
flexWrap,
flexBasis,
flexShrink,
flexDirection,
alignContent,
justifyContent,
alignItems,
padding,
paddingTop,
paddingBottom,
paddingLeft,
paddingRight,
paddingVertical,
paddingHorizontal,
...styleProp
} = StyleSheet.flatten(style) || {};
const containerStyle: StyleProp<ViewStyle> = {
backgroundColor,
borderColor,
borderWidth,
width: "100%",
...styleProp,
};
const innerStyle: StyleProp<ViewStyle> = {
flex,
flexGrow,
flexWrap,
flexBasis,
flexShrink,
flexDirection,
alignContent,
justifyContent,
alignItems,
padding,
paddingTop,
paddingBottom,
paddingLeft,
paddingRight,
paddingVertical,
paddingHorizontal: paddingHorizontal || useThemeGutterPadding ? 16 : 0,
};
const Wrap = elevation ? Elevation : View;
if (elevation) containerStyle.elevation = elevation;
return (
<Wrap style={[containerStyle, style]} {...rest}>
{backgroundImage ? (
<ImageBackground
source={
typeof backgroundImage === "string"
? { uri: backgroundImage }
: backgroundImage
}
resizeMode={backgroundImageResizeMode}
style={{
flex: 1,
}}
>
<View style={innerStyle}>{children}</View>
</ImageBackground>
) : (
<View style={innerStyle}>{children}</View>
)}
</Wrap>
);
}
Example #28
Source File: index.tsx From NextLevelWeek with MIT License | 4 votes |
Home = () => {
const [uf, setUF] = useState<UF[]>([]);
const [city, setCity] = useState<City[]>([]);
const [selectedUf, setSelectedUf] = useState("0");
const [selectedCity, setSelectedCity] = useState("0");
const navigation = useNavigation();
/**
* API IBGE
*/
useEffect(() => {
axios
.get(
"https://servicodados.ibge.gov.br/api/v1/localidades/estados?orderBy=nome"
)
.then((response) => {
setUF(response.data);
});
}, []);
useEffect(() => {
if (selectedUf === "0") {
return;
}
axios
.get(
`https://servicodados.ibge.gov.br/api/v1/localidades/estados/${selectedUf}/municipios`
)
.then((response) => {
setCity(response.data);
});
}, [selectedUf]);
/**
* Função para navegar de uma tela para a outra.
*/
function handleNavigateToPoints() {
navigation.navigate("Points", {
selectedUf,
selectedCity,
});
}
/**
* Funções do "select"
*/
function handleSelectedUf(uf: string) {
setSelectedUf(uf);
}
function handleSelectedCity(city: string) {
setSelectedCity(city);
}
return (
// KeyboardAvoidingView - Para evitar que o teclado fique por cima da aplicação.
<KeyboardAvoidingView
style={{ flex: 1 }}
behavior={Platform.OS === "ios" ? "padding" : undefined}
>
<ImageBackground
source={require("../../assets/home-background.png")}
style={styles.container}
imageStyle={{ width: 274, height: 368 }}
>
<View style={styles.main}>
<Image source={require("../../assets/logo.png")} />
<View>
<Text style={styles.title}>
Seu marketplace de coleta de resíduos
</Text>
<Text style={styles.description}>
Ajudamnos pessoas a encontrarem pontos de coleta de forma
eficiente.
</Text>
</View>
</View>
<View style={styles.footer}>
<RNPickerSelect
placeholder={{
label: "Selecione uma UF",
value: "0",
}}
style={{
viewContainer: {
backgroundColor: "#FFF",
alignItems: "center",
justifyContent: "center",
height: 60,
borderRadius: 10,
marginBottom: 8,
paddingHorizontal: 24,
},
}}
onValueChange={(item) => handleSelectedUf(item)}
items={uf.map((item) => {
return {
label: `${item.sigla} - ${item.nome}`,
value: item.sigla,
};
})}
/>
<RNPickerSelect
placeholder={{
label: "Selecione uma cidade",
value: "0",
}}
style={{
viewContainer: {
backgroundColor: "#FFF",
alignItems: "center",
justifyContent: "center",
height: 60,
borderRadius: 10,
marginBottom: 8,
paddingHorizontal: 24,
},
}}
onValueChange={(item) => handleSelectedCity(item)}
items={
city
? city.map((item) => {
return { label: `${item.nome}`, value: item.nome };
})
: []
}
/>
<RectButton style={styles.button} onPress={handleNavigateToPoints}>
<View style={styles.buttonIcon}>
<Text>
<Icon name="arrow-right" color="#FFF" size={24} />
</Text>
</View>
<Text style={styles.buttonText}>Entrar</Text>
</RectButton>
</View>
</ImageBackground>
</KeyboardAvoidingView>
);
}
Example #29
Source File: index.tsx From react-native-credit-card-display with MIT License | 4 votes |
CreditCardDisplay = (props: Props) => {
let cardTypeIcon = null;
switch (creditcardutils.parseCardType(props.number as string)) {
case 'amex':
cardTypeIcon = {
uri: '',
};
break;
case 'dinersclub':
cardTypeIcon = {
uri: '',
};
break;
case 'discover':
cardTypeIcon = {
uri: '',
};
break;
case 'jcb':
cardTypeIcon = {
uri: '',
};
break;
case 'maestro':
cardTypeIcon = {
uri: '',
};
break;
case 'mastercard':
cardTypeIcon = {
uri: '',
};
break;
case 'unionpay':
cardTypeIcon = {
uri: '',
};
break;
case 'visa':
cardTypeIcon = {
uri: '',
};
break;
case 'visaelectron':
cardTypeIcon = {
uri: '',
};
break;
}
return (
<View style={{ height: props.height, width: props.width }}>
<FlipCard
style={props.cardStyles}
flipHorizontal={true}
flipVertical={false}
flip={props.flipped}
>
<View style={props.frontStyles}>
<View style={{ height: props.height, width: props.width }}>
<ImageBackground
source={props.frontImage}
style={styles.imageBackground}
imageStyle={{ borderRadius: props.borderRadius }}
>
<View style={styles.imageContainer}>
<View style={{ flexGrow: 1 }} />
<Text
style={{
fontSize: props.fontSize,
alignSelf: 'center',
color: props.fontColor,
}}
>
{creditcardutils.formatCardNumber(String(props.number))}
</Text>
<View style={styles.rowContainer}>
<View style={styles.groupContainer}>
{props.since && (
<>
<Text
style={{
...styles.groupLabel,
fontSize: props.fontSize * 0.7,
color: props.fontColor,
textAlign: 'right',
}}
>
CUSTOMER{'\n'}SINCE
</Text>
<Text
style={{
fontSize: props.fontSize * 0.7,
color: props.fontColor,
}}
>
{props.since}
</Text>
</>
)}
</View>
<View style={styles.groupContainer}>
{props.expiration && (
<>
<Text
style={{
...styles.groupLabel,
fontSize: props.fontSize * 0.7,
color: props.fontColor,
textAlign: 'center',
}}
>
VALID{'\n'}THRU
</Text>
<Text
style={{
fontSize: props.fontSize * 0.7,
color: props.fontColor,
}}
>
{creditcardutils.formatCardExpiry(props.expiration)}
</Text>
</>
)}
</View>
<View style={styles.cardTypeIconContainer}>
{cardTypeIcon && (
<Image
source={cardTypeIcon}
style={styles.cardTypeIcon}
resizeMode="contain"
/>
)}
</View>
</View>
<Text
style={{
fontSize: props.fontSize,
marginTop: 5,
color: props.fontColor,
}}
>
{props.name}
</Text>
</View>
</ImageBackground>
</View>
</View>
<View style={props.backStyles}>
<View style={{ height: props.height, width: props.width }}>
<ImageBackground
source={props.backImage}
style={styles.imageBackground}
imageStyle={{ borderRadius: props.borderRadius }}
>
<View style={{ height: '45%' }} />
<View style={{ flexDirection: 'row' }}>
<View style={{ width: '82%' }} />
<Text style={{ fontSize: props.fontSize, alignSelf: 'center' }}>
{props.cvc}
</Text>
</View>
</ImageBackground>
</View>
</View>
</FlipCard>
</View>
);
}