React Native components for picking phone number code. Supports 5 languages (Arab, German, French, Italian, Polish, Ukrainian, Russian, English, Spanish, Turkish)
npm react-native-phonecode-picker --save
import React, { useEffect, useState } from 'react';
import { View, Modal, SafeAreaView } from 'react-native';
import { PhoneInput, Countries, PhoneList } from 'react-native-phonecode-picker';
export const PhonePicker = () => {
const [phone, setPhone] = useState('');
const [country, setCountry] = useState({ countryName: '', phcode: '', key: '', mask: '', });
const [visible, setVisible] = useState(false);
useEffect(() => {
const country = Countries.getCountryByIso('en', 'UA');
setCountry(country);
}, []);
const onChooseCountry = (country: { countryName: string; phcode: string; key: string; mask: string; }) => {
setCountry(country);
setVisible(false);
};
return (
<View style={{ flex: 1, justifyContent: 'center', alignItems: 'center', paddingHorizontal: 30 }}>
<PhoneInput country={country} value={phone} onChangeText={setPhone} onPress={() => { setVisible(true) }} />
<Modal visible={visible} animationType='slide'>
<SafeAreaView style={{ flex: 1 }}>
<PhoneList language={'en'} onPress={onChooseCountry} isSearch={true} />
</SafeAreaView>
</Modal>
</View>
)
};
import { PhoneList } from 'react-native-phonecode-picker';
<PhoneList onPress={(country)=>console.log('country->', country)} language='en'/>
Language = 'ru' | 'es' | 'en' | 'ua' | 'ar' | 'de' | 'el' | 'fr' | 'it' | 'pl' | 'tr'
getCountries - returns countries array filtered by search.
interface ICountries {
getCountries: (lang: Language, search?: string) => Array<Country>;
getCountryByIso: (lang: Language, key: string) => Array<Country>;
getCountryByPhoneCode: (lang: Language, key: string) => Country | undefined;
};
console.log(CountriesApi.getCountries('en'));
getFlag - returns source flag by country key. getAllFlags - returns all source flag.
interface IFlags {
getFlag: (key: string) => any;
getAllFlags: () => object;
};
<Image source={FlagsApi.getFlag('US')} resizeMode="stretch" style={{ width: 30, height: 30 }} />
interface Props {
language: Language;
isSearch?: boolean;
onPress: (country: { countryName: string; phcode: string; key: string; mask: string; }) => void;
containerStyle?: object;
itemContainerStyle?: object;
textStyle?: object;
placeholder?: string;
};
interface Props {
country: { countryName: string; phcode: string; key: string; };
flag: sourseImage;
testID: string;
onPress: (country: { countryName: string; phcode: string; key: string; }) => void;
itemContainerStyle?: object;
textStyle?: object;
};
interface Props {
country: { countryName: string; phcode: string; key: string; mask: string };
onPress: () => void;
value: string;
onChangeText: (formatted: string, extracted: string | undefined) => void;
style?: {
container?: ViewStyle,
flag?: ImageStyle;
textInput?: TextStyle,
textCode?: TextStyle,
phoneCodeContainer?: ViewStyle,
placeholderTextColor?: ColorValue,
};
inputProps: TextInputMaskProps;
showFlag?: boolean;
};
interface Props {
searchString: string;
onChangeText: (text: string) => void;
placeholder?: string;
};
ISC