VueCountryTelInput is a Vue.js plugin that provides a user-friendly input component for selecting a country and entering a telephone number. It offers built-in validation to ensure the entered phone number is valid for the selected country.
The plugin utilizes the REST Countries API to fetch country data, allowing users to easily select their country from a dropdown list. It also leverages the libphonenumber-js library for phone number parsing and validation, ensuring that the entered phone number adheres to the expected format for the selected country.
With VueCountryTelInput, you can enhance your Vue.js applications with a seamless and intuitive country and telephone number input, all while ensuring the accuracy and validity of the entered phone numbers.
- Country selection: Users can easily select their country from a dropdown list.
- Phone number input: Users can input their telephone number according to the selected country's format.
- Validation: The plugin validates the entered phone number to ensure it is valid for the selected country.
- REST Countries API integration: Country data is fetched from the REST Countries API, providing accurate and up-to-date information.
- libphonenumber-js integration: The plugin leverages the libphonenumber-js library for phone number parsing and validation.
- Customization: The plugin provides various customization options, including themes, sizes, and more.
- it's typescript ready
-
Install the plugin:
npm i @aiabdelbaqy/vue-country-tel-input@latest
-
Add the plugin into your app:
import {createApp} from 'vue' import VueCountryTelInput from '@aiabdelbaqy/vue-country-tel-input' import '@aiabdelbaqy/vue-country-tel-input/styles.css'; const app = createApp(App); app.use(VueCountryTelInput); app.mount('#app');
-
Use the
vue-country-tel-input
component:<template> <VueCountryTelInput /> </template>
npm i @aiabdelbaqy/vue-country-tel-input@latest
Install the plugin into Vue:
import {createApp} from 'vue'
import VueCountryTelInput from '@aiabdelbaqy/vue-country-tel-input'
import '@aiabdelbaqy/vue-country-tel-input/styles.css';
const app = createApp(App);
app.use(VueCountryTelInput);
app.mount('#app');
Or use the component directly:
<template>
<VueCountryTelInput ref="inputRef"/>
<button @click="validatePhone">validate</button>
<button @click="resetPhone">reset</button>
<p>{{phone}}</p>
</template>
<script setup lang="ts">
import {ref} from 'vue';
// important
import {VueCountryTelInput} from '@aiabdelbaqy/vue-country-tel-input'
import '@aiabdelbaqy/vue-country-tel-input/styles.css';
interface ValidatePayload {
valid: boolean;
errors: string[];
model: {
country: string | null;
phone: string | undefined;
dialingNumber: number | null;
};
countryInfo: () => any;
}
const inputRef = ref<any>(null);
const phone = ref<string>('');
const validatePhone = () => {
const data = inputRef.value?.validate<ValidatePayload>();
if (!data.valid) return;
console.log('valid', data);
phone.value = data.model.dialingNumber + data.model.phone;
}
const resetPhone = () => {
inputRef.value?.reset();
}
</script>
View all available options in Props.
Prop | Type | Default Value | Accepted Values |
---|---|---|---|
msg |
String | Any string | |
size |
String | 'medium' | 'small', 'medium', 'large' |
label |
String | phone number | Any string |
showRequired |
Boolean | false | true, false |
showLabel |
Boolean | true | true, false |
themeOverride |
Object | null | ThemeOverride |
selectWidth |
String | '20%' | Any valid CSS width value (e.g., '100px', '50%', etc.) |
validate
type validate = () => {
valid: boolean;
errors: string[];
model: {
country: string | null;
phone: string | undefined;
dialingNumber: number | null;
};
countryInfo: () => any;
};
type reset = () => void;
reset
type reset = () => void;
interface ThemeType {
text: TextType;
height: HeightType;
padding: PaddingType;
border: BorderType;
color: ColorType;
font: FontType;
transitions: TransitionsType;
}
interface TextType {
tiny: string;
sm: string;
md: string;
lg: string;
}
interface HeightType {
tiny: string;
sm: string;
md: string;
lg: string;
}
interface PaddingType {
tiny: string;
sm: string;
md: string;
lg: string;
}
interface BorderType {
base: string;
active: string;
hover: string;
focus: string;
error: string;
radius: string;
}
interface ColorType {
primary: string;
primaryHover: string;
secondary: string;
secondaryHover: string;
menuHover: string;
menuActive: string;
}
interface FontType {
other: string;
en: string;
}
interface TransitionsType {
base: string;
bezier: string;
}
<template>
<VueCountryTelInput :themeOverride="themeOverride"/>
</template>
Clone the project
git clone https://github.com/AliAbdelbaky/vue-country-tel-number
Go to the project directory
cd vue-country-tel-number
Install dependencies
npm install
or
yarn install
Start the server
npm run dev
or
yarn run dev
Copyright (c) 2024 Ali Abdelbaqy. Released under the MIT License.
made with ❤ by Ali Abdelbaqy.