react-native-phone-input
Version:
Phone input box for React Native
197 lines • 31.7 kB
JavaScript
"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const react_1 = __importDefault(require("react")); // eslint-disable-line import/no-extraneous-dependencies, no-use-before-define
const react_native_1 = require("react-native");
const country_1 = __importDefault(require("./country"));
const flags_1 = __importDefault(require("./resources/flags"));
const PhoneNumber_1 = __importDefault(require("./PhoneNumber"));
const styles_1 = __importDefault(require("./styles"));
const CountryPicker_1 = __importDefault(require("./CountryPicker"));
class PhoneInput extends react_1.default.Component {
static setCustomCountriesData(json) {
country_1.default.setCustomCountriesData(json);
}
constructor(props) {
super(props);
this.onChangePhoneNumber = (number) => {
const actionAfterSetState = this.props.onChangePhoneNumber
? (displayValue, iso2) => {
var _a, _b;
(_b = (_a = this.props).onChangePhoneNumber) === null || _b === void 0 ? void 0 : _b.call(_a, displayValue, iso2);
}
: null;
this.updateValue(number, actionAfterSetState);
};
this.onPressFlag = () => {
if (this.props.onPressFlag) {
this.props.onPressFlag();
}
else {
if (this.state.iso2)
this.picker.selectCountry(this.state.iso2);
this.picker.show();
}
};
// eslint-disable-next-line class-methods-use-this
this.getFlag = (iso2) => flags_1.default.get(iso2);
this.getISOCode = () => this.state.iso2;
this.selectCountry = (iso2) => {
if (this.state.iso2 !== iso2) {
const countryData = PhoneNumber_1.default.getCountryDataByCode(iso2);
if (countryData) {
this.setState({
iso2,
displayValue: this.format(`+${countryData.dialCode}`),
value: `+${countryData.dialCode}`
}, () => {
if (this.props.onSelectCountry)
this.props.onSelectCountry(iso2);
});
}
}
};
this.setValue = (number) => {
if (this.state.value !== number) {
this.updateValue(number);
}
};
let { initialCountry, initialValue } = this.props;
const { countriesList, disabled } = this.props;
if (countriesList) {
country_1.default.setCustomCountriesData(countriesList);
}
let displayValue = '';
if (initialValue) {
if (initialValue[0] !== '+') {
initialValue = `+${initialValue}`;
}
initialCountry = PhoneNumber_1.default.getCountryCodeOfNumber(initialValue);
displayValue = this.format(initialValue, initialCountry);
}
else {
const countryData = PhoneNumber_1.default.getCountryDataByCode(initialCountry);
initialValue = countryData ? `+${countryData.dialCode}` : '';
displayValue = initialValue;
}
this.state = {
disabled,
iso2: initialCountry,
displayValue,
value: initialValue,
};
}
componentDidUpdate() {
const { disabled } = this.props;
if (disabled !== this.state.disabled) {
this.setState({ disabled }); // eslint-disable-line react/no-did-update-set-state
}
}
// eslint-disable-next-line class-methods-use-this
getPickerData() {
return PhoneNumber_1.default.getAllCountries().map((country, index) => ({
key: index,
image: flags_1.default.get(country.iso2),
label: country.name,
dialCode: `+${country.dialCode}`,
iso2: country.iso2
}));
}
getCountryCode() {
const countryData = PhoneNumber_1.default.getCountryDataByCode(this.state.iso2);
return countryData ? countryData.dialCode : null;
}
// eslint-disable-next-line class-methods-use-this
getAllCountries() {
return PhoneNumber_1.default.getAllCountries();
}
getDialCode() {
return PhoneNumber_1.default.getDialCode(this.state.value);
}
getValue(text) {
return text ? text.replace(/[^0-9]/g, '') : this.state.value;
}
getNumberType() {
return PhoneNumber_1.default.getNumberType(this.state.value, this.state.iso2);
}
isValidNumber() {
if (this.state.value.length < 4)
return false;
return PhoneNumber_1.default.isValidNumber(this.state.value, this.state.iso2);
}
format(text, iso2) {
return this.props.autoFormat
? PhoneNumber_1.default.format(text, iso2 || this.state.iso2)
: text;
}
updateValue(number, actionAfterSetState = null) {
let modifiedNumber = this.getValue(number);
const { allowZeroAfterCountryCode } = this.props;
if (modifiedNumber[0] !== '+' && number.length) {
modifiedNumber = `+${modifiedNumber}`;
}
modifiedNumber = allowZeroAfterCountryCode
? modifiedNumber
: this.possiblyEliminateZeroAfterCountryCode(modifiedNumber);
const iso2 = PhoneNumber_1.default.getCountryCodeOfNumber(modifiedNumber);
let countryDialCode;
if (iso2) {
const countryData = PhoneNumber_1.default.getCountryDataByCode(iso2);
countryDialCode = countryData.dialCode;
}
let displayValue;
if (modifiedNumber === `+${countryDialCode}`) {
displayValue = modifiedNumber;
}
else {
displayValue = this.format(modifiedNumber);
}
this.setState({
iso2,
displayValue,
value: modifiedNumber,
}, () => {
if (actionAfterSetState) {
actionAfterSetState(displayValue, iso2);
}
});
}
// eslint-disable-next-line class-methods-use-this
possiblyEliminateZeroAfterCountryCode(number) {
const dialCode = PhoneNumber_1.default.getDialCode(number);
return number.startsWith(`${dialCode}0`)
? dialCode + number.substr(dialCode.length + 1)
: number;
}
getAccessibilityLabel() {
return this.props.accessibilityLabel || 'Telephone input';
}
focus() {
this.inputPhone.focus();
}
blur() {
this.inputPhone.blur();
}
render() {
const { iso2, displayValue, disabled } = this.state;
const country = this.getAllCountries().find((c) => c.iso2 === iso2);
const TextComponent = this.props.textComponent || react_native_1.TextInput;
return (react_1.default.createElement(react_native_1.View, { style: [styles_1.default.container, this.props.style] },
react_1.default.createElement(react_native_1.TouchableOpacity, { onPress: this.onPressFlag, disabled: disabled, accessibilityRole: "imagebutton", accessibilityLabel: country ? country.name : iso2 }, this.props.renderFlag ? (react_1.default.createElement(react_1.default.Fragment, null, this.props.renderFlag({
imageSource: flags_1.default.get(iso2),
}))) : (react_1.default.createElement(react_native_1.Image, { accessibilityIgnoresInvertColors: true, source: flags_1.default.get(iso2), style: [styles_1.default.flag, this.props.flagStyle] }))),
react_1.default.createElement(react_native_1.View, { style: { flex: 1, marginLeft: this.props.offset || 10 } },
react_1.default.createElement(TextComponent, Object.assign({ ref: (ref) => {
this.inputPhone = ref;
}, accessibilityLabel: this.getAccessibilityLabel(), editable: !disabled, autoCorrect: false, style: [styles_1.default.text, this.props.textStyle], onChangeText: (text) => {
this.onChangePhoneNumber(text);
}, keyboardType: "phone-pad", underlineColorAndroid: "rgba(0,0,0,0)", value: displayValue }, this.props.textProps))),
react_1.default.createElement(CountryPicker_1.default, { ref: (ref) => {
this.picker = ref;
}, selectedCountry: iso2, onSubmit: this.selectCountry, buttonColor: this.props.pickerButtonColor, cancelText: this.props.cancelText, cancelTextStyle: this.props.cancelTextStyle, confirmText: this.props.confirmText, confirmTextStyle: this.props.confirmTextStyle, pickerBackgroundColor: this.props.pickerBackgroundColor, itemStyle: this.props.pickerItemStyle, onPressCancel: this.props.onPressCancel, onPressConfirm: this.props.onPressConfirm })));
}
}
exports.default = PhoneInput;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PhoneInput.js","sourceRoot":"","sources":["../src/PhoneInput.tsx"],"names":[],"mappings":"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","sourcesContent":["import React from 'react'; // eslint-disable-line import/no-extraneous-dependencies, no-use-before-define\nimport {\n    Image, TextInput, TouchableOpacity, View\n} from 'react-native';\nimport Country from './country';\nimport Flags from './resources/flags';\nimport PhoneNumber from './PhoneNumber';\nimport styles from './styles';\nimport CountryPicker from './CountryPicker';\nimport { ReactNativePhoneInputProps } from './typings';\n\nexport default class PhoneInput<TextComponentType extends React.ComponentType = typeof TextInput>\n    extends React.Component<ReactNativePhoneInputProps<TextComponentType>, any> {\n    static setCustomCountriesData(json) {\n        Country.setCustomCountriesData(json);\n    }\n\n    private picker: any;\n\n    private inputPhone: any;\n\n    constructor(props) {\n        super(props);\n\n        let {\n            initialCountry, initialValue\n        } = this.props;\n\n        const {\n            countriesList, disabled\n        } = this.props;\n\n        if (countriesList) {\n            Country.setCustomCountriesData(countriesList);\n        }\n\n        let displayValue = '';\n\n        if (initialValue) {\n            if (initialValue[0] !== '+') {\n                initialValue = `+${initialValue}`;\n            }\n\n            initialCountry = PhoneNumber.getCountryCodeOfNumber(initialValue);\n            displayValue = this.format(initialValue, initialCountry);\n        } else {\n            const countryData = PhoneNumber.getCountryDataByCode(initialCountry);\n            initialValue = countryData ? `+${countryData.dialCode}` : '';\n            displayValue = initialValue;\n        }\n\n        this.state = {\n            disabled,\n            iso2: initialCountry,\n            displayValue,\n            value: initialValue,\n        };\n    }\n\n    componentDidUpdate() {\n        const { disabled } = this.props;\n        if (disabled !== this.state.disabled) {\n            this.setState({ disabled }); // eslint-disable-line react/no-did-update-set-state\n        }\n    }\n\n    onChangePhoneNumber = (number) => {\n        const actionAfterSetState = this.props.onChangePhoneNumber\n            ? (displayValue: string, iso2: string) => {\n                this.props.onChangePhoneNumber?.(displayValue, iso2);\n            }\n            : null;\n        this.updateValue(number, actionAfterSetState);\n    }\n\n    onPressFlag = () => {\n        if (this.props.onPressFlag) {\n            this.props.onPressFlag();\n        } else {\n            if (this.state.iso2) this.picker.selectCountry(this.state.iso2);\n            this.picker.show();\n        }\n    }\n\n    // eslint-disable-next-line class-methods-use-this\n    getPickerData() {\n        return PhoneNumber.getAllCountries().map((country, index) => ({\n            key: index,\n            image: Flags.get(country.iso2),\n            label: country.name,\n            dialCode: `+${country.dialCode}`,\n            iso2: country.iso2\n        }));\n    }\n\n    getCountryCode() {\n        const countryData = PhoneNumber.getCountryDataByCode(this.state.iso2);\n        return countryData ? countryData.dialCode : null;\n    }\n\n    // eslint-disable-next-line class-methods-use-this\n    getAllCountries() {\n        return PhoneNumber.getAllCountries();\n    }\n\n    // eslint-disable-next-line class-methods-use-this\n    getFlag = (iso2) => Flags.get(iso2);\n\n    getDialCode() {\n        return PhoneNumber.getDialCode(this.state.value);\n    }\n\n    getValue(text?) {\n        return text ? text.replace(/[^0-9]/g, '') : this.state.value;\n    }\n\n    getNumberType() {\n        return PhoneNumber.getNumberType(\n            this.state.value,\n            this.state.iso2\n        );\n    }\n\n    getISOCode = () => this.state.iso2;\n\n    selectCountry = (iso2) => {\n        if (this.state.iso2 !== iso2) {\n            const countryData = PhoneNumber.getCountryDataByCode(iso2);\n            if (countryData) {\n                this.setState(\n                    {\n                        iso2,\n                        displayValue: this.format(`+${countryData.dialCode}`),\n                        value: `+${countryData.dialCode}`\n                    },\n                    () => {\n                        if (this.props.onSelectCountry) this.props.onSelectCountry(iso2);\n                    }\n                );\n            }\n        }\n    }\n\n    setValue = (number) => {\n        if (this.state.value !== number) {\n            this.updateValue(number);\n        }\n    }\n\n    isValidNumber() {\n        if (this.state.value.length < 4) return false;\n        return PhoneNumber.isValidNumber(\n            this.state.value,\n            this.state.iso2\n        );\n    }\n\n    format(text, iso2?) {\n        return this.props.autoFormat\n            ? PhoneNumber.format(text, iso2 || this.state.iso2)\n            : text;\n    }\n\n    updateValue(number, actionAfterSetState: any = null) {\n        let modifiedNumber = this.getValue(number);\n        const { allowZeroAfterCountryCode } = this.props;\n\n        if (modifiedNumber[0] !== '+' && number.length) {\n            modifiedNumber = `+${modifiedNumber}`;\n        }\n        modifiedNumber = allowZeroAfterCountryCode\n            ? modifiedNumber\n            : this.possiblyEliminateZeroAfterCountryCode(modifiedNumber);\n        const iso2: string = PhoneNumber.getCountryCodeOfNumber(modifiedNumber);\n\n        let countryDialCode;\n        if (iso2) {\n            const countryData = PhoneNumber.getCountryDataByCode(iso2);\n            countryDialCode = countryData.dialCode;\n        }\n\n        let displayValue;\n        if (modifiedNumber === `+${countryDialCode}`) {\n            displayValue = modifiedNumber;\n        } else {\n            displayValue = this.format(modifiedNumber);\n        }\n\n        this.setState({\n            iso2,\n            displayValue,\n            value: modifiedNumber,\n        }, () => {\n            if (actionAfterSetState) {\n                actionAfterSetState(displayValue, iso2);\n            }\n        });\n    }\n\n    // eslint-disable-next-line class-methods-use-this\n    possiblyEliminateZeroAfterCountryCode(number) {\n        const dialCode = PhoneNumber.getDialCode(number);\n        return number.startsWith(`${dialCode}0`)\n            ? dialCode + number.substr(dialCode.length + 1)\n            : number;\n    }\n\n    getAccessibilityLabel() {\n        return this.props.accessibilityLabel || 'Telephone input';\n    }\n\n    focus() {\n        this.inputPhone.focus();\n    }\n\n    blur() {\n        this.inputPhone.blur();\n    }\n\n    render() {\n        const { iso2, displayValue, disabled } = this.state;\n        const country = this.getAllCountries().find((c) => c.iso2 === iso2);\n        const TextComponent: any = this.props.textComponent || TextInput;\n        return (\n            <View style={[styles.container, this.props.style]}>\n                <TouchableOpacity\n                    onPress={this.onPressFlag}\n                    disabled={disabled}\n                    accessibilityRole=\"imagebutton\"\n                    accessibilityLabel={country ? country.name : iso2}\n                >\n                    {this.props.renderFlag ? (\n                        <>\n                            {this.props.renderFlag({\n                                imageSource: Flags.get(iso2),\n                            })}\n                        </>\n                    ) : (\n                        <Image\n                            accessibilityIgnoresInvertColors={true}\n                            source={Flags.get(iso2)}\n                            style={[styles.flag, this.props.flagStyle]}\n                        />\n                    )}\n                </TouchableOpacity>\n                <View style={{ flex: 1, marginLeft: this.props.offset || 10 }}>\n                    <TextComponent\n                        ref={(ref) => {\n                            this.inputPhone = ref;\n                        }}\n                        accessibilityLabel={this.getAccessibilityLabel()}\n                        editable={!disabled}\n                        autoCorrect={false}\n                        style={[styles.text, this.props.textStyle]}\n                        onChangeText={(text) => {\n                            this.onChangePhoneNumber(text);\n                        }}\n                        keyboardType=\"phone-pad\"\n                        underlineColorAndroid=\"rgba(0,0,0,0)\"\n                        value={displayValue}\n                        {...this.props.textProps}\n                    />\n                </View>\n\n                <CountryPicker\n                    ref={(ref) => {\n                        this.picker = ref;\n                    }}\n                    selectedCountry={iso2}\n                    onSubmit={this.selectCountry}\n                    buttonColor={this.props.pickerButtonColor}\n                    cancelText={this.props.cancelText}\n                    cancelTextStyle={this.props.cancelTextStyle}\n                    confirmText={this.props.confirmText}\n                    confirmTextStyle={this.props.confirmTextStyle}\n                    pickerBackgroundColor={this.props.pickerBackgroundColor}\n                    itemStyle={this.props.pickerItemStyle}\n                    onPressCancel={this.props.onPressCancel}\n                    onPressConfirm={this.props.onPressConfirm}\n                />\n            </View>\n        );\n    }\n}\n"]}