react-native-phone-input
Version:
Phone input box for React Native
105 lines • 14.8 kB
JavaScript
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const react_1 = __importStar(require("react")); // eslint-disable-line import/no-extraneous-dependencies, no-use-before-define
const react_native_1 = require("react-native");
const picker_1 = require("@react-native-picker/picker");
const country_1 = __importDefault(require("./country"));
const styles_1 = __importDefault(require("./styles"));
const PickerItem = picker_1.Picker.Item;
class CountryPicker extends react_1.Component {
constructor(props) {
super(props);
this.onPressCancel = () => {
if (this.props.onPressCancel) {
this.props.onPressCancel();
}
this.setState({
modalVisible: false,
});
};
this.onPressSubmit = () => {
if (this.props.onPressConfirm) {
this.props.onPressConfirm();
}
if (this.props.onSubmit) {
this.props.onSubmit(this.state.selectedCountry);
}
this.setState({
modalVisible: false,
});
};
this.onValueChange = (selectedCountry) => {
this.setState({
selectedCountry,
});
};
this.state = {
buttonColor: this.props.buttonColor || '#007AFF',
modalVisible: false,
selectedCountry: this.props.selectedCountry || country_1.default.getAll()[0],
};
}
selectCountry(selectedCountry) {
this.setState({
selectedCountry,
});
}
show() {
this.setState({
modalVisible: true,
});
}
// eslint-disable-next-line class-methods-use-this
renderItem(country, index) {
return react_1.default.createElement(PickerItem, { key: country.iso2, value: country.iso2, label: country.name });
}
render() {
const { buttonColor } = this.state;
const itemStyle = this.props.itemStyle || {};
return (react_1.default.createElement(react_native_1.Modal, { animationType: "slide", transparent: true, visible: this.state.modalVisible, onRequestClose: () => {
console.log('Country picker has been closed.');
} },
react_1.default.createElement(react_native_1.View, { style: styles_1.default.basicContainer },
react_1.default.createElement(react_native_1.View, { style: [
styles_1.default.modalContainer,
{ backgroundColor: this.props.pickerBackgroundColor || 'white' },
] },
react_1.default.createElement(react_native_1.View, { style: styles_1.default.buttonView },
react_1.default.createElement(react_native_1.TouchableOpacity, { onPress: this.onPressCancel },
react_1.default.createElement(react_native_1.Text, { style: [{ color: buttonColor }, this.props.cancelTextStyle] }, this.props.cancelText || 'Cancel')),
react_1.default.createElement(react_native_1.TouchableOpacity, { onPress: this.onPressSubmit },
react_1.default.createElement(react_native_1.Text, { style: [{ color: buttonColor }, this.props.confirmTextStyle] }, this.props.confirmText || 'Confirm'))),
react_1.default.createElement(react_native_1.View, { style: styles_1.default.mainBox },
react_1.default.createElement(picker_1.Picker, { ref: (ref) => {
this.picker = ref;
}, style: styles_1.default.bottomPicker, selectedValue: this.state.selectedCountry, onValueChange: (country) => this.onValueChange(country), itemStyle: itemStyle, mode: "dialog" }, country_1.default.getAll().map((country, index) => this.renderItem(country, index))))))));
}
}
exports.default = CountryPicker;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CountryPicker.js","sourceRoot":"","sources":["../src/CountryPicker.tsx"],"names":[],"mappings":"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","sourcesContent":["import React, { Component } from 'react'; // eslint-disable-line import/no-extraneous-dependencies, no-use-before-define\nimport {\n    Text, TouchableOpacity, View, Modal,\n} from 'react-native';\nimport { Picker } from '@react-native-picker/picker';\n\nimport Country from './country';\nimport styles from './styles';\nimport { ReactNativeCountryPickerProps, ReactNativeCountryPickerState } from './typings';\n\nconst PickerItem = Picker.Item;\n\nexport default class CountryPicker extends Component<ReactNativeCountryPickerProps, ReactNativeCountryPickerState> {\n    private picker: any;\n\n    constructor(props) {\n        super(props);\n\n        this.state = {\n            buttonColor: this.props.buttonColor || '#007AFF',\n            modalVisible: false,\n            selectedCountry: this.props.selectedCountry || Country.getAll()[0],\n        };\n    }\n\n    selectCountry(selectedCountry) {\n        this.setState({\n            selectedCountry,\n        });\n    }\n\n    onPressCancel = () => {\n        if (this.props.onPressCancel) {\n            this.props.onPressCancel();\n        }\n\n        this.setState({\n            modalVisible: false,\n        });\n    }\n\n    onPressSubmit = () => {\n        if (this.props.onPressConfirm) {\n            this.props.onPressConfirm();\n        }\n\n        if (this.props.onSubmit) {\n            this.props.onSubmit(this.state.selectedCountry);\n        }\n\n        this.setState({\n            modalVisible: false,\n        });\n    }\n\n    onValueChange = (selectedCountry) => {\n        this.setState({\n            selectedCountry,\n        });\n    }\n\n    show() {\n        this.setState({\n            modalVisible: true,\n        });\n    }\n\n    // eslint-disable-next-line class-methods-use-this\n    renderItem(country, index) {\n        return <PickerItem key={country.iso2} value={country.iso2} label={country.name} />;\n    }\n\n    render() {\n        const { buttonColor } = this.state;\n        const itemStyle = this.props.itemStyle || {};\n        return (\n            <Modal\n                animationType=\"slide\"\n                transparent\n                visible={this.state.modalVisible}\n                onRequestClose={() => {\n                    console.log('Country picker has been closed.');\n                }}\n            >\n                <View style={styles.basicContainer}>\n                    <View\n                        style={[\n                            styles.modalContainer,\n                            { backgroundColor: this.props.pickerBackgroundColor || 'white' },\n                        ]}\n                    >\n                        <View style={styles.buttonView}>\n                            <TouchableOpacity onPress={this.onPressCancel}>\n                                <Text style={[{ color: buttonColor }, this.props.cancelTextStyle]}>\n                                    {this.props.cancelText || 'Cancel'}\n                                </Text>\n                            </TouchableOpacity>\n\n                            <TouchableOpacity onPress={this.onPressSubmit}>\n                                <Text style={[{ color: buttonColor }, this.props.confirmTextStyle]}>\n                                    {this.props.confirmText || 'Confirm'}\n                                </Text>\n                            </TouchableOpacity>\n                        </View>\n\n                        <View style={styles.mainBox}>\n                            <Picker\n                                ref={(ref) => {\n                                    this.picker = ref;\n                                }}\n                                style={styles.bottomPicker}\n                                selectedValue={this.state.selectedCountry}\n                                onValueChange={(country) => this.onValueChange(country)}\n                                itemStyle={itemStyle}\n                                mode=\"dialog\"\n                            >\n                                {Country.getAll().map((country, index) => this.renderItem(country, index))}\n                            </Picker>\n                        </View>\n                    </View>\n                </View>\n            </Modal>\n        );\n    }\n}\n"]}