17.3.0 • Published 22 days ago

ngx-mat-input-tel v17.3.0

Weekly downloads
-
License
MIT
Repository
github
Last release
22 days ago

International Telephone Input for Angular Material (ngxMatInputTel)

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.

npm version NPM npm bundle size npm

Demo

Caution

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:

  • Angular >=15
  • Angular Material >=15
  • ReactiveFormsModule
  • FormsModule
  • Validation with libphonenumber-js

Installation

Install This Library

$ npm i ngx-mat-input-tel@latest

Install Dependencies Optional

$ npm i libphonenumber-js@latest

Usage

Import

Add NgxMatInputTelComponent to your component file:

imports: [NgxMatInputTelComponent];

Example

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

OptionsTypeDefaultDescription
enablePlaceholderbooleantrueInput placeholder text, which adapts to the country selected.
enableSearchbooleanfalseWhether to display a search bar to help filter down the list of countries
formatstringdefaultFormat of "as you type" input. Possible values: national, international, default
inputPlaceholderstringundefinedPlaceholder for the input component.
onlyCountriesstring[][]List of manually selected country abbreviations, which will appear in the dropdown.
preferredCountriesstring[][]List of country abbreviations, which will appear at the top.
resetOnChangebooleanfalseReset input on country change
searchPlaceholderstringSearch ...Placeholder for the search input

Css variable

NameDefaultExplanation
--ngxMatInputTel-color#000If you wish to change the overall color
--ngxMatInputTel-opacity0If you wish the country flag to be shown by default
--ngxMatInputTel-flag-displayinline-blockIf you wish to hide the country flag

Library Contributions

  • Fork repo.
  • Go to ./projects/ngx-mat-input-tel
  • Update ./src/lib with new functionality.
  • Update README.md
  • Pull request.

Helpful commands

  • Build lib: $ npm run build_lib
  • Copy license and readme files: $ npm run copy-files
  • Create package: $ npm run npm_pack
  • Build lib and create package: $ npm run package

Use locally

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}}

Acknowledgments

This repo is a fork from the ngx-mat-intl-tel-input library.

17.3.0

22 days ago

17.2.1

25 days ago

17.2.0

3 months ago

17.1.8

3 months ago

17.1.7

3 months ago

17.1.6

3 months ago

17.1.5

4 months ago

17.1.2

4 months ago

17.1.1

4 months ago

17.1.4

4 months ago

17.1.3

4 months ago

17.1.0

4 months ago

16.1.9

7 months ago

16.1.8

7 months ago

16.1.7

7 months ago

17.0.0

6 months ago

16.2.0

7 months ago

16.2.1

7 months ago

16.1.6

10 months ago

16.1.5

10 months ago

16.1.4

10 months ago

16.1.3

10 months ago

16.1.2

10 months ago

16.1.1

10 months ago

16.1.0

10 months ago