Security News
Research
Data Theft Repackaged: A Case Study in Malicious Wrapper Packages on npm
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
ngx-mat-input-tel
Advanced tools
An Angular Material package for entering and validating international telephone numbers. It adds a flag dropdown to any input, detects the user's country, displays a relevant placeholder and provides formatting/validation methods.
An Angular Material package for entering and validating international telephone numbers. It adds a flag dropdown to any input, detects the user's country, displays a relevant placeholder and provides formatting/validation methods.
This is a fork from the ngx-mat-intl-tel-input library whish does not seems to be maintained anymore. Last commit is over a year
Supports:
$ npm i ngx-mat-input-tel@latest
$ npm i libphonenumber-js@latest
Add NgxMatInputTelComponent
to your component file:
imports: [NgxMatInputTelComponent];
Refer to main app in this repository for working example.
<form #f="ngForm" [formGroup]="phoneForm">
<ngx-mat-input-tel
[preferredCountries]="['us', 'gb']"
[enablePlaceholder]="true"
[enableSearch]="true"
name="phone"
describedBy="phoneInput"
formControlName="phone"
></ngx-mat-input-tel>
</form>
<form #f="ngForm" [formGroup]="phoneForm">
<ngx-mat-input-tel
[preferredCountries]="['us', 'gb']"
[enablePlaceholder]="true"
[enableSearch]="true"
name="phone"
autocomplete="tel"
(countryChanged)="yourComponentMethodToTreatyCountryChangedEvent($event)" // $event is a instance of current select Country
formControlName="phone"></ngx-mat-input-tel>
</form>
If you want to show the sample number for the country selected or errors , use mat-hint anf mat-error as
<form #f="ngForm" [formGroup]="phoneForm">
<ngx-mat-input-tel
[preferredCountries]="['us', 'gb']"
[onlyCountries]="['us', 'gb', 'es']"
[enablePlaceholder]="true"
name="phone"
autocomplete="tel"
formControlName="phone"
#phone
></ngx-mat-input-tel>
<mat-hint>e.g. {{phone.selectedCountry.placeHolder}}</mat-hint>
<mat-error *ngIf="f.form.controls['phone']?.errors?.required"
>Required Field</mat-error
>
<mat-error *ngIf="f.form.controls['phone']?.errors?.validatePhoneNumber"
>Invalid Number</mat-error
>
</form>
Options | Type | Default | Description |
---|---|---|---|
enablePlaceholder | boolean | false | Input placeholder text, which adapts to the country selected. |
enableSearch | boolean | false | Whether to display a search bar to help filter down the list of countries |
format | string | default | Format of "as you type" input. Possible values: national, international, default |
placeholder | string | undefined | Placeholder for the input component. |
maxLength | number | 15 | max length of the input. |
onlyCountries | string[] | [] | List of manually selected country abbreviations, which will appear in the dropdown. |
preferredCountries | string[] | [] | List of country abbreviations, which will appear at the top. |
resetOnChange | boolean | false | Reset input on country change |
searchPlaceholder | string | Search ... | Placeholder for the search input |
Options | Type | Default | Description |
---|---|---|---|
countryChanged | EventEmitter<Country> | undefined | On country change |
Name | Default | Explanation |
---|---|---|
--ngxMatInputTel-opacity | 0 | If you wish the country flag to be shown by default |
--ngxMatInputTel-flag-display | inline-block | If you wish to hide the country flag |
./projects/ngx-mat-input-tel
./src/lib
with new functionality.$ npm run build_lib
$ npm run copy-files
$ npm run npm_pack
$ npm run package
After building and creating package, you can use it locally too.
In your project run:
$ npm install --save {{path to your local '*.tgz' package file}}
FAQs
An Angular Material package for entering and validating international telephone numbers. It adds a flag dropdown to any input, detects the user's country, displays a relevant placeholder and provides formatting/validation methods.
We found that ngx-mat-input-tel 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
Research
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
Research
Security News
Attackers used a malicious npm package typosquatting a popular ESLint plugin to steal sensitive data, execute commands, and exploit developer systems.
Security News
The Ultralytics' PyPI Package was compromised four times in one weekend through GitHub Actions cache poisoning and failure to rotate previously compromised API tokens.