Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
antd-phone-input
Advanced tools
Advanced phone input component for Ant Design that provides support for all
countries and is compatible with antd
3 and higher versions. It has
built-in support for area codes and provides validation to ensure that the entered numbers are valid. This open-source
project is designed to simplify the process of collecting phone numbers from users.
npm i antd-phone-input
yarn add antd-phone-input
As mentioned above, this component is compatible with 3.x
, 4.x
, and after
the v0.1.4 release, 5.x
versions of Ant
Design. The latest one does not require any additional actions for loading the styles as it
uses cssinjs
ecosystem.
import React from "react";
import FormItem from "antd/es/form/FormItem";
import PhoneInput from "antd-phone-input";
const Demo = () => {
return (
<FormItem name="phone">
<PhoneInput enableSearch/>
</FormItem>
)
}
For 4.x
and older versions, you should use the legacy
endpoint.
import PhoneInput from "antd-phone-input/legacy";
For including the styles, you should import them in the main less
file after importing either
the antd/dist/antd.less
or antd/dist/antd.dark.less
styles.
@import "~antd/dist/antd";
+ @import "~antd-phone-input/legacy/style";
The value of the component is an object containing the parts of a phone number. This format of value gives a wide range of opportunities for handling the data in your custom way. For example, you can easily merge the parts of the phone number into a single string.
{
"countryCode": 1,
"areaCode": 702,
"phoneNumber": "1234567",
"isoCode": "us",
"valid": true
}
The valid
property of the value object shows the real-time validity of the phone number depending on the country. So
this can be used in a validator
like this:
const validator = (_, {valid}) => {
if (valid) {
return Promise.resolve();
}
return Promise.reject("Invalid phone number");
}
return (
<FormItem rules={[{validator}]}>
<PhoneInput/>
</FormItem>
)
Property | Description | Type |
---|---|---|
size | Either large , middle or small . Default value is middle . See at ant docs for more. | string |
value | An object containing the parts of phone number. E.g. value={{countryCode: 1, areaCode: 702, phoneNumber: "1234567"}} . | object |
style | Applies CSS styles to the container element. | CSSProperties |
className | The value will be assigned to the container element. | string |
disabled | Disables the whole input component. | boolean |
enableSearch | Enables search in the country selection dropdown menu. Default value is false . | boolean |
disableDropdown | Disables the manual country selection through the dropdown menu. | boolean |
inputProps | HTML properties of input to pass into the input. E.g. inputProps={{autoFocus: true}} . | InputHTMLAttributes |
searchPlaceholder | The value is shown if enableSearch is true . Default value is search . | string |
searchNotFound | The value is shown if enableSearch is true and the query does not match any country. Default value is No entries to show . | string |
placeholder | Custom placeholder. Default placeholder is 1 (702) 123-4567 . | string |
country | Country code to be selected by default. By default, it will show the flag of the user's country. | string |
regions | Show only the countries of the specified regions. See the list of available regions. | string[] |
onlyCountries | Country codes to be included in the list. E.g. onlyCountries={['us', 'ca', 'uk']} . | string[] |
excludeCountries | Country codes to be excluded from the list of countries. E.g. excludeCountries={['us', 'ca', 'uk']} . | string[] |
preferredCountries | Country codes to be at the top of the list. E.g. preferredCountries={['us', 'ca', 'uk']} . | string[] |
onChange | Callback when the user is inputting. See at ant docs for more. | function(value, e) |
onPressEnter | The callback function that is triggered when Enter key is pressed. | function(e) |
onFocus | The callback is triggered when the input element is focused. | function(e, value) |
onClick | The callback is triggered when the user clicks on the input element. | function(e, value) |
onBlur | The callback is triggered when the input element gets blurred or unfocused. | function(e, value) |
onKeyDown | The callback is triggered when any key is pressed down. | function(e) |
onMount | The callback is triggered once the component gets mounted. | function(e) |
Any contribution is welcome. If you have any ideas or suggestions, feel free to open an issue or a pull request. And don't forget to add tests for your changes.
Copyright (C) 2023 Artyom Vancyan. MIT
FAQs
Advanced, highly customizable phone input component for Ant Design.
We found that antd-phone-input demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.