├── projects
├── demo
│ ├── src
│ │ ├── assets
│ │ │ └── .gitkeep
│ │ ├── app
│ │ │ ├── app.component.scss
│ │ │ ├── app.module.ts
│ │ │ ├── app.component.spec.ts
│ │ │ └── app.component.ts
│ │ ├── environments
│ │ │ ├── environment.prod.ts
│ │ │ └── environment.ts
│ │ ├── favicon.ico
│ │ ├── main.ts
│ │ ├── styles.scss
│ │ ├── index.html
│ │ ├── test.ts
│ │ └── polyfills.ts
│ ├── tsconfig.app.json
│ ├── tsconfig.spec.json
│ ├── .browserslistrc
│ └── karma.conf.js
└── lib
│ ├── src
│ ├── lib
│ │ ├── interface
│ │ │ ├── country.interface.ts
│ │ │ ├── country-locale.interface.ts
│ │ │ └── country-code.interface.ts
│ │ ├── pipe
│ │ │ └── country.pipe.ts
│ │ ├── module.ts
│ │ ├── component
│ │ │ └── int-phone-prefix
│ │ │ │ ├── int-phone-prefix.component.html
│ │ │ │ ├── int-phone-prefix.component.ts
│ │ │ │ └── int-phone-prefix.component.scss
│ │ ├── directive
│ │ │ └── only-number.directive.ts
│ │ └── service
│ │ │ ├── locale.service.ts
│ │ │ └── country.service.ts
│ ├── public-api.ts
│ └── test.ts
│ ├── ng-package.json
│ ├── tsconfig.lib.prod.json
│ ├── tsconfig.spec.json
│ ├── tsconfig.lib.json
│ ├── .browserslistrc
│ ├── package.json
│ ├── karma.conf.js
│ └── README.md
├── .vscode
├── extensions.json
├── launch.json
└── tasks.json
├── .editorconfig
├── .gitignore
├── tsconfig.json
├── package.json
├── README.md
└── angular.json
/projects/demo/src/assets/.gitkeep:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/projects/demo/src/app/app.component.scss:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/projects/demo/src/environments/environment.prod.ts:
--------------------------------------------------------------------------------
1 | export const environment = {
2 | production: true
3 | };
4 |
--------------------------------------------------------------------------------
/projects/demo/src/favicon.ico:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/kondi0/ng4-intl-phone/HEAD/projects/demo/src/favicon.ico
--------------------------------------------------------------------------------
/projects/lib/src/lib/interface/country.interface.ts:
--------------------------------------------------------------------------------
1 | export interface Country {
2 | name: string,
3 | dialCode: string
4 | countryCode: string,
5 | }
6 |
--------------------------------------------------------------------------------
/.vscode/extensions.json:
--------------------------------------------------------------------------------
1 | {
2 | // For more information, visit: https://go.microsoft.com/fwlink/?linkid=827846
3 | "recommendations": ["angular.ng-template"]
4 | }
5 |
--------------------------------------------------------------------------------
/projects/lib/src/lib/interface/country-locale.interface.ts:
--------------------------------------------------------------------------------
1 | import {CountryCode} from "./country-code.interface";
2 | export class CountryLocale {
3 | [lang: string]: CountryCode
4 | }
5 |
--------------------------------------------------------------------------------
/projects/lib/src/public-api.ts:
--------------------------------------------------------------------------------
1 | /*
2 | * Public API Surface of lib
3 | */
4 |
5 | export * from './lib/component/int-phone-prefix/int-phone-prefix.component';
6 | export * from './lib/module';
7 |
--------------------------------------------------------------------------------
/projects/lib/ng-package.json:
--------------------------------------------------------------------------------
1 | {
2 | "$schema": "../../node_modules/ng-packagr/ng-package.schema.json",
3 | "dest": "../../dist/lib",
4 | "lib": {
5 | "entryFile": "src/public-api.ts"
6 | }
7 | }
--------------------------------------------------------------------------------
/projects/lib/tsconfig.lib.prod.json:
--------------------------------------------------------------------------------
1 | /* To learn more about this file see: https://angular.io/config/tsconfig. */
2 | {
3 | "extends": "./tsconfig.lib.json",
4 | "compilerOptions": {
5 | "declarationMap": false
6 | },
7 | "angularCompilerOptions": {
8 | "compilationMode": "partial"
9 | }
10 | }
11 |
--------------------------------------------------------------------------------
/.editorconfig:
--------------------------------------------------------------------------------
1 | # Editor configuration, see https://editorconfig.org
2 | root = true
3 |
4 | [*]
5 | charset = utf-8
6 | indent_style = space
7 | indent_size = 2
8 | insert_final_newline = true
9 | trim_trailing_whitespace = true
10 |
11 | [*.ts]
12 | quote_type = single
13 |
14 | [*.md]
15 | max_line_length = off
16 | trim_trailing_whitespace = false
17 |
--------------------------------------------------------------------------------
/projects/demo/tsconfig.app.json:
--------------------------------------------------------------------------------
1 | /* To learn more about this file see: https://angular.io/config/tsconfig. */
2 | {
3 | "extends": "../../tsconfig.json",
4 | "compilerOptions": {
5 | "outDir": "../../out-tsc/app",
6 | "types": []
7 | },
8 | "files": [
9 | "src/main.ts",
10 | "src/polyfills.ts"
11 | ],
12 | "include": [
13 | "src/**/*.d.ts"
14 | ]
15 | }
16 |
--------------------------------------------------------------------------------
/projects/lib/tsconfig.spec.json:
--------------------------------------------------------------------------------
1 | /* To learn more about this file see: https://angular.io/config/tsconfig. */
2 | {
3 | "extends": "../../tsconfig.json",
4 | "compilerOptions": {
5 | "outDir": "../../out-tsc/spec",
6 | "types": [
7 | "jasmine"
8 | ]
9 | },
10 | "files": [
11 | "src/test.ts"
12 | ],
13 | "include": [
14 | "**/*.spec.ts",
15 | "**/*.d.ts"
16 | ]
17 | }
18 |
--------------------------------------------------------------------------------
/projects/lib/tsconfig.lib.json:
--------------------------------------------------------------------------------
1 | /* To learn more about this file see: https://angular.io/config/tsconfig. */
2 | {
3 | "extends": "../../tsconfig.json",
4 | "compilerOptions": {
5 | "outDir": "../../out-tsc/lib",
6 | "declaration": true,
7 | "declarationMap": true,
8 | "inlineSources": true,
9 | "types": []
10 | },
11 | "exclude": [
12 | "src/test.ts",
13 | "**/*.spec.ts"
14 | ]
15 | }
16 |
--------------------------------------------------------------------------------
/projects/demo/src/main.ts:
--------------------------------------------------------------------------------
1 | import { enableProdMode } from '@angular/core';
2 | import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
3 |
4 | import { AppModule } from './app/app.module';
5 | import { environment } from './environments/environment';
6 |
7 | if (environment.production) {
8 | enableProdMode();
9 | }
10 |
11 | platformBrowserDynamic().bootstrapModule(AppModule)
12 | .catch(err => console.error(err));
13 |
--------------------------------------------------------------------------------
/projects/demo/tsconfig.spec.json:
--------------------------------------------------------------------------------
1 | /* To learn more about this file see: https://angular.io/config/tsconfig. */
2 | {
3 | "extends": "../../tsconfig.json",
4 | "compilerOptions": {
5 | "outDir": "../../out-tsc/spec",
6 | "types": [
7 | "jasmine"
8 | ]
9 | },
10 | "files": [
11 | "src/test.ts",
12 | "src/polyfills.ts"
13 | ],
14 | "include": [
15 | "src/**/*.spec.ts",
16 | "src/**/*.d.ts"
17 | ]
18 | }
19 |
--------------------------------------------------------------------------------
/projects/demo/src/styles.scss:
--------------------------------------------------------------------------------
1 | /* You can add global styles to this file, and also import other style files */
2 | h1 {
3 | color: #369;
4 | font-family: Arial, Helvetica, sans-serif;
5 | font-size: 250%;
6 | }
7 |
8 | .mc {
9 | padding: 100px;
10 | }
11 |
12 | .mt {
13 | margin-top: 10px;
14 | }
15 |
16 | .card {
17 | box-shadow: 0 4px 8px 0 rgba(0,0,0,0.2);
18 | transition: 0.3s;
19 | border-radius: 5px;
20 | padding: 20px;
21 | }
22 |
--------------------------------------------------------------------------------
/projects/demo/src/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | Demo
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
--------------------------------------------------------------------------------
/projects/lib/src/lib/pipe/country.pipe.ts:
--------------------------------------------------------------------------------
1 | import { Pipe, PipeTransform } from '@angular/core';
2 | import {Country} from "../interface/country.interface";
3 |
4 | @Pipe({
5 | name: 'country'
6 | })
7 | export class CountryPipe implements PipeTransform {
8 |
9 | transform(value: Country[], args?: string): any {
10 | let searchText = new RegExp(args, 'ig');
11 |
12 | if (value) {
13 | return value.filter((country: Country) => country.name.search(searchText) !== -1);
14 | }
15 | }
16 |
17 | }
18 |
--------------------------------------------------------------------------------
/.vscode/launch.json:
--------------------------------------------------------------------------------
1 | {
2 | // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
3 | "version": "0.2.0",
4 | "configurations": [
5 | {
6 | "name": "ng serve",
7 | "type": "pwa-chrome",
8 | "request": "launch",
9 | "preLaunchTask": "npm: start",
10 | "url": "http://localhost:4200/"
11 | },
12 | {
13 | "name": "ng test",
14 | "type": "chrome",
15 | "request": "launch",
16 | "preLaunchTask": "npm: test",
17 | "url": "http://localhost:9876/debug.html"
18 | }
19 | ]
20 | }
21 |
--------------------------------------------------------------------------------
/projects/demo/src/app/app.module.ts:
--------------------------------------------------------------------------------
1 | import { NgModule } from '@angular/core';
2 | import { BrowserModule } from '@angular/platform-browser';
3 |
4 | import { AppComponent } from './app.component';
5 | import {InternationalPhoneModule} from '../../../lib/src/lib/module';
6 | import {FormsModule, ReactiveFormsModule} from '@angular/forms';
7 |
8 | @NgModule({
9 | declarations: [
10 | AppComponent
11 | ],
12 | imports: [
13 | BrowserModule,
14 | InternationalPhoneModule,
15 | FormsModule,
16 | ReactiveFormsModule
17 | ],
18 | providers: [],
19 | bootstrap: [AppComponent]
20 | })
21 | export class AppModule { }
22 |
--------------------------------------------------------------------------------
/projects/demo/.browserslistrc:
--------------------------------------------------------------------------------
1 | # This file is used by the build system to adjust CSS and JS output to support the specified browsers below.
2 | # For additional information regarding the format and rule options, please see:
3 | # https://github.com/browserslist/browserslist#queries
4 |
5 | # For the full list of supported browsers by the Angular framework, please see:
6 | # https://angular.io/guide/browser-support
7 |
8 | # You can see what browsers were selected by your queries by running:
9 | # npx browserslist
10 |
11 | last 1 Chrome version
12 | last 1 Firefox version
13 | last 2 Edge major versions
14 | last 2 Safari major versions
15 | last 2 iOS major versions
16 | Firefox ESR
17 |
--------------------------------------------------------------------------------
/projects/lib/.browserslistrc:
--------------------------------------------------------------------------------
1 | # This file is used by the build system to adjust CSS and JS output to support the specified browsers below.
2 | # For additional information regarding the format and rule options, please see:
3 | # https://github.com/browserslist/browserslist#queries
4 |
5 | # For the full list of supported browsers by the Angular framework, please see:
6 | # https://angular.io/guide/browser-support
7 |
8 | # You can see what browsers were selected by your queries by running:
9 | # npx browserslist
10 |
11 | last 1 Chrome version
12 | last 1 Firefox version
13 | last 2 Edge major versions
14 | last 2 Safari major versions
15 | last 2 iOS major versions
16 | Firefox ESR
17 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | # See http://help.github.com/ignore-files/ for more about ignoring files.
2 |
3 | # Compiled output
4 | /dist
5 | /tmp
6 | /out-tsc
7 | /bazel-out
8 |
9 | # Node
10 | /node_modules
11 | npm-debug.log
12 | yarn-error.log
13 |
14 | # IDEs and editors
15 | .idea/
16 | .project
17 | .classpath
18 | .c9/
19 | *.launch
20 | .settings/
21 | *.sublime-workspace
22 |
23 | # Visual Studio Code
24 | .vscode/*
25 | !.vscode/settings.json
26 | !.vscode/tasks.json
27 | !.vscode/launch.json
28 | !.vscode/extensions.json
29 | .history/*
30 |
31 | # Miscellaneous
32 | /.angular/cache
33 | .sass-cache/
34 | /connect.lock
35 | /coverage
36 | /libpeerconnection.log
37 | testem.log
38 | /typings
39 |
40 | # System files
41 | .DS_Store
42 | Thumbs.db
43 |
--------------------------------------------------------------------------------
/projects/demo/src/environments/environment.ts:
--------------------------------------------------------------------------------
1 | // This file can be replaced during build by using the `fileReplacements` array.
2 | // `ng build` replaces `environment.ts` with `environment.prod.ts`.
3 | // The list of file replacements can be found in `angular.json`.
4 |
5 | export const environment = {
6 | production: false
7 | };
8 |
9 | /*
10 | * For easier debugging in development mode, you can import the following file
11 | * to ignore zone related error stack frames such as `zone.run`, `zoneDelegate.invokeTask`.
12 | *
13 | * This import should be commented out in production mode because it will have a negative impact
14 | * on performance if an error is thrown.
15 | */
16 | // import 'zone.js/plugins/zone-error'; // Included with Angular CLI.
17 |
--------------------------------------------------------------------------------
/projects/lib/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "ng4-intl-phone",
3 | "version": "14.0.1",
4 | "description": "International phone prefix library for Angular",
5 | "repository": {
6 | "type": "git",
7 | "url": "https://github.com/kondi0/ng4-intl-phone.git"
8 | },
9 | "author": "kondi0",
10 | "license": "MIT",
11 | "peerDependencies": {
12 | "@angular/animations": "~14.2.4",
13 | "@angular/common": "~14.2.4",
14 | "@angular/compiler": "~14.2.4",
15 | "@angular/core": "~14.2.4",
16 | "@angular/forms": "~14.2.4",
17 | "@angular/platform-browser": "~14.2.4",
18 | "@angular/platform-browser-dynamic": "~14.2.4",
19 | "@angular/router": "~14.2.4",
20 | "rxjs": "~7.5.0",
21 | "tslib": "^2.3.0",
22 | "zone.js": "~0.11.4"
23 | },
24 | "dependencies": {
25 | "tslib": "^2.3.0"
26 | }
27 | }
28 |
--------------------------------------------------------------------------------
/projects/demo/src/test.ts:
--------------------------------------------------------------------------------
1 | // This file is required by karma.conf.js and loads recursively all the .spec and framework files
2 |
3 | import 'zone.js/testing';
4 | import { getTestBed } from '@angular/core/testing';
5 | import {
6 | BrowserDynamicTestingModule,
7 | platformBrowserDynamicTesting
8 | } from '@angular/platform-browser-dynamic/testing';
9 |
10 | declare const require: {
11 | context(path: string, deep?: boolean, filter?: RegExp): {
12 | (id: string): T;
13 | keys(): string[];
14 | };
15 | };
16 |
17 | // First, initialize the Angular testing environment.
18 | getTestBed().initTestEnvironment(
19 | BrowserDynamicTestingModule,
20 | platformBrowserDynamicTesting(),
21 | );
22 |
23 | // Then we find all the tests.
24 | const context = require.context('./', true, /\.spec\.ts$/);
25 | // And load the modules.
26 | context.keys().map(context);
27 |
--------------------------------------------------------------------------------
/projects/lib/src/test.ts:
--------------------------------------------------------------------------------
1 | // This file is required by karma.conf.js and loads recursively all the .spec and framework files
2 |
3 | import 'zone.js';
4 | import 'zone.js/testing';
5 | import { getTestBed } from '@angular/core/testing';
6 | import {
7 | BrowserDynamicTestingModule,
8 | platformBrowserDynamicTesting
9 | } from '@angular/platform-browser-dynamic/testing';
10 |
11 | declare const require: {
12 | context(path: string, deep?: boolean, filter?: RegExp): {
13 | (id: string): T;
14 | keys(): string[];
15 | };
16 | };
17 |
18 | // First, initialize the Angular testing environment.
19 | getTestBed().initTestEnvironment(
20 | BrowserDynamicTestingModule,
21 | platformBrowserDynamicTesting(),
22 | );
23 |
24 | // Then we find all the tests.
25 | const context = require.context('./', true, /\.spec\.ts$/);
26 | // And load the modules.
27 | context.keys().map(context);
28 |
--------------------------------------------------------------------------------
/tsconfig.json:
--------------------------------------------------------------------------------
1 | /* To learn more about this file see: https://angular.io/config/tsconfig. */
2 | {
3 | "compileOnSave": false,
4 | "compilerOptions": {
5 | "baseUrl": "./",
6 | "outDir": "./dist/out-tsc",
7 | "forceConsistentCasingInFileNames": true,
8 | "strict": false,
9 | "noImplicitOverride": true,
10 | "noPropertyAccessFromIndexSignature": true,
11 | "paths": {
12 | "ng4-intl-phone": [
13 | "dist/lib/lib",
14 | "dist/lib"
15 | ]
16 | },
17 | "noImplicitReturns": true,
18 | "noFallthroughCasesInSwitch": true,
19 | "sourceMap": true,
20 | "declaration": false,
21 | "downlevelIteration": true,
22 | "experimentalDecorators": true,
23 | "moduleResolution": "node",
24 | "importHelpers": true,
25 | "target": "es2017",
26 | "module": "es2020",
27 | "lib": [
28 | "es2020",
29 | "dom"
30 | ]
31 | },
32 | }
33 |
--------------------------------------------------------------------------------
/projects/lib/src/lib/module.ts:
--------------------------------------------------------------------------------
1 | import { NgModule } from '@angular/core';
2 | import { CommonModule } from '@angular/common';
3 | import {FormsModule, ReactiveFormsModule} from '@angular/forms';
4 | import {IntPhonePrefixComponent} from "./component/int-phone-prefix/int-phone-prefix.component";
5 | import {OnlyNumberDirective} from "./directive/only-number.directive";
6 | import {CountryPipe} from "./pipe/country.pipe";
7 | import {CountryService} from "./service/country.service";
8 | import {LocaleService} from "./service/locale.service";
9 |
10 |
11 |
12 | @NgModule({
13 | imports: [
14 | CommonModule,
15 | FormsModule,
16 | ReactiveFormsModule
17 | ],
18 | declarations: [
19 | IntPhonePrefixComponent,
20 | OnlyNumberDirective,
21 | CountryPipe
22 | ],
23 | exports: [
24 | IntPhonePrefixComponent
25 | ],
26 | providers: [CountryService, LocaleService]
27 | })
28 | export class InternationalPhoneModule {}
29 |
--------------------------------------------------------------------------------
/projects/demo/src/app/app.component.spec.ts:
--------------------------------------------------------------------------------
1 | import { TestBed } from '@angular/core/testing';
2 | import { AppComponent } from './app.component';
3 |
4 | describe('AppComponent', () => {
5 | beforeEach(async () => {
6 | await TestBed.configureTestingModule({
7 | declarations: [
8 | AppComponent
9 | ],
10 | }).compileComponents();
11 | });
12 |
13 | it('should create the app', () => {
14 | const fixture = TestBed.createComponent(AppComponent);
15 | const app = fixture.componentInstance;
16 | expect(app).toBeTruthy();
17 | });
18 |
19 | it(`should have as title 'demo'`, () => {
20 | const fixture = TestBed.createComponent(AppComponent);
21 | const app = fixture.componentInstance;
22 | expect(app.title).toEqual('demo');
23 | });
24 |
25 | it('should render title', () => {
26 | const fixture = TestBed.createComponent(AppComponent);
27 | fixture.detectChanges();
28 | const compiled = fixture.nativeElement as HTMLElement;
29 | expect(compiled.querySelector('.content span')?.textContent).toContain('demo app is running!');
30 | });
31 | });
32 |
--------------------------------------------------------------------------------
/.vscode/tasks.json:
--------------------------------------------------------------------------------
1 | {
2 | // For more information, visit: https://go.microsoft.com/fwlink/?LinkId=733558
3 | "version": "2.0.0",
4 | "tasks": [
5 | {
6 | "type": "npm",
7 | "script": "start",
8 | "isBackground": true,
9 | "problemMatcher": {
10 | "owner": "typescript",
11 | "pattern": "$tsc",
12 | "background": {
13 | "activeOnStart": true,
14 | "beginsPattern": {
15 | "regexp": "(.*?)"
16 | },
17 | "endsPattern": {
18 | "regexp": "bundle generation complete"
19 | }
20 | }
21 | }
22 | },
23 | {
24 | "type": "npm",
25 | "script": "test",
26 | "isBackground": true,
27 | "problemMatcher": {
28 | "owner": "typescript",
29 | "pattern": "$tsc",
30 | "background": {
31 | "activeOnStart": true,
32 | "beginsPattern": {
33 | "regexp": "(.*?)"
34 | },
35 | "endsPattern": {
36 | "regexp": "bundle generation complete"
37 | }
38 | }
39 | }
40 | }
41 | ]
42 | }
43 |
--------------------------------------------------------------------------------
/projects/lib/src/lib/component/int-phone-prefix/int-phone-prefix.component.html:
--------------------------------------------------------------------------------
1 |
27 |
28 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "ng4-intl-phone",
3 | "version": "14.0.0",
4 | "description": "International phone prefix library for Angular",
5 | "repository": {
6 | "type": "git",
7 | "url": "https://github.com/kondi0/ng4-intl-phone.git"
8 | },
9 | "author": "kondi0",
10 | "license": "MIT",
11 | "scripts": {
12 | "ng": "ng",
13 | "start": "ng serve",
14 | "build": "ng build",
15 | "watch": "ng build --watch --configuration development",
16 | "test": "ng test"
17 | },
18 | "dependencies": {
19 | "@angular/animations": "~14.2.4",
20 | "@angular/common": "~14.2.4",
21 | "@angular/compiler": "~14.2.4",
22 | "@angular/core": "~14.2.4",
23 | "@angular/forms": "~14.2.4",
24 | "@angular/platform-browser": "~14.2.4",
25 | "@angular/platform-browser-dynamic": "~14.2.4",
26 | "@angular/router": "~14.2.4",
27 | "rxjs": "~7.5.0",
28 | "tslib": "^2.3.0",
29 | "zone.js": "~0.11.4"
30 | },
31 | "devDependencies": {
32 | "@angular-devkit/build-angular": "~14.2.4",
33 | "@angular/cli": "~14.2.4",
34 | "@angular/compiler-cli": "~14.2.4",
35 | "@types/jasmine": "~3.10.0",
36 | "@types/node": "^12.11.1",
37 | "jasmine-core": "~4.0.0",
38 | "karma": "~6.3.0",
39 | "karma-chrome-launcher": "~3.1.0",
40 | "karma-coverage": "~2.1.0",
41 | "karma-jasmine": "~4.0.0",
42 | "karma-jasmine-html-reporter": "~1.7.0",
43 | "ng-packagr": "^14.2.1",
44 | "typescript": "~4.6.2"
45 | }
46 | }
47 |
--------------------------------------------------------------------------------
/projects/demo/karma.conf.js:
--------------------------------------------------------------------------------
1 | // Karma configuration file, see link for more information
2 | // https://karma-runner.github.io/1.0/config/configuration-file.html
3 |
4 | module.exports = function (config) {
5 | config.set({
6 | basePath: '',
7 | frameworks: ['jasmine', '@angular-devkit/build-angular'],
8 | plugins: [
9 | require('karma-jasmine'),
10 | require('karma-chrome-launcher'),
11 | require('karma-jasmine-html-reporter'),
12 | require('karma-coverage'),
13 | require('@angular-devkit/build-angular/plugins/karma')
14 | ],
15 | client: {
16 | jasmine: {
17 | // you can add configuration options for Jasmine here
18 | // the possible options are listed at https://jasmine.github.io/api/edge/Configuration.html
19 | // for example, you can disable the random execution with `random: false`
20 | // or set a specific seed with `seed: 4321`
21 | },
22 | clearContext: false // leave Jasmine Spec Runner output visible in browser
23 | },
24 | jasmineHtmlReporter: {
25 | suppressAll: true // removes the duplicated traces
26 | },
27 | coverageReporter: {
28 | dir: require('path').join(__dirname, '../../coverage/demo'),
29 | subdir: '.',
30 | reporters: [
31 | { type: 'html' },
32 | { type: 'text-summary' }
33 | ]
34 | },
35 | reporters: ['progress', 'kjhtml'],
36 | port: 9876,
37 | colors: true,
38 | logLevel: config.LOG_INFO,
39 | autoWatch: true,
40 | browsers: ['Chrome'],
41 | singleRun: false,
42 | restartOnFileChange: true
43 | });
44 | };
45 |
--------------------------------------------------------------------------------
/projects/lib/karma.conf.js:
--------------------------------------------------------------------------------
1 | // Karma configuration file, see link for more information
2 | // https://karma-runner.github.io/1.0/config/configuration-file.html
3 |
4 | module.exports = function (config) {
5 | config.set({
6 | basePath: '',
7 | frameworks: ['jasmine', '@angular-devkit/build-angular'],
8 | plugins: [
9 | require('karma-jasmine'),
10 | require('karma-chrome-launcher'),
11 | require('karma-jasmine-html-reporter'),
12 | require('karma-coverage'),
13 | require('@angular-devkit/build-angular/plugins/karma')
14 | ],
15 | client: {
16 | jasmine: {
17 | // you can add configuration options for Jasmine here
18 | // the possible options are listed at https://jasmine.github.io/api/edge/Configuration.html
19 | // for example, you can disable the random execution with `random: false`
20 | // or set a specific seed with `seed: 4321`
21 | },
22 | clearContext: false // leave Jasmine Spec Runner output visible in browser
23 | },
24 | jasmineHtmlReporter: {
25 | suppressAll: true // removes the duplicated traces
26 | },
27 | coverageReporter: {
28 | dir: require('path').join(__dirname, '../../coverage/lib'),
29 | subdir: '.',
30 | reporters: [
31 | { type: 'html' },
32 | { type: 'text-summary' }
33 | ]
34 | },
35 | reporters: ['progress', 'kjhtml'],
36 | port: 9876,
37 | colors: true,
38 | logLevel: config.LOG_INFO,
39 | autoWatch: true,
40 | browsers: ['Chrome'],
41 | singleRun: false,
42 | restartOnFileChange: true
43 | });
44 | };
45 |
--------------------------------------------------------------------------------
/projects/lib/src/lib/directive/only-number.directive.ts:
--------------------------------------------------------------------------------
1 | import {Directive, ElementRef, HostListener, Input} from '@angular/core';
2 |
3 | @Directive({
4 | selector: '[onlyNumber]'
5 | })
6 | export class OnlyNumberDirective {
7 |
8 | @Input()
9 | onlyNumber: boolean;
10 |
11 | regexStr = '^[0-9]*$';
12 |
13 | constructor(private el: ElementRef) {
14 | }
15 |
16 | @HostListener('keydown', ['$event']) onKeyDown(event: KeyboardEvent) {
17 | let e = event;
18 | if (this.onlyNumber) {
19 | if (
20 | [46, 8, 9, 27, 13, 110, 190, 171].indexOf(e.keyCode) !== -1 ||
21 | // Allow: Ctrl+A
22 | (e.keyCode === 65 && e.ctrlKey === true) ||
23 | // Allow: Ctrl+C
24 | (e.keyCode === 67 && e.ctrlKey === true) ||
25 | // Allow: Ctrl+V
26 | (e.keyCode === 86 && e.ctrlKey === true) ||
27 | // Allow: Ctrl+X
28 | (e.keyCode === 88 && e.ctrlKey === true) ||
29 | // Allow: home, end, left, right
30 | (e.keyCode >= 35 && e.keyCode <= 39) ||
31 | // Allow plus button
32 | (e.keyCode === 107) || (e.keyCode === 187)) {
33 | // let it happen, don't do anything
34 | return;
35 | }
36 | let ch = String.fromCharCode(e.keyCode);
37 | let regEx = new RegExp(this.regexStr);
38 | if (regEx.test(ch)) {
39 | return;
40 | } else if ((e.shiftKey || (e.keyCode < 48 || e.keyCode > 57)) && (e.keyCode < 96 || e.keyCode > 105)) {
41 | e.preventDefault();
42 | }
43 | } else {
44 | return;
45 | }
46 | }
47 | }
48 |
--------------------------------------------------------------------------------
/projects/demo/src/app/app.component.ts:
--------------------------------------------------------------------------------
1 | import {Component, OnInit} from '@angular/core';
2 | import {FormBuilder, FormGroup, Validators} from '@angular/forms';
3 | import {CountryService} from '../../../lib/src/lib/service/country.service';
4 |
5 | @Component({
6 | selector: 'app-root',
7 | template: `
8 |
9 |
10 |
11 |
12 |
14 |
15 |
16 | The phone number is: {{phoneValue}}
17 |
18 |
19 |
36 |
37 | `,
38 | })
39 | export class AppComponent implements OnInit {
40 | phoneValue: string;
41 | myForm: FormGroup;
42 |
43 | constructor(libService: CountryService,
44 | private formBuilder: FormBuilder) {
45 | this.phoneValue = '123345456';
46 | }
47 |
48 |
49 | ngOnInit() {
50 | this.myForm = this.formBuilder.group({
51 | myPhone: ['', Validators.required],
52 | disabledPhone: ['']
53 | });
54 |
55 | this.myForm.get('disabledPhone').disable();
56 | }
57 |
58 | logForm(value: any) {
59 | console.log(value);
60 | }
61 | }
62 |
--------------------------------------------------------------------------------
/projects/demo/src/polyfills.ts:
--------------------------------------------------------------------------------
1 | /**
2 | * This file includes polyfills needed by Angular and is loaded before the app.
3 | * You can add your own extra polyfills to this file.
4 | *
5 | * This file is divided into 2 sections:
6 | * 1. Browser polyfills. These are applied before loading ZoneJS and are sorted by browsers.
7 | * 2. Application imports. Files imported after ZoneJS that should be loaded before your main
8 | * file.
9 | *
10 | * The current setup is for so-called "evergreen" browsers; the last versions of browsers that
11 | * automatically update themselves. This includes recent versions of Safari, Chrome (including
12 | * Opera), Edge on the desktop, and iOS and Chrome on mobile.
13 | *
14 | * Learn more in https://angular.io/guide/browser-support
15 | */
16 |
17 | /***************************************************************************************************
18 | * BROWSER POLYFILLS
19 | */
20 |
21 | /**
22 | * By default, zone.js will patch all possible macroTask and DomEvents
23 | * user can disable parts of macroTask/DomEvents patch by setting following flags
24 | * because those flags need to be set before `zone.js` being loaded, and webpack
25 | * will put import in the top of bundle, so user need to create a separate file
26 | * in this directory (for example: zone-flags.ts), and put the following flags
27 | * into that file, and then add the following code before importing zone.js.
28 | * import './zone-flags';
29 | *
30 | * The flags allowed in zone-flags.ts are listed here.
31 | *
32 | * The following flags will work for all browsers.
33 | *
34 | * (window as any).__Zone_disable_requestAnimationFrame = true; // disable patch requestAnimationFrame
35 | * (window as any).__Zone_disable_on_property = true; // disable patch onProperty such as onclick
36 | * (window as any).__zone_symbol__UNPATCHED_EVENTS = ['scroll', 'mousemove']; // disable patch specified eventNames
37 | *
38 | * in IE/Edge developer tools, the addEventListener will also be wrapped by zone.js
39 | * with the following flag, it will bypass `zone.js` patch for IE/Edge
40 | *
41 | * (window as any).__Zone_enable_cross_context_check = true;
42 | *
43 | */
44 |
45 | /***************************************************************************************************
46 | * Zone JS is required by default for Angular itself.
47 | */
48 | import 'zone.js'; // Included with Angular CLI.
49 |
50 |
51 | /***************************************************************************************************
52 | * APPLICATION IMPORTS
53 | */
54 |
--------------------------------------------------------------------------------
/projects/lib/README.md:
--------------------------------------------------------------------------------
1 | # Angular international phone prefix input
2 |
3 | #Demo
4 | https://ng4-intl-phone.netlify.app/
5 |
6 | ## Description
7 | This is a simple library with international phone prefix with flags images.
8 |
9 | ## Installation
10 |
11 | To install this component to an external project, follow the procedure:
12 |
13 | 1. __npm install ng4-intl-phone --save__
14 |
15 | 2. Add __InternationalPhoneModule__ import to your __@NgModule__ like example below
16 | ```ts
17 | import { NgModule } from '@angular/core';
18 | import { BrowserModule } from '@angular/platform-browser';
19 | import { MyTestApp } from './my-test-app';
20 | import { InternationalPhoneModule } from 'ng4-intl-phone';
21 | @NgModule({
22 | imports: [ BrowserModule, InternationalPhoneModule ],
23 | declarations: [ MyTestApp ],
24 | bootstrap: [ MyTestApp ]
25 | })
26 | export class MyTestAppModule {}
27 | ```
28 |
29 | ##Testing in localhost
30 | - `npm install ./relative/path/to/lib` after `npm run build` to test locally in another app
31 |
32 | ## Usage
33 |
34 | Use one of the following two options.
35 |
36 | ### 1. ngModel binding
37 |
38 | In this option the ngModel binding is used.
39 |
40 | ```html
41 |
42 | {{title}}
43 |
44 |
50 | ```
51 |
52 | ### 2. Reactive forms
53 |
54 | In this option the value accessor of reactive forms is used.
55 |
56 | To use reactive forms define the application class as follows:
57 |
58 | ```ts
59 |
60 | export class MyTestApp implements OnInit {
61 |
62 | private myForm: FormGroup;
63 |
64 | constructor(private formBuilder: FormBuilder) { }
65 |
66 | ngOnInit() {
67 | this.myForm = this.formBuilder.group({
68 | myPhone: ['', Validators.required]
69 | // other controls are here...
70 | });
71 | }
72 | }
73 | ```
74 |
75 | Add the following snippet inside your template:
76 |
77 | ```html
78 |
83 | ```
84 | ### @Input() locale
85 | An ISO 639-1 language code can be provided to set available language:
86 | es: Spanish,
87 | en: English
88 |
89 | ### @Input() defaultCountry
90 | An ISO 639-1 country code can be provided to set default country selected.
91 |
92 | ### @Input() maxLength
93 | maxLength (default: 15)
94 |
95 | ### @Input() onlyNumbers
96 | Allows only numeric values (default: true)
97 |
98 | ## License
99 | * License: MIT
100 |
101 | ## Author
102 | * Author: kondi0
103 |
104 | ## Mail
105 | * Mail: kondi.czerwinski@gmail.com
106 |
107 | ## Keywords
108 | * Phone
109 | * Prefix
110 | * International
111 | * Angular2
112 | * Angular4
113 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # Angular international phone prefix input
2 |
3 | # Demo
4 | https://ng4-intl-phone.netlify.app/
5 |
6 | ## Description
7 | This is a simple library with international phone prefix with flags images.
8 |
9 | ### Donating
10 |
11 | You can also help me and the project out by contributing through a donation on PayPal.
12 |
13 |
14 |
15 |
16 |
17 |
18 | ## Installation
19 |
20 | To install this component to an external project, follow the procedure:
21 |
22 | 1. __npm install ng4-intl-phone --save__
23 |
24 | 2. Add __InternationalPhoneModule__ import to your __@NgModule__ like example below
25 | ```ts
26 | import { NgModule } from '@angular/core';
27 | import { BrowserModule } from '@angular/platform-browser';
28 | import { MyTestApp } from './my-test-app';
29 | import { InternationalPhoneModule } from 'ng4-intl-phone';
30 | @NgModule({
31 | imports: [ BrowserModule, InternationalPhoneModule ],
32 | declarations: [ MyTestApp ],
33 | bootstrap: [ MyTestApp ]
34 | })
35 | export class MyTestAppModule {}
36 | ```
37 |
38 | ##Testing in localhost
39 | - `npm install ./relative/path/to/lib` after `npm run build` to test locally in another app
40 |
41 | ## Usage
42 |
43 | Use one of the following two options.
44 |
45 | ### 1. ngModel binding
46 |
47 | In this option the ngModel binding is used.
48 |
49 | ```html
50 |
51 | {{title}}
52 |
53 |
59 | ```
60 |
61 | ### 2. Reactive forms
62 |
63 | In this option the value accessor of reactive forms is used.
64 |
65 | To use reactive forms define the application class as follows:
66 |
67 | ```ts
68 |
69 | export class MyTestApp implements OnInit {
70 |
71 | private myForm: FormGroup;
72 |
73 | constructor(private formBuilder: FormBuilder) { }
74 |
75 | ngOnInit() {
76 | this.myForm = this.formBuilder.group({
77 | myPhone: ['', Validators.required]
78 | // other controls are here...
79 | });
80 | }
81 | }
82 | ```
83 |
84 | Add the following snippet inside your template:
85 |
86 | ```html
87 |
92 | ```
93 | ### @Input() locale
94 | An ISO 639-1 language code can be provided to set available language:
95 | es: Spanish,
96 | en: English
97 |
98 | ### @Input() defaultCountry
99 | An ISO 639-1 country code can be provided to set default country selected.
100 |
101 | ### @Input() maxLength
102 | maxLength (default: 15)
103 |
104 | ### @Input() onlyNumbers
105 | Allows only numeric values (default: true)
106 |
107 | ## License
108 | * License: MIT
109 |
110 | ## Author
111 | * Author: kondi0
112 |
113 | ## Mail
114 | * Mail: kondi.czerwinski@gmail.com
115 |
116 | ## Keywords
117 | * Phone
118 | * Prefix
119 | * International
120 | * Angular2
121 | * Angular4
122 |
--------------------------------------------------------------------------------
/angular.json:
--------------------------------------------------------------------------------
1 | {
2 | "$schema": "./node_modules/@angular/cli/lib/config/schema.json",
3 | "version": 1,
4 | "newProjectRoot": "projects",
5 | "projects": {
6 | "lib": {
7 | "projectType": "library",
8 | "root": "projects/lib",
9 | "sourceRoot": "projects/lib/src",
10 | "prefix": "lib",
11 | "architect": {
12 | "build": {
13 | "builder": "@angular-devkit/build-angular:ng-packagr",
14 | "options": {
15 | "project": "projects/lib/ng-package.json"
16 | },
17 | "configurations": {
18 | "production": {
19 | "tsConfig": "projects/lib/tsconfig.lib.prod.json"
20 | },
21 | "development": {
22 | "tsConfig": "projects/lib/tsconfig.lib.json"
23 | }
24 | },
25 | "defaultConfiguration": "production"
26 | },
27 | "test": {
28 | "builder": "@angular-devkit/build-angular:karma",
29 | "options": {
30 | "main": "projects/lib/src/test.ts",
31 | "tsConfig": "projects/lib/tsconfig.spec.json",
32 | "karmaConfig": "projects/lib/karma.conf.js"
33 | }
34 | }
35 | }
36 | },
37 | "demo": {
38 | "projectType": "application",
39 | "schematics": {
40 | "@schematics/angular:component": {
41 | "style": "scss"
42 | },
43 | "@schematics/angular:application": {
44 | "strict": true
45 | }
46 | },
47 | "root": "projects/demo",
48 | "sourceRoot": "projects/demo/src",
49 | "prefix": "app",
50 | "architect": {
51 | "build": {
52 | "builder": "@angular-devkit/build-angular:browser",
53 | "options": {
54 | "outputPath": "dist/demo",
55 | "index": "projects/demo/src/index.html",
56 | "main": "projects/demo/src/main.ts",
57 | "polyfills": "projects/demo/src/polyfills.ts",
58 | "tsConfig": "projects/demo/tsconfig.app.json",
59 | "inlineStyleLanguage": "scss",
60 | "assets": [
61 | "projects/demo/src/favicon.ico",
62 | "projects/demo/src/assets"
63 | ],
64 | "styles": [
65 | "projects/demo/src/styles.scss"
66 | ],
67 | "scripts": []
68 | },
69 | "configurations": {
70 | "production": {
71 |
72 | "fileReplacements": [
73 | {
74 | "replace": "projects/demo/src/environments/environment.ts",
75 | "with": "projects/demo/src/environments/environment.prod.ts"
76 | }
77 | ],
78 | "outputHashing": "all"
79 | },
80 | "development": {
81 | "buildOptimizer": false,
82 | "optimization": false,
83 | "vendorChunk": true,
84 | "extractLicenses": false,
85 | "sourceMap": true,
86 | "namedChunks": true
87 | }
88 | },
89 | "defaultConfiguration": "production"
90 | },
91 | "serve": {
92 | "builder": "@angular-devkit/build-angular:dev-server",
93 | "configurations": {
94 | "production": {
95 | "browserTarget": "demo:build:production"
96 | },
97 | "development": {
98 | "browserTarget": "demo:build:development"
99 | }
100 | },
101 | "defaultConfiguration": "development"
102 | },
103 | "extract-i18n": {
104 | "builder": "@angular-devkit/build-angular:extract-i18n",
105 | "options": {
106 | "browserTarget": "demo:build"
107 | }
108 | },
109 | "test": {
110 | "builder": "@angular-devkit/build-angular:karma",
111 | "options": {
112 | "main": "projects/demo/src/test.ts",
113 | "polyfills": "projects/demo/src/polyfills.ts",
114 | "tsConfig": "projects/demo/tsconfig.spec.json",
115 | "karmaConfig": "projects/demo/karma.conf.js",
116 | "inlineStyleLanguage": "scss",
117 | "assets": [
118 | "projects/demo/src/favicon.ico",
119 | "projects/demo/src/assets"
120 | ],
121 | "styles": [
122 | "projects/demo/src/styles.scss"
123 | ],
124 | "scripts": []
125 | }
126 | }
127 | }
128 | }
129 | },
130 | "defaultProject": "lib",
131 | "cli": {
132 | "analytics": false
133 | }
134 | }
135 |
--------------------------------------------------------------------------------
/projects/lib/src/lib/interface/country-code.interface.ts:
--------------------------------------------------------------------------------
1 | export interface CountryCode {
2 | "ax": string,
3 | "af": string,
4 | "al": string,
5 | "dz": string,
6 | "as": string,
7 | "ad": string,
8 | "ao": string,
9 | "ai": string,
10 | "aq": string,
11 | "ag": string,
12 | "ar": string,
13 | "am": string,
14 | "aw": string,
15 | "au": string,
16 | "at": string,
17 | "az": string,
18 | "bs": string,
19 | "bh": string,
20 | "bd": string,
21 | "bb": string,
22 | "by": string,
23 | "be": string,
24 | "bz": string,
25 | "bj": string,
26 | "bm": string,
27 | "bt": string,
28 | "bo": string,
29 | "ba": string,
30 | "bw": string,
31 | "bv": string,
32 | "br": string,
33 | "io": string,
34 | "bn": string,
35 | "bg": string,
36 | "bf": string,
37 | "bi": string,
38 | "bq": string,
39 | "kh": string,
40 | "cm": string,
41 | "ca": string,
42 | "cv": string,
43 | "ky": string,
44 | "cf": string,
45 | "td": string,
46 | "cl": string,
47 | "cn": string,
48 | "cx": string,
49 | "cc": string,
50 | "co": string,
51 | "km": string,
52 | "cd": string,
53 | "cg": string,
54 | "ck": string,
55 | "cr": string,
56 | "ci": string,
57 | "hr": string,
58 | "cu": string,
59 | "cw": string,
60 | "cy": string,
61 | "cz": string,
62 | "dk": string,
63 | "dj": string,
64 | "dm": string,
65 | "do": string,
66 | "ec": string,
67 | "eg": string,
68 | "sv": string,
69 | "gq": string,
70 | "er": string,
71 | "ee": string,
72 | "et": string,
73 | "fk": string,
74 | "fo": string,
75 | "fj": string,
76 | "fi": string,
77 | "fr": string,
78 | "gf": string,
79 | "pf": string,
80 | "tf": string,
81 | "ga": string,
82 | "gm": string,
83 | "ge": string,
84 | "de": string,
85 | "gh": string,
86 | "gi": string,
87 | "gr": string,
88 | "gl": string,
89 | "gd": string,
90 | "gp": string,
91 | "gu": string,
92 | "gt": string,
93 | "gg": string,
94 | "gn": string,
95 | "gw": string,
96 | "gy": string,
97 | "ht": string,
98 | "hm": string,
99 | "hn": string,
100 | "hk": string,
101 | "hu": string,
102 | "is": string,
103 | "in": string,
104 | "id": string,
105 | "ir": string,
106 | "iq": string,
107 | "ie": string,
108 | "im": string,
109 | "il": string,
110 | "it": string,
111 | "jm": string,
112 | "jp": string,
113 | "je": string,
114 | "jo": string,
115 | "kz": string,
116 | "ke": string,
117 | "ki": string,
118 | "kp": string,
119 | "kr": string,
120 | "xk": string,
121 | "kw": string,
122 | "kg": string,
123 | "la": string,
124 | "lv": string,
125 | "lb": string,
126 | "ls": string,
127 | "lr": string,
128 | "ly": string,
129 | "li": string,
130 | "lt": string,
131 | "lu": string,
132 | "mo": string,
133 | "mk": string,
134 | "mg": string,
135 | "mw": string,
136 | "my": string,
137 | "mv": string,
138 | "ml": string,
139 | "mt": string,
140 | "mh": string,
141 | "mq": string,
142 | "mr": string,
143 | "mu": string,
144 | "yt": string,
145 | "mx": string,
146 | "fm": string,
147 | "md": string,
148 | "mc": string,
149 | "mn": string,
150 | "me": string,
151 | "ms": string,
152 | "ma": string,
153 | "mz": string,
154 | "mm": string,
155 | "na": string,
156 | "nr": string,
157 | "np": string,
158 | "nl": string,
159 | "an": string,
160 | "nc": string,
161 | "nz": string,
162 | "ni": string,
163 | "ne": string,
164 | "ng": string,
165 | "nu": string,
166 | "nf": string,
167 | "mp": string,
168 | "no": string,
169 | "om": string,
170 | "pk": string,
171 | "pw": string,
172 | "ps": string,
173 | "pa": string,
174 | "pg": string,
175 | "py": string,
176 | "pe": string,
177 | "ph": string,
178 | "pn": string,
179 | "pl": string,
180 | "pt": string,
181 | "pr": string,
182 | "qa": string,
183 | "re": string,
184 | "ro": string,
185 | "ru": string,
186 | "rw": string,
187 | "sh": string,
188 | "kn": string,
189 | "lc": string,
190 | "pm": string,
191 | "vc": string,
192 | "ws": string,
193 | "bl": string,
194 | "sm": string,
195 | "st": string,
196 | "sa": string,
197 | "sn": string,
198 | "cs": string,
199 | "rs": string,
200 | "sc": string,
201 | "sl": string,
202 | "sg": string,
203 | "sx": string,
204 | "sk": string,
205 | "si": string,
206 | "sb": string,
207 | "so": string,
208 | "za": string,
209 | "gs": string,
210 | "es": string,
211 | "lk": string,
212 | "sd": string,
213 | "ss": string,
214 | "sr": string,
215 | "sj": string,
216 | "sz": string,
217 | "se": string,
218 | "ch": string,
219 | "sy": string,
220 | "tw": string,
221 | "tj": string,
222 | "tz": string,
223 | "th": string,
224 | "tl": string,
225 | "tg": string,
226 | "tk": string,
227 | "to": string,
228 | "tt": string,
229 | "tn": string,
230 | "tr": string,
231 | "tm": string,
232 | "tc": string,
233 | "tv": string,
234 | "ug": string,
235 | "ua": string,
236 | "ae": string,
237 | "gb": string,
238 | "us": string,
239 | "um": string,
240 | "uy": string,
241 | "uz": string,
242 | "vu": string,
243 | "va": string,
244 | "ve": string,
245 | "vn": string,
246 | "vg": string,
247 | "vi": string,
248 | "wf": string,
249 | "eh": string,
250 | "ye": string,
251 | "zm": string,
252 | "zw": string
253 | }
254 |
--------------------------------------------------------------------------------
/projects/lib/src/lib/component/int-phone-prefix/int-phone-prefix.component.ts:
--------------------------------------------------------------------------------
1 | import {Component, ElementRef, forwardRef, HostListener, Input, OnInit, Renderer2} from '@angular/core';
2 | import {Country} from '../../interface/country.interface';
3 | import {ControlValueAccessor, NG_VALUE_ACCESSOR} from '@angular/forms';
4 | import {CountryCode} from '../../interface/country-code.interface';
5 | import {CountryService} from '../../service/country.service';
6 | import {LocaleService} from '../../service/locale.service';
7 |
8 | const COUNTER_CONTROL_ACCESSOR = {
9 | provide: NG_VALUE_ACCESSOR,
10 | useExisting: forwardRef(() => IntPhonePrefixComponent),
11 | multi: true
12 | };
13 |
14 | const PLUS = '+';
15 |
16 | @Component({
17 | selector: 'int-phone-prefix',
18 | templateUrl: './int-phone-prefix.component.html',
19 | styleUrls: [
20 | './int-phone-prefix.component.scss',
21 | ],
22 | host: {
23 | '(document:click)': 'hideDropdown($event)',
24 | },
25 | providers: [COUNTER_CONTROL_ACCESSOR, CountryService, LocaleService]
26 | })
27 | export class IntPhonePrefixComponent implements OnInit, ControlValueAccessor {
28 |
29 | @Input()
30 | locale: string;
31 |
32 | @Input()
33 | defaultCountry: string;
34 |
35 | @Input()
36 | maxLength = 15;
37 |
38 | @Input()
39 | onlyNumbers = true;
40 |
41 | // ELEMENT REF
42 | phoneComponent: ElementRef;
43 |
44 | // CONTROL VALUE ACCESSOR FUNCTIONS
45 | onTouch: Function;
46 | onModelChange: Function;
47 |
48 | countries: Country[];
49 | locales: CountryCode;
50 | selectedCountry: Country;
51 | countryFilter: string;
52 | showDropdown = false;
53 | phoneInput = '';
54 | disabled = false;
55 |
56 | value = '';
57 |
58 | // FILTER COUNTRIES LIST WHEN DROPDOWN IS OPEN
59 | @HostListener('document:keypress', ['$event'])
60 | handleKeyboardEvent(event: KeyboardEvent) {
61 | if (this.showDropdown) {
62 | this.countryFilter = `${this.countryFilter}${event.key}`;
63 | }
64 | }
65 |
66 | constructor(private service: CountryService, private localeService: LocaleService, phoneComponent: ElementRef) {
67 | this.phoneComponent = phoneComponent;
68 | }
69 |
70 | ngOnInit(): void {
71 | this.countries = this.service.getCountries();
72 | this.locales = this.localeService.getLocales(this.locale);
73 | this.translateCountryNames();
74 | }
75 |
76 | setDisabledState(isDisabled: boolean): void {
77 | this.disabled = isDisabled;
78 | }
79 |
80 | registerOnTouched(fn: Function) {
81 | this.onTouch = fn;
82 | }
83 |
84 | registerOnChange(fn: Function) {
85 | this.onModelChange = fn;
86 | }
87 |
88 | writeValue(value: string) {
89 | this.value = value || '';
90 | this.phoneInput = this.value;
91 |
92 | if (IntPhonePrefixComponent.startsWithPlus(this.value)) {
93 | this.findPrefix(this.value.split(PLUS)[1]);
94 | if (this.selectedCountry) {
95 | this.updatePhoneInput(this.selectedCountry.countryCode);
96 | }
97 | }
98 |
99 | if (this.defaultCountry) {
100 | this.updatePhoneInput(this.defaultCountry);
101 | }
102 | }
103 |
104 | updateSelectedCountry(event: Event, countryCode: string) {
105 | event.preventDefault();
106 | this.updatePhoneInput(countryCode);
107 |
108 | this.updateValue();
109 | }
110 |
111 | showDropDown() {
112 | this.showDropdown = !this.showDropdown;
113 | this.countryFilter = '';
114 | }
115 |
116 | hideDropdown(event: Event) {
117 | if (!this.phoneComponent.nativeElement.contains(event.target)) {
118 | this.showDropdown = false;
119 | }
120 | }
121 |
122 | updatePhone() {
123 | if (IntPhonePrefixComponent.startsWithPlus(this.phoneInput)) {
124 | this.findPrefix(this.phoneInput.split(PLUS)[1]);
125 | } else {
126 | this.selectedCountry = null;
127 | }
128 |
129 | this.updateValue();
130 | }
131 |
132 | private translateCountryNames() {
133 | this.countries.forEach((country: Country) => {
134 | country.name = this.locales[country.countryCode];
135 | });
136 |
137 | this.orderCountriesByName();
138 | }
139 |
140 | private orderCountriesByName() {
141 | this.countries = this.countries.sort((a, b) => (a.name > b.name) ? 1 : -1);
142 | }
143 |
144 | private updatePhoneInput(countryCode: string) {
145 | this.showDropdown = false;
146 |
147 | let newInputValue: string = IntPhonePrefixComponent.startsWithPlus(this.phoneInput)
148 | ? `${this.phoneInput.split(PLUS)[1].substr(this.selectedCountry.dialCode.length, this.phoneInput.length)}`
149 | : this.phoneInput;
150 |
151 | this.selectedCountry = this.countries.find((country: Country) => country.countryCode === countryCode);
152 | this.phoneInput = `${PLUS}${this.selectedCountry.dialCode} ${newInputValue.replace(/ /g, '')}`;
153 | }
154 |
155 | private findPrefix(prefix: string) {
156 | let foundPrefixes: Country[] = this.countries.filter((country: Country) => prefix.startsWith(country.dialCode));
157 | this.selectedCountry = foundPrefixes.length
158 | ? IntPhonePrefixComponent.reducePrefixes(foundPrefixes)
159 | : null;
160 | }
161 |
162 | private updateValue() {
163 | this.value = this.phoneInput.replace(/ /g, '');
164 | this.onModelChange(this.value);
165 | this.onTouch();
166 | }
167 |
168 | private static startsWithPlus(text: string): boolean {
169 | return text.startsWith(PLUS);
170 | }
171 |
172 | private static reducePrefixes(foundPrefixes: Country[]) {
173 | return foundPrefixes.reduce(
174 | (first: Country, second: Country) =>
175 | first.dialCode.length > second.dialCode.length
176 | ? first
177 | : second
178 | );
179 | }
180 | }
181 |
--------------------------------------------------------------------------------
/projects/lib/src/lib/service/locale.service.ts:
--------------------------------------------------------------------------------
1 | import {Injectable} from '@angular/core';
2 | import {CountryLocale} from '../interface/country-locale.interface';
3 | import {CountryCode} from "../interface/country-code.interface";
4 |
5 | @Injectable()
6 | export class LocaleService {
7 | private locales: CountryLocale = {
8 | 'en': {
9 | 'ax': 'AALAND ISLANDS',
10 | 'af': 'AFGHANISTAN',
11 | 'al': 'ALBANIA',
12 | 'dz': 'ALGERIA',
13 | 'as': 'AMERICAN SAMOA',
14 | 'ad': 'ANDORRA',
15 | 'ao': 'ANGOLA',
16 | 'ai': 'ANGUILLA',
17 | 'aq': 'ANTARCTICA',
18 | 'ag': 'ANTIGUA AND BARBUDA',
19 | 'ar': 'ARGENTINA',
20 | 'am': 'ARMENIA',
21 | 'aw': 'ARUBA',
22 | 'au': 'AUSTRALIA',
23 | 'at': 'AUSTRIA',
24 | 'az': 'AZERBAIJAN',
25 | 'bs': 'BAHAMAS',
26 | 'bh': 'BAHRAIN',
27 | 'bd': 'BANGLADESH',
28 | 'bb': 'BARBADOS',
29 | 'by': 'BELARUS',
30 | 'be': 'BELGIUM',
31 | 'bz': 'BELIZE',
32 | 'bj': 'BENIN',
33 | 'bm': 'BERMUDA',
34 | 'bt': 'BHUTAN',
35 | 'bo': 'BOLIVIA',
36 | 'ba': 'BOSNIA AND HERZEGOWINA',
37 | 'bw': 'BOTSWANA',
38 | 'bv': 'BOUVET ISLAND',
39 | 'br': 'BRAZIL',
40 | 'io': 'BRITISH INDIAN OCEAN TERRITORY',
41 | 'bn': 'BRUNEI DARUSSALAM',
42 | 'bg': 'BULGARIA',
43 | 'bf': 'BURKINA FASO',
44 | 'bi': 'BURUNDI',
45 | 'bq': 'CARIBBEAN NETHERLANDS',
46 | 'kh': 'CAMBODIA',
47 | 'cm': 'CAMEROON',
48 | 'ca': 'CANADA',
49 | 'cv': 'CAPE VERDE',
50 | 'ky': 'CAYMAN ISLANDS',
51 | 'cf': 'CENTRAL AFRICAN REPUBLIC',
52 | 'td': 'CHAD',
53 | 'cl': 'CHILE',
54 | 'cn': 'CHINA',
55 | 'cx': 'CHRISTMAS ISLAND',
56 | 'cc': 'COCOS ISLANDS',
57 | 'co': 'COLOMBIA',
58 | 'km': 'COMOROS',
59 | 'cd': 'CONGO',
60 | 'cg': 'CONGO REPUBLIC',
61 | 'ck': 'COOK ISLANDS',
62 | 'cr': 'COSTA RICA',
63 | 'ci': 'COTE DIVOIRE',
64 | 'hr': 'CROATIA ',
65 | 'cu': 'CUBA',
66 | 'cw': 'CURACAO',
67 | 'cy': 'CYPRUS',
68 | 'cz': 'CZECH REPUBLIC',
69 | 'dk': 'DENMARK',
70 | 'dj': 'DJIBOUTI',
71 | 'dm': 'DOMINICA',
72 | 'do': 'DOMINICAN REPUBLIC',
73 | 'ec': 'ECUADOR',
74 | 'eg': 'EGYPT',
75 | 'sv': 'EL SALVADOR',
76 | 'gq': 'EQUATORIAL GUINEA',
77 | 'er': 'ERITREA',
78 | 'ee': 'ESTONIA',
79 | 'et': 'ETHIOPIA',
80 | 'fk': 'FALKLAND ISLANDS (MALVINAS)',
81 | 'fo': 'FAROE ISLANDS',
82 | 'fj': 'FIJI',
83 | 'fi': 'FINLAND',
84 | 'fr': 'FRANCE',
85 | 'gf': 'FRENCH GUIANA',
86 | 'pf': 'FRENCH POLYNESIA',
87 | 'tf': 'FRENCH SOUTHERN TERRITORIES',
88 | 'ga': 'GABON',
89 | 'gm': 'GAMBIA',
90 | 'ge': 'GEORGIA',
91 | 'de': 'GERMANY',
92 | 'gh': 'GHANA',
93 | 'gi': 'GIBRALTAR',
94 | 'gr': 'GREECE',
95 | 'gl': 'GREENLAND',
96 | 'gd': 'GRENADA',
97 | 'gp': 'GUADELOUPE',
98 | 'gu': 'GUAM',
99 | 'gt': 'GUATEMALA',
100 | 'gg': 'GUERNSEY',
101 | 'gn': 'GUINEA',
102 | 'gw': 'GUINEA-BISSAU',
103 | 'gy': 'GUYANA',
104 | 'ht': 'HAITI',
105 | 'hm': 'HEARD AND MC DONALD ISLANDS',
106 | 'hn': 'HONDURAS',
107 | 'hk': 'HONG KONG',
108 | 'hu': 'HUNGARY',
109 | 'is': 'ICELAND',
110 | 'in': 'INDIA',
111 | 'id': 'INDONESIA',
112 | 'ir': 'IRAN ',
113 | 'iq': 'IRAQ',
114 | 'ie': 'IRELAND',
115 | 'im': 'ISLA DE MAN',
116 | 'il': 'ISRAEL',
117 | 'it': 'ITALY',
118 | 'jm': 'JAMAICA',
119 | 'jp': 'JAPAN',
120 | 'je': 'JERSEY',
121 | 'jo': 'JORDAN',
122 | 'kz': 'KAZAKHSTAN',
123 | 'ke': 'KENYA',
124 | 'ki': 'KIRIBATI',
125 | 'kp': 'KOREA NORTH ',
126 | 'kr': 'KOREA SOUTH',
127 | 'xk': 'KOSOVO',
128 | 'kw': 'KUWAIT',
129 | 'kg': 'KYRGYZSTAN',
130 | 'la': 'LAO',
131 | 'lv': 'LATVIA',
132 | 'lb': 'LEBANON',
133 | 'ls': 'LESOTHO',
134 | 'lr': 'LIBERIA',
135 | 'ly': 'LIBYAN ARAB JAMAHIRIYA',
136 | 'li': 'LIECHTENSTEIN',
137 | 'lt': 'LITHUANIA',
138 | 'lu': 'LUXEMBOURG',
139 | 'mo': 'MACAU',
140 | 'mk': 'MACEDONIA',
141 | 'mg': 'MADAGASCAR',
142 | 'mw': 'MALAWI',
143 | 'my': 'MALAYSIA',
144 | 'mv': 'MALDIVES',
145 | 'ml': 'MALI',
146 | 'mt': 'MALTA',
147 | 'mh': 'MARSHALL ISLANDS',
148 | 'mq': 'MARTINIQUE',
149 | 'mr': 'MAURITANIA',
150 | 'mu': 'MAURITIUS',
151 | 'yt': 'MAYOTTE',
152 | 'mx': 'MEXICO',
153 | 'fm': 'MICRONESIA',
154 | 'md': 'MOLDOVA',
155 | 'mc': 'MONACO',
156 | 'mn': 'MONGOLIA',
157 | 'me': 'MONTENEGRO',
158 | 'ms': 'MONTSERRAT',
159 | 'ma': 'MOROCCO',
160 | 'mz': 'MOZAMBIQUE',
161 | 'mm': 'MYANMAR',
162 | 'na': 'NAMIBIA',
163 | 'nr': 'NAURU',
164 | 'np': 'NEPAL',
165 | 'nl': 'NETHERLANDS',
166 | 'an': 'NETHERLANDS ANTILLES',
167 | 'nc': 'NEW CALEDONIA',
168 | 'nz': 'NEW ZEALAND',
169 | 'ni': 'NICARAGUA',
170 | 'ne': 'NIGER',
171 | 'ng': 'NIGERIA',
172 | 'nu': 'NIUE',
173 | 'nf': 'NORFOLK ISLAND',
174 | 'mp': 'NORTHERN MARIANA ISLANDS',
175 | 'no': 'NORWAY',
176 | 'om': 'OMAN',
177 | 'pk': 'PAKISTAN',
178 | 'pw': 'PALAU',
179 | 'ps': 'PALESTINA',
180 | 'pa': 'PANAMA',
181 | 'pg': 'PAPUA NEW GUINEA',
182 | 'py': 'PARAGUAY',
183 | 'pe': 'PERU',
184 | 'ph': 'PHILIPPINES',
185 | 'pn': 'PITCAIRN',
186 | 'pl': 'POLAND',
187 | 'pt': 'PORTUGAL',
188 | 'pr': 'PUERTO RICO',
189 | 'qa': 'QATAR',
190 | 're': 'REUNION',
191 | 'ro': 'ROMANIA',
192 | 'ru': 'RUSSIAN FEDERATION',
193 | 'rw': 'RWANDA',
194 | 'sh': 'SAINT HELENA',
195 | 'kn': 'SAINT KITTS AND NEVIS',
196 | 'lc': 'SAINT LUCIA',
197 | 'pm': 'SAINT PIERRE AND MIQUELON',
198 | 'vc': 'SAINT VINCENT AND THE GRENADINES',
199 | 'ws': 'SAMOA',
200 | 'bl': 'SAN BARTOLOMÉ',
201 | 'sm': 'SAN MARINO',
202 | 'st': 'SAO TOME AND PRINCIPE',
203 | 'sa': 'SAUDI ARABIA',
204 | 'sn': 'SENEGAL',
205 | 'cs': 'SERBIA AND MONTENEGRO',
206 | 'rs': 'SERBIA',
207 | 'sc': 'SEYCHELLES',
208 | 'sl': 'SIERRA LEONE',
209 | 'sg': 'SINGAPORE',
210 | 'sx': 'SINT MAARTEN',
211 | 'sk': 'SLOVAKIA',
212 | 'si': 'SLOVENIA',
213 | 'sb': 'SOLOMON ISLANDS',
214 | 'so': 'SOMALIA',
215 | 'za': 'SOUTH AFRICA',
216 | 'gs': 'SOUTH GEORGIA ISLANDS',
217 | 'es': 'SPAIN',
218 | 'lk': 'SRI LANKA',
219 | 'sd': 'SUDAN',
220 | 'ss': 'SOUTH SUDAN',
221 | 'sr': 'SURINAME',
222 | 'sj': 'SVALBARD AND JAN MAYEN ISLANDS',
223 | 'sz': 'SWAZILAND',
224 | 'se': 'SWEDEN',
225 | 'ch': 'SWITZERLAND',
226 | 'sy': 'SYRIAN ARAB REPUBLIC',
227 | 'tw': 'TAIWAN',
228 | 'tj': 'TAJIKISTAN',
229 | 'tz': 'TANZANIA',
230 | 'th': 'THAILAND',
231 | 'tl': 'TIMOR-LESTE',
232 | 'tg': 'TOGO',
233 | 'tk': 'TOKELAU',
234 | 'to': 'TONGA',
235 | 'tt': 'TRINIDAD AND TOBAGO',
236 | 'tn': 'TUNISIA',
237 | 'tr': 'TURKEY',
238 | 'tm': 'TURKMENISTAN',
239 | 'tc': 'TURKS AND CAICOS ISLANDS',
240 | 'tv': 'TUVALU',
241 | 'ug': 'UGANDA',
242 | 'ua': 'UKRAINE',
243 | 'ae': 'UNITED ARAB EMIRATES',
244 | 'gb': 'UNITED KINGDOM',
245 | 'us': 'UNITED STATES',
246 | 'um': 'UNITED STATES MINOR OUTLYING ISLANDS',
247 | 'uy': 'URUGUAY',
248 | 'uz': 'UZBEKISTAN',
249 | 'vu': 'VANUATU',
250 | 'va': 'VATICAN CITY STATE',
251 | 've': 'VENEZUELA',
252 | 'vn': 'VIET NAM',
253 | 'vg': 'VIRGIN ISLANDS (BRITISH)',
254 | 'vi': 'VIRGIN ISLANDS (U.S.)',
255 | 'wf': 'WALLIS AND FUTUNA ISLANDS',
256 | 'eh': 'WESTERN SAHARA',
257 | 'ye': 'YEMEN',
258 | 'zm': 'ZAMBIA',
259 | 'zw': 'ZIMBABWE '
260 | },
261 | 'es': {
262 | 'ax': 'ISLAS ÁLAND',
263 | 'af': 'AFGHANISTÁN',
264 | 'al': 'ALBANIA',
265 | 'dz': 'ARGEL',
266 | 'as': 'SAMOA AMERICANA',
267 | 'ad': 'ANDORRA',
268 | 'ao': 'ANGOLA',
269 | 'ai': 'ANGUILA',
270 | 'aq': 'ANTÁRTIDA',
271 | 'ag': 'ANTIGUA Y BARBUDA',
272 | 'ar': 'ARGENTINA',
273 | 'am': 'ARMENIA',
274 | 'aw': 'ARUBA',
275 | 'au': 'AUSTRALIA',
276 | 'at': 'AUSTRIA',
277 | 'az': 'AZERBAIYÁN',
278 | 'bs': 'BAHAMAS',
279 | 'bh': 'BAHRÉIN',
280 | 'bd': 'BANGLADESH',
281 | 'bb': 'BARBADOS',
282 | 'by': 'BELARÚS',
283 | 'be': 'BÉLGICA',
284 | 'bz': 'BELICE',
285 | 'bj': 'BENIN',
286 | 'bm': 'BERMUDAAS',
287 | 'bt': 'BHUTÁN',
288 | 'bo': 'BOLIVIA',
289 | 'ba': 'BOSNIA Y HERZEGOVINA',
290 | 'bw': 'BOTSUANA',
291 | 'bv': 'ISLA BOUVET',
292 | 'br': 'BRASIL',
293 | 'io': 'TERRITORIO BRITÁNICO DEL OCÉANO ÍNDICO',
294 | 'bn': 'BRUNÉI',
295 | 'bg': 'BULGARIA',
296 | 'bf': 'BURKINA FASO',
297 | 'bi': 'BURUNDI',
298 | 'bq': 'CARIBE PAÍSES BAJOS',
299 | 'kh': 'CAMBOYA',
300 | 'cm': 'CAMERÚN',
301 | 'ca': 'CANADÁ',
302 | 'cv': 'CABO VERDE',
303 | 'ky': 'ISLAS CAIMÁN',
304 | 'cf': 'REPÚBLICA CENTRO-AFRICANA',
305 | 'td': 'CHAD',
306 | 'cl': 'CHILE',
307 | 'cn': 'CHINA',
308 | 'cx': 'ISLAS CHRISTMAS',
309 | 'cc': 'ISLAS COCOS',
310 | 'co': 'COLOMBIA',
311 | 'km': 'COMOROS',
312 | 'cd': 'CONGO (ZAIRE)',
313 | 'cg': 'CONGO',
314 | 'ck': 'ISLAS COOK',
315 | 'cr': 'COSTA RICA',
316 | 'ci': 'COSTA DE MARFIL',
317 | 'hr': 'CROACIA ',
318 | 'cu': 'CUBA',
319 | 'cw': 'CURAÇAO',
320 | 'cy': 'CHIPRE',
321 | 'cz': 'REPÚBLICA CHECA',
322 | 'dk': 'DINAMARCA',
323 | 'dj': 'YIBUTI',
324 | 'dm': 'DOMÍNICA',
325 | 'do': 'REPÚBLICA DOMINICANA',
326 | 'ec': 'ECUADOR',
327 | 'eg': 'EGIPTO',
328 | 'sv': 'EL SALVADOR',
329 | 'gq': 'GUINEA ECUATORIAL',
330 | 'er': 'ERITREA',
331 | 'ee': 'ESTONIA',
332 | 'et': 'ETIOPÍA',
333 | 'fk': 'ISLAS MALVINAS',
334 | 'fo': 'ISLAS FAROE',
335 | 'fj': 'FIJI',
336 | 'fi': 'FINLANDIA',
337 | 'fr': 'FRANCIA',
338 | 'gf': 'GUIANA FRANCESA',
339 | 'pf': 'POLYNESIA FRANCESA',
340 | 'tf': 'TERRITORIOS AUSTRALES FRANCESES',
341 | 'ga': 'GABÓN',
342 | 'gm': 'GAMBIA',
343 | 'ge': 'GEORGIA',
344 | 'de': 'ALEMANIA',
345 | 'gh': 'GHANA',
346 | 'gi': 'GIBRALTAR',
347 | 'gr': 'GREECE',
348 | 'gl': 'GROENLANDIA',
349 | 'gd': 'GRANADA',
350 | 'gp': 'GUADALUPE',
351 | 'gu': 'GUAM',
352 | 'gt': 'GUATEMALA',
353 | 'gg': 'GUERNSEY',
354 | 'gn': 'GUINEA',
355 | 'gw': 'GUINEA-BISSAU',
356 | 'gy': 'GUYANA',
357 | 'ht': 'HAITI',
358 | 'hm': 'ISLAS HEARD Y MC DONALD',
359 | 'hn': 'HONDURAS',
360 | 'hk': 'HONG KONG',
361 | 'hu': 'HUNGRÍA',
362 | 'is': 'ISLANDIA',
363 | 'in': 'INDIA',
364 | 'id': 'INDONESIA',
365 | 'ir': 'IRÁN',
366 | 'iq': 'IRAK',
367 | 'ie': 'IRLANDA',
368 | 'im': 'ISLA DE MAN',
369 | 'il': 'ISRAEL',
370 | 'it': 'ITALIA',
371 | 'jm': 'JAMAICA',
372 | 'jp': 'JAPÓN',
373 | 'je': 'JERSEY',
374 | 'jo': 'JORDANIA',
375 | 'kz': 'KAZAJSTÁN',
376 | 'ke': 'KENIA',
377 | 'ki': 'KIRIBATI',
378 | 'kp': 'KOREA DEL NORTE',
379 | 'kr': 'KOREA DEL SUR',
380 | 'xk': 'KOSOVO',
381 | 'kw': 'KUWAIT',
382 | 'kg': 'KIRGUISTÁN',
383 | 'la': 'LAOS',
384 | 'lv': 'LETONIA',
385 | 'lb': 'LÍBANO',
386 | 'ls': 'LESOTHO',
387 | 'lr': 'LIBERIA',
388 | 'ly': 'LIBIA',
389 | 'li': 'LIECHTENSTEIN',
390 | 'lt': 'LITUANIA',
391 | 'lu': 'LUXEMBURGO',
392 | 'mo': 'MACAO',
393 | 'mk': 'MACEDONIA',
394 | 'mg': 'MADAGASCAR',
395 | 'mw': 'MALAWI',
396 | 'my': 'MALASIA',
397 | 'mv': 'MALDIVAS',
398 | 'ml': 'MALI',
399 | 'mt': 'MALTA',
400 | 'mh': 'ISLAS MARSHALL',
401 | 'mq': 'MATINICA',
402 | 'mr': 'MAURITANIA',
403 | 'mu': 'MAURICIO',
404 | 'yt': 'MAYOTTE',
405 | 'mx': 'MÉXICO',
406 | 'fm': 'MICRONESIA',
407 | 'md': 'MOLDOVA',
408 | 'mc': 'MÓNACO',
409 | 'mn': 'MONGOLIA',
410 | 'me': 'MONTENEGRO',
411 | 'ms': 'MONTSERRAT',
412 | 'ma': 'MARRUECOS',
413 | 'mz': 'MOZAMBIQUE',
414 | 'mm': 'MYANMAR',
415 | 'na': 'NAMIBIA',
416 | 'nr': 'NAURU',
417 | 'np': 'NEPAL',
418 | 'nl': 'PAÍSES BAJOS',
419 | 'an': 'ANTILLAS NEERLANDESAS',
420 | 'nc': 'NUEVA CALEDONIA',
421 | 'nz': 'NUEVA ZELANDA',
422 | 'ni': 'NICARAGUA',
423 | 'ne': 'NÍGER',
424 | 'ng': 'NIGERIA',
425 | 'nu': 'NIUE',
426 | 'nf': 'ISLAS NORKFOLK',
427 | 'mp': 'ISLAS MARIANAS DEL NORTE',
428 | 'no': 'NORUEGA',
429 | 'om': 'OMÁN',
430 | 'pk': 'PAKISTÁN',
431 | 'pw': 'ISLAS PALAOS',
432 | 'ps': 'PALESTINA',
433 | 'pa': 'PANAMÁ',
434 | 'pg': 'PAPÚA NUEVA GUINEA',
435 | 'py': 'PARAGUAY',
436 | 'pe': 'PERÚ',
437 | 'ph': 'FILIPINAS',
438 | 'pn': 'ISLAS PITCAIRN',
439 | 'pl': 'POLONIA',
440 | 'pt': 'PORTUGAL',
441 | 'pr': 'PUERTO RICO',
442 | 'qa': 'QATAR',
443 | 're': 'REUNIÓN',
444 | 'ro': 'RUMANÍA',
445 | 'ru': 'RUSIA',
446 | 'rw': 'RUANDA',
447 | 'sh': 'SANTA ELENA',
448 | 'kn': 'SAN CRISTÓBAL Y NIEVES',
449 | 'lc': 'SANTA LUCÍA',
450 | 'pm': 'SAN PEDRO Y MIQUELÓN',
451 | 'vc': 'SAN VICENTE Y LAS GRANADINAS',
452 | 'ws': 'SAMOA',
453 | 'bl': 'SAN BARTOLOMÉ',
454 | 'sm': 'SAN MARINO',
455 | 'st': 'SANTO TOMÉ Y PRÍNCIPE',
456 | 'sa': 'ARABIA SAUDITA',
457 | 'sn': 'SENEGAL',
458 | 'cs': 'SERBIA Y MONTENEGRO',
459 | 'rs': 'SERBIA',
460 | 'sc': 'SEYCHELLES',
461 | 'sl': 'SIERRA LEONA',
462 | 'sg': 'SINGAPUR',
463 | 'sx': 'SINT MAARTEN',
464 | 'sk': 'ESLOVAQUIA',
465 | 'si': 'ESLOVENIA',
466 | 'sb': 'ISLAS SOLOMÓN',
467 | 'so': 'SOMALIA',
468 | 'za': 'SUDÁFRICA',
469 | 'gs': 'GEORGIA DEL SUR E ISLAS SANDWICH DEL SUR',
470 | 'es': 'ESPAÑA',
471 | 'lk': 'SRI LANKA',
472 | 'sd': 'SUDÁN',
473 | 'ss': 'SUDÁN DEL SUR',
474 | 'sr': 'SURINAM',
475 | 'sj': 'ISLAS SVALBARD Y JAN MAYEN',
476 | 'sz': 'SUAZILANDIA',
477 | 'se': 'SUECIA',
478 | 'ch': 'SUIZA',
479 | 'sy': 'SIRIA',
480 | 'tw': 'TAIWÁN',
481 | 'tj': 'TAYIKISTÁN',
482 | 'tz': 'TANZANIA',
483 | 'th': 'TAILANDIA',
484 | 'tl': 'TIMOR-LESTE',
485 | 'tg': 'TOGO',
486 | 'tk': 'TOKELAU',
487 | 'to': 'TONGA',
488 | 'tt': 'TRINIDAD Y TOBAGO',
489 | 'tn': 'TÚNEZ',
490 | 'tr': 'TURQUÍA',
491 | 'tm': 'TURKMENISTÁN',
492 | 'tc': 'ISLAS TURCAS Y CAICOS',
493 | 'tv': 'TUVALU',
494 | 'ug': 'UGANDA',
495 | 'ua': 'UCRANIA',
496 | 'ae': 'EMIRATOS ÁRABES UNIDOS',
497 | 'gb': 'REINO UNIDO',
498 | 'us': 'ESTADOS UNIDOS DE AMÉRICA',
499 | 'um': 'ESTADOS UNIDOS ISLAS MINOR OUTLYING',
500 | 'uy': 'URUGUAY',
501 | 'uz': 'UZBEKISTÁN',
502 | 'vu': 'VANUATU',
503 | 'va': 'CIUDAD DEL VATICANO',
504 | 've': 'VENEZUELA',
505 | 'vn': 'VIETNAM',
506 | 'vg': 'ISLAS VÍRGENES (INGLESAS)',
507 | 'vi': 'ISLAS VÍRGENES (U.S.)',
508 | 'wf': 'WALLIS Y FUTUNA',
509 | 'eh': 'SAHARA OCCIDENTAL',
510 | 'ye': 'YEMEN',
511 | 'zm': 'ZAMBIA',
512 | 'zw': 'ZIMBABUE '
513 | }
514 | };
515 |
516 | getLocales(locale: string): CountryCode {
517 | if (locale && this.locales.hasOwnProperty(locale)) {
518 | // User given locale
519 | return this.locales[locale];
520 | }
521 | // Default: en
522 | return this.locales['en'];
523 | }
524 | }
525 |
--------------------------------------------------------------------------------
/projects/lib/src/lib/service/country.service.ts:
--------------------------------------------------------------------------------
1 | import {Injectable} from '@angular/core';
2 | import {Country} from "../interface/country.interface";
3 |
4 | @Injectable()
5 | export class CountryService {
6 |
7 | countries: Country[];
8 |
9 | constructor() {
10 | this.countries = [
11 | {
12 | name: '',
13 | dialCode: '994',
14 | countryCode: 'az'
15 | },
16 | {
17 | name: '',
18 | dialCode: '1242',
19 | countryCode: 'bs'
20 | },
21 | {
22 | name: '',
23 | dialCode: '973',
24 | countryCode: 'bh'
25 | },
26 | {
27 | name: '',
28 | dialCode: '880',
29 | countryCode: 'bd'
30 | },
31 | {
32 | name: '',
33 | dialCode: '1246',
34 | countryCode: 'bb'
35 | },
36 | {
37 | name: '',
38 | dialCode: '375',
39 | countryCode: 'by'
40 | },
41 | {
42 | name: '',
43 | dialCode: '32',
44 | countryCode: 'be'
45 | },
46 | {
47 | name: '',
48 | dialCode: '501',
49 | countryCode: 'bz'
50 | },
51 | {
52 | name: '',
53 | dialCode: '229',
54 | countryCode: 'bj'
55 | },
56 | {
57 | name: '',
58 | dialCode: '1441',
59 | countryCode: 'bm'
60 | },
61 | {
62 | name: '',
63 | dialCode: '975',
64 | countryCode: 'bt'
65 | },
66 | {
67 | name: '',
68 | dialCode: '591',
69 | countryCode: 'bo'
70 | },
71 | {
72 | name: '',
73 | dialCode: '387',
74 | countryCode: 'ba'
75 | },
76 | {
77 | name: '',
78 | dialCode: '267',
79 | countryCode: 'bw'
80 | },
81 | {
82 | name: '',
83 | dialCode: '55',
84 | countryCode: 'br'
85 | },
86 | {
87 | name: '',
88 | dialCode: '246',
89 | countryCode: 'io'
90 | },
91 | {
92 | name: '',
93 | dialCode: '1284',
94 | countryCode: 'vg'
95 | },
96 | {
97 | name: '',
98 | dialCode: '673',
99 | countryCode: 'bn'
100 | },
101 | {
102 | name: '',
103 | dialCode: '359',
104 | countryCode: 'bg'
105 | },
106 | {
107 | name: '',
108 | dialCode: '226',
109 | countryCode: 'bf'
110 | },
111 | {
112 | name: '',
113 | dialCode: '257',
114 | countryCode: 'bi'
115 | },
116 | {
117 | name: '',
118 | dialCode: '855',
119 | countryCode: 'kh'
120 | },
121 | {
122 | name: '',
123 | dialCode: '237',
124 | countryCode: 'cm'
125 | },
126 | {
127 | name: '',
128 | dialCode: '1',
129 | countryCode: 'ca'
130 | },
131 | {
132 | name: '',
133 | dialCode: '238',
134 | countryCode: 'cv'
135 | },
136 | {
137 | name: '',
138 | dialCode: '599',
139 | countryCode: 'bq'
140 | },
141 | {
142 | name: '',
143 | dialCode: '1345',
144 | countryCode: 'ky'
145 | },
146 | {
147 | name: '',
148 | dialCode: '236',
149 | countryCode: 'cf'
150 | },
151 | {
152 | name: '',
153 | dialCode: '235',
154 | countryCode: 'td'
155 | },
156 | {
157 | name: '',
158 | dialCode: '56',
159 | countryCode: 'cl'
160 | },
161 | {
162 | name: '',
163 | dialCode: '86',
164 | countryCode: 'cn'
165 | },
166 | {
167 | name: '',
168 | dialCode: '61',
169 | countryCode: 'au'
170 | },
171 | {
172 | name: '',
173 | dialCode: '57',
174 | countryCode: 'co'
175 | },
176 | {
177 | name: '',
178 | dialCode: '269',
179 | countryCode: 'km'
180 | },
181 | {
182 | name: '',
183 | dialCode: '243',
184 | countryCode: 'cd'
185 | },
186 | {
187 | name: '',
188 | dialCode: '242',
189 | countryCode: 'cg'
190 | },
191 | {
192 | name: '',
193 | dialCode: '682',
194 | countryCode: 'ck'
195 | },
196 | {
197 | name: '',
198 | dialCode: '506',
199 | countryCode: 'cr'
200 | },
201 | {
202 | name: '',
203 | dialCode: '225',
204 | countryCode: 'ci'
205 | },
206 | {
207 | name: '',
208 | dialCode: '385',
209 | countryCode: 'hr'
210 | },
211 | {
212 | name: '',
213 | dialCode: '53',
214 | countryCode: 'cu'
215 | },
216 | {
217 | name: '',
218 | dialCode: '599',
219 | countryCode: 'cw'
220 | },
221 | {
222 | name: '',
223 | dialCode: '357',
224 | countryCode: 'cy'
225 | },
226 | {
227 | name: '',
228 | dialCode: '420',
229 | countryCode: 'cz'
230 | },
231 | {
232 | name: '',
233 | dialCode: '45',
234 | countryCode: 'dk'
235 | },
236 | {
237 | name: '',
238 | dialCode: '253',
239 | countryCode: 'dj'
240 | },
241 | {
242 | name: '',
243 | dialCode: '1767',
244 | countryCode: 'dm'
245 | },
246 | {
247 | name: '',
248 | dialCode: '1',
249 | countryCode: 'do'
250 | },
251 | {
252 | name: '',
253 | dialCode: '593',
254 | countryCode: 'ec'
255 | },
256 | {
257 | name: '',
258 | dialCode: '20',
259 | countryCode: 'eg'
260 | },
261 | {
262 | name: '',
263 | dialCode: '503',
264 | countryCode: 'sv'
265 | },
266 | {
267 | name: '',
268 | dialCode: '240',
269 | countryCode: 'gq'
270 | },
271 | {
272 | name: '',
273 | dialCode: '291',
274 | countryCode: 'er'
275 | },
276 | {
277 | name: '',
278 | dialCode: '372',
279 | countryCode: 'ee'
280 | },
281 | {
282 | name: '',
283 | dialCode: '251',
284 | countryCode: 'et'
285 | },
286 | {
287 | name: '',
288 | dialCode: '500',
289 | countryCode: 'fk'
290 | },
291 | {
292 | name: '',
293 | dialCode: '298',
294 | countryCode: 'fo'
295 | },
296 | {
297 | name: '',
298 | dialCode: '679',
299 | countryCode: 'fj'
300 | },
301 | {
302 | name: '',
303 | dialCode: '358',
304 | countryCode: 'fi'
305 | },
306 | {
307 | name: '',
308 | dialCode: '33',
309 | countryCode: 'fr'
310 | },
311 | {
312 | name: '',
313 | dialCode: '594',
314 | countryCode: 'gf'
315 | },
316 | {
317 | name: '',
318 | dialCode: '689',
319 | countryCode: 'pf'
320 | },
321 | {
322 | name: '',
323 | dialCode: '241',
324 | countryCode: 'ga'
325 | },
326 | {
327 | name: '',
328 | dialCode: '220',
329 | countryCode: 'gm'
330 | },
331 | {
332 | name: '',
333 | dialCode: '995',
334 | countryCode: 'ge'
335 | },
336 | {
337 | name: '',
338 | dialCode: '49',
339 | countryCode: 'de'
340 | },
341 | {
342 | name: '',
343 | dialCode: '233',
344 | countryCode: 'gh'
345 | },
346 | {
347 | name: '',
348 | dialCode: '350',
349 | countryCode: 'gi'
350 | },
351 | {
352 | name: '',
353 | dialCode: '30',
354 | countryCode: 'gr'
355 | },
356 | {
357 | name: '',
358 | dialCode: '299',
359 | countryCode: 'gl'
360 | },
361 | {
362 | name: '',
363 | dialCode: '1473',
364 | countryCode: 'gd'
365 | },
366 | {
367 | name: '',
368 | dialCode: '590',
369 | countryCode: 'gp'
370 | },
371 | {
372 | name: '',
373 | dialCode: '1671',
374 | countryCode: 'gu'
375 | },
376 | {
377 | name: '',
378 | dialCode: '502',
379 | countryCode: 'gt'
380 | },
381 | {
382 | name: '',
383 | dialCode: '44',
384 | countryCode: 'gg'
385 | },
386 | {
387 | name: '',
388 | dialCode: '224',
389 | countryCode: 'gn'
390 | },
391 | {
392 | name: '',
393 | dialCode: '245',
394 | countryCode: 'gw'
395 | },
396 | {
397 | name: '',
398 | dialCode: '592',
399 | countryCode: 'gy'
400 | },
401 | {
402 | name: '',
403 | dialCode: '509',
404 | countryCode: 'ht'
405 | },
406 | {
407 | name: '',
408 | dialCode: '504',
409 | countryCode: 'hn'
410 | },
411 | {
412 | name: '',
413 | dialCode: '852',
414 | countryCode: 'hk'
415 | },
416 | {
417 | name: '',
418 | dialCode: '36',
419 | countryCode: 'hu'
420 | },
421 | {
422 | name: '',
423 | dialCode: '354',
424 | countryCode: 'is'
425 | },
426 | {
427 | name: '',
428 | dialCode: '91',
429 | countryCode: 'in'
430 | },
431 | {
432 | name: '',
433 | dialCode: '62',
434 | countryCode: 'id'
435 | },
436 | {
437 | name: '',
438 | dialCode: '98',
439 | countryCode: 'ir'
440 | },
441 | {
442 | name: '',
443 | dialCode: '964',
444 | countryCode: 'iq'
445 | },
446 | {
447 | name: '',
448 | dialCode: '353',
449 | countryCode: 'ie'
450 | },
451 | {
452 | name: '',
453 | dialCode: '44',
454 | countryCode: 'im'
455 | },
456 | {
457 | name: '',
458 | dialCode: '972',
459 | countryCode: 'il'
460 | },
461 | {
462 | name: '',
463 | dialCode: '39',
464 | countryCode: 'it'
465 | },
466 | {
467 | name: '',
468 | dialCode: '1876',
469 | countryCode: 'jm'
470 | },
471 | {
472 | name: '',
473 | dialCode: '81',
474 | countryCode: 'jp'
475 | },
476 | {
477 | name: '',
478 | dialCode: '44',
479 | countryCode: 'je'
480 | },
481 | {
482 | name: '',
483 | dialCode: '962',
484 | countryCode: 'jo'
485 | },
486 | {
487 | name: '',
488 | dialCode: '7',
489 | countryCode: 'kz'
490 | },
491 | {
492 | name: '',
493 | dialCode: '254',
494 | countryCode: 'ke'
495 | },
496 | {
497 | name: '',
498 | dialCode: '686',
499 | countryCode: 'ki'
500 | },
501 | {
502 | name: '',
503 | dialCode: '383',
504 | countryCode: 'xk'
505 | },
506 | {
507 | name: '',
508 | dialCode: '965',
509 | countryCode: 'kw'
510 | },
511 | {
512 | name: '',
513 | dialCode: '996',
514 | countryCode: 'kg'
515 | },
516 | {
517 | name: '',
518 | dialCode: '856',
519 | countryCode: 'la'
520 | },
521 | {
522 | name: '',
523 | dialCode: '371',
524 | countryCode: 'lv'
525 | },
526 | {
527 | name: '',
528 | dialCode: '961',
529 | countryCode: 'lb'
530 | },
531 | {
532 | name: '',
533 | dialCode: '266',
534 | countryCode: 'ls'
535 | },
536 | {
537 | name: '',
538 | dialCode: '231',
539 | countryCode: 'lr'
540 | },
541 | {
542 | name: '',
543 | dialCode: '218',
544 | countryCode: 'ly'
545 | },
546 | {
547 | name: '',
548 | dialCode: '423',
549 | countryCode: 'li'
550 | },
551 | {
552 | name: '',
553 | dialCode: '370',
554 | countryCode: 'lt'
555 | },
556 | {
557 | name: '',
558 | dialCode: '352',
559 | countryCode: 'lu'
560 | },
561 | {
562 | name: '',
563 | dialCode: '853',
564 | countryCode: 'mo'
565 | },
566 | {
567 | name: '',
568 | dialCode: '389',
569 | countryCode: 'mk'
570 | },
571 | {
572 | name: '',
573 | dialCode: '261',
574 | countryCode: 'mg'
575 | },
576 | {
577 | name: '',
578 | dialCode: '265',
579 | countryCode: 'mw'
580 | },
581 | {
582 | name: '',
583 | dialCode: '60',
584 | countryCode: 'my'
585 | },
586 | {
587 | name: '',
588 | dialCode: '960',
589 | countryCode: 'mv'
590 | },
591 | {
592 | name: '',
593 | dialCode: '223',
594 | countryCode: 'ml'
595 | },
596 | {
597 | name: '',
598 | dialCode: '356',
599 | countryCode: 'mt'
600 | },
601 | {
602 | name: '',
603 | dialCode: '692',
604 | countryCode: 'mh'
605 | },
606 | {
607 | name: '',
608 | dialCode: '596',
609 | countryCode: 'mq'
610 | },
611 | {
612 | name: '',
613 | dialCode: '222',
614 | countryCode: 'mr'
615 | },
616 | {
617 | name: '',
618 | dialCode: '230',
619 | countryCode: 'mu'
620 | },
621 | {
622 | name: '',
623 | dialCode: '262',
624 | countryCode: 'yt'
625 | },
626 | {
627 | name: '',
628 | dialCode: '52',
629 | countryCode: 'mx'
630 | },
631 | {
632 | name: '',
633 | dialCode: '691',
634 | countryCode: 'fm'
635 | },
636 | {
637 | name: '',
638 | dialCode: '373',
639 | countryCode: 'md'
640 | },
641 | {
642 | name: '',
643 | dialCode: '377',
644 | countryCode: 'mc'
645 | },
646 | {
647 | name: '',
648 | dialCode: '976',
649 | countryCode: 'mn'
650 | },
651 | {
652 | name: '',
653 | dialCode: '382',
654 | countryCode: 'me'
655 | },
656 | {
657 | name: '',
658 | dialCode: '1664',
659 | countryCode: 'ms'
660 | },
661 | {
662 | name: '',
663 | dialCode: '212',
664 | countryCode: 'ma'
665 | },
666 | {
667 | name: '',
668 | dialCode: '258',
669 | countryCode: 'mz'
670 | },
671 | {
672 | name: '',
673 | dialCode: '95',
674 | countryCode: 'mm'
675 | },
676 | {
677 | name: '',
678 | dialCode: '264',
679 | countryCode: 'na'
680 | },
681 | {
682 | name: '',
683 | dialCode: '674',
684 | countryCode: 'nr'
685 | },
686 | {
687 | name: '',
688 | dialCode: '977',
689 | countryCode: 'np'
690 | },
691 | {
692 | name: '',
693 | dialCode: '31',
694 | countryCode: 'nl'
695 | },
696 | {
697 | name: '',
698 | dialCode: '687',
699 | countryCode: 'nc'
700 | },
701 | {
702 | name: '',
703 | dialCode: '64',
704 | countryCode: 'nz'
705 | },
706 | {
707 | name: '',
708 | dialCode: '505',
709 | countryCode: 'ni'
710 | },
711 | {
712 | name: '',
713 | dialCode: '227',
714 | countryCode: 'ne'
715 | },
716 | {
717 | name: '',
718 | dialCode: '234',
719 | countryCode: 'ng'
720 | },
721 | {
722 | name: '',
723 | dialCode: '683',
724 | countryCode: 'nu'
725 | },
726 | {
727 | name: '',
728 | dialCode: '672',
729 | countryCode: 'nf'
730 | },
731 | {
732 | name: '',
733 | dialCode: '850',
734 | countryCode: 'kp'
735 | },
736 | {
737 | name: '',
738 | dialCode: '1670',
739 | countryCode: 'mp'
740 | },
741 | {
742 | name: '',
743 | dialCode: '47',
744 | countryCode: 'no'
745 | },
746 | {
747 | name: '',
748 | dialCode: '968',
749 | countryCode: 'om'
750 | },
751 | {
752 | name: '',
753 | dialCode: '92',
754 | countryCode: 'pk'
755 | },
756 | {
757 | name: '',
758 | dialCode: '680',
759 | countryCode: 'pw'
760 | },
761 | {
762 | name: '',
763 | dialCode: '970',
764 | countryCode: 'ps'
765 | },
766 | {
767 | name: '',
768 | dialCode: '507',
769 | countryCode: 'pa'
770 | },
771 | {
772 | name: '',
773 | dialCode: '675',
774 | countryCode: 'pg'
775 | },
776 | {
777 | name: '',
778 | dialCode: '595',
779 | countryCode: 'py'
780 | },
781 | {
782 | name: '',
783 | dialCode: '51',
784 | countryCode: 'pe'
785 | },
786 | {
787 | name: '',
788 | dialCode: '63',
789 | countryCode: 'ph'
790 | },
791 | {
792 | name: '',
793 | dialCode: '48',
794 | countryCode: 'pl'
795 | },
796 | {
797 | name: '',
798 | dialCode: '351',
799 | countryCode: 'pt'
800 | },
801 | {
802 | name: '',
803 | dialCode: '1',
804 | countryCode: 'pr'
805 | },
806 | {
807 | name: '',
808 | dialCode: '974',
809 | countryCode: 'qa'
810 | },
811 | {
812 | name: '',
813 | dialCode: '262',
814 | countryCode: 're'
815 | },
816 | {
817 | name: '',
818 | dialCode: '40',
819 | countryCode: 'ro'
820 | },
821 | {
822 | name: '',
823 | dialCode: '7',
824 | countryCode: 'ru'
825 | },
826 | {
827 | name: '',
828 | dialCode: '250',
829 | countryCode: 'rw'
830 | },
831 | {
832 | name: '',
833 | dialCode: '590',
834 | countryCode: 'bl'
835 | },
836 | {
837 | name: '',
838 | dialCode: '290',
839 | countryCode: 'sh'
840 | },
841 | {
842 | name: '',
843 | dialCode: '1869',
844 | countryCode: 'kn'
845 | },
846 | {
847 | name: '',
848 | dialCode: '1758',
849 | countryCode: 'lc'
850 | },
851 | {
852 | name: '',
853 | dialCode: '508',
854 | countryCode: 'pm'
855 | },
856 | {
857 | name: '',
858 | dialCode: '1784',
859 | countryCode: 'vc'
860 | },
861 | {
862 | name: '',
863 | dialCode: '685',
864 | countryCode: 'ws'
865 | },
866 | {
867 | name: '',
868 | dialCode: '378',
869 | countryCode: 'sm'
870 | },
871 | {
872 | name: '',
873 | dialCode: '239',
874 | countryCode: 'st'
875 | },
876 | {
877 | name: '',
878 | dialCode: '966',
879 | countryCode: 'sa'
880 | },
881 | {
882 | name: '',
883 | dialCode: '221',
884 | countryCode: 'sn'
885 | },
886 | {
887 | name: '',
888 | dialCode: '381',
889 | countryCode: 'rs'
890 | },
891 | {
892 | name: '',
893 | dialCode: '248',
894 | countryCode: 'sc'
895 | },
896 | {
897 | name: '',
898 | dialCode: '232',
899 | countryCode: 'sl'
900 | },
901 | {
902 | name: '',
903 | dialCode: '65',
904 | countryCode: 'sg'
905 | },
906 | {
907 | name: '',
908 | dialCode: '1721',
909 | countryCode: 'sx'
910 | },
911 | {
912 | name: '',
913 | dialCode: '421',
914 | countryCode: 'sk'
915 | },
916 | {
917 | name: '',
918 | dialCode: '386',
919 | countryCode: 'si'
920 | },
921 | {
922 | name: '',
923 | dialCode: '677',
924 | countryCode: 'sb'
925 | },
926 | {
927 | name: '',
928 | dialCode: '252',
929 | countryCode: 'so'
930 | },
931 | {
932 | name: '',
933 | dialCode: '27',
934 | countryCode: 'za'
935 | },
936 | {
937 | name: '',
938 | dialCode: '82',
939 | countryCode: 'kr'
940 | },
941 | {
942 | name: '',
943 | dialCode: '211',
944 | countryCode: 'ss'
945 | },
946 | {
947 | name: '',
948 | dialCode: '34',
949 | countryCode: 'es'
950 | },
951 | {
952 | name: '',
953 | dialCode: '94',
954 | countryCode: 'lk'
955 | },
956 | {
957 | name: '',
958 | dialCode: '249',
959 | countryCode: 'sd'
960 | },
961 | {
962 | name: '',
963 | dialCode: '597',
964 | countryCode: 'sr'
965 | },
966 | {
967 | name: '',
968 | dialCode: '47',
969 | countryCode: 'sj'
970 | },
971 | {
972 | name: '',
973 | dialCode: '268',
974 | countryCode: 'sz'
975 | },
976 | {
977 | name: '',
978 | dialCode: '46',
979 | countryCode: 'se'
980 | },
981 | {
982 | name: '',
983 | dialCode: '41',
984 | countryCode: 'ch'
985 | },
986 | {
987 | name: '',
988 | dialCode: '963',
989 | countryCode: 'sy'
990 | },
991 | {
992 | name: '',
993 | dialCode: '886',
994 | countryCode: 'tw'
995 | },
996 | {
997 | name: '',
998 | dialCode: '992',
999 | countryCode: 'tj'
1000 | },
1001 | {
1002 | name: '',
1003 | dialCode: '255',
1004 | countryCode: 'tz'
1005 | },
1006 | {
1007 | name: '',
1008 | dialCode: '66',
1009 | countryCode: 'th'
1010 | },
1011 | {
1012 | name: '',
1013 | dialCode: '670',
1014 | countryCode: 'tl'
1015 | },
1016 | {
1017 | name: '',
1018 | dialCode: '228',
1019 | countryCode: 'tg'
1020 | },
1021 | {
1022 | name: '',
1023 | dialCode: '690',
1024 | countryCode: 'tk'
1025 | },
1026 | {
1027 | name: '',
1028 | dialCode: '676',
1029 | countryCode: 'to'
1030 | },
1031 | {
1032 | name: '',
1033 | dialCode: '1868',
1034 | countryCode: 'tt'
1035 | },
1036 | {
1037 | name: '',
1038 | dialCode: '216',
1039 | countryCode: 'tn'
1040 | },
1041 | {
1042 | name: '',
1043 | dialCode: '90',
1044 | countryCode: 'tr'
1045 | },
1046 | {
1047 | name: '',
1048 | dialCode: '993',
1049 | countryCode: 'tm'
1050 | },
1051 | {
1052 | name: '',
1053 | dialCode: '1649',
1054 | countryCode: 'tc'
1055 | },
1056 | {
1057 | name: '',
1058 | dialCode: '688',
1059 | countryCode: 'tv'
1060 | },
1061 | {
1062 | name: '',
1063 | dialCode: '1340',
1064 | countryCode: 'vi'
1065 | },
1066 | {
1067 | name: '',
1068 | dialCode: '256',
1069 | countryCode: 'ug'
1070 | },
1071 | {
1072 | name: '',
1073 | dialCode: '380',
1074 | countryCode: 'ua'
1075 | },
1076 | {
1077 | name: '',
1078 | dialCode: '971',
1079 | countryCode: 'ae'
1080 | },
1081 | {
1082 | name: '',
1083 | dialCode: '44',
1084 | countryCode: 'gb'
1085 | },
1086 | {
1087 | name: '',
1088 | dialCode: '1',
1089 | countryCode: 'us'
1090 | },
1091 | {
1092 | name: '',
1093 | dialCode: '598',
1094 | countryCode: 'uy'
1095 | },
1096 | {
1097 | name: '',
1098 | dialCode: '998',
1099 | countryCode: 'uz'
1100 | },
1101 | {
1102 | name: '',
1103 | dialCode: '678',
1104 | countryCode: 'vu'
1105 | },
1106 | {
1107 | name: '',
1108 | dialCode: '39',
1109 | countryCode: 'va'
1110 | },
1111 | {
1112 | name: '',
1113 | dialCode: '58',
1114 | countryCode: 've'
1115 | },
1116 | {
1117 | name: '',
1118 | dialCode: '84',
1119 | countryCode: 'vn'
1120 | },
1121 | {
1122 | name: '',
1123 | dialCode: '681',
1124 | countryCode: 'wf'
1125 | },
1126 | {
1127 | name: '',
1128 | dialCode: '212',
1129 | countryCode: 'eh'
1130 | },
1131 | {
1132 | name: '',
1133 | dialCode: '967',
1134 | countryCode: 'ye'
1135 | },
1136 | {
1137 | name: '',
1138 | dialCode: '260',
1139 | countryCode: 'zm'
1140 | },
1141 | {
1142 | name: '',
1143 | dialCode: '263',
1144 | countryCode: 'zw'
1145 | },
1146 | {
1147 | name: '',
1148 | dialCode: '358',
1149 | countryCode: 'ax'
1150 | }
1151 | ];
1152 | }
1153 |
1154 | getCountries(): Country[] {
1155 | return this.countries;
1156 | }
1157 |
1158 |
1159 | }
1160 |
1161 |
1162 |
--------------------------------------------------------------------------------
/projects/lib/src/lib/component/int-phone-prefix/int-phone-prefix.component.scss:
--------------------------------------------------------------------------------
1 | .country-name {
2 | margin-left: 6px;
3 | }
4 |
5 | .dial-code {
6 | color: #999;
7 | }
8 |
9 | .scrollable-menu {
10 | height: auto;
11 | max-height: 200px;
12 | width: 350px;
13 | overflow-x: hidden;
14 | }
15 | .flagInput {
16 | padding: 0 !important;
17 | }
18 |
19 | .input-group-addon {
20 | text-align: left;
21 | }
22 |
23 | .btn-flag {
24 | border-color: white;
25 | }
26 |
27 | .btn:hover, .btn:focus{
28 | background-color: white;
29 | }
30 |
31 | .defaultCountry {
32 | display:inline-block;
33 | width:15px;
34 | height:15px;
35 | }
36 |
37 | .list-group {
38 | margin-bottom: 0;
39 | }
40 |
41 |
42 | /* Dropdown Button */
43 | .dropbtn {
44 | background-color: white;
45 | color: white;
46 | border: none;
47 | cursor: pointer;
48 | }
49 |
50 | .dropdown {
51 | position: relative;
52 | display: inline-block;
53 | }
54 |
55 | .dropdown-content {
56 | position: absolute;
57 | background-color: #f9f9f9;
58 | min-width: 160px;
59 | box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
60 | z-index: 1000;
61 | }
62 |
63 | .dropdown-content a {
64 | color: black;
65 | padding: 12px 16px;
66 | text-decoration: none;
67 | display: block;
68 | }
69 |
70 | /*!
71 | * Generated with CSS Flag Sprite generator (https://www.flag-sprites.com/) -
72 | */
73 | .flag{display:inline-block;position: relative;width:16px;height:11px;background:url('') no-repeat}.flag.flag-gu{background-position:-96px -55px}.flag.flag-mn{background-position:-208px -88px}.flag.flag-va{background-position:-48px -154px}.flag.flag-tibet{background-position:-32px -143px}.flag.flag-fo{background-position:-64px -44px}.flag.flag-th{background-position:-16px -143px}.flag.flag-tr{background-position:-144px -143px}.flag.flag-tl{background-position:-80px -143px}.flag.flag-kz{background-position:-144px -77px}.flag.flag-zm{background-position:-16px -165px}.flag.flag-uz{background-position:-32px -154px}.flag.flag-dk{background-position:-64px -33px}.flag.flag-scotland{background-position:-176px -121px}.flag.flag-gi{background-position:-224px -44px}.flag.flag-gy{background-position:-128px -55px}.flag.flag-bj{background-position:-112px -11px}.flag.flag-fr{background-position:-80px -44px}.flag.flag-mo{background-position:-224px -88px}.flag.flag-ir{background-position:-112px -66px}.flag.flag-io{background-position:-80px -66px}.flag.flag-tm{background-position:-96px -143px}.flag.flag-ch{background-position:-96px -22px}.flag.flag-mt{background-position:-32px -99px}.flag.flag-nl{background-position:-240px -99px}.flag.flag-gp{background-position:-16px -55px}.flag.flag-im{background-position:-48px -66px}.flag.flag-tv{background-position:-176px -143px}.flag.flag-mu{background-position:-48px -99px}.flag.flag-pe{background-position:-96px -110px}.flag.flag-vi{background-position:-112px -154px}.flag.flag-hn{background-position:-176px -55px}.flag.flag-ss{background-position:-128px -132px}.flag.flag-ae{background-position:-16px 0}.flag.flag-td{background-position:-240px -132px}.flag.flag-pw{background-position:0 -121px}.flag.flag-nu{background-position:-32px -110px}.flag.flag-bt{background-position:-208px -11px}.flag.flag-ms{background-position:-16px -99px}.flag.flag-cv{background-position:-240px -22px}.flag.flag-es{background-position:-224px -33px}.flag.flag-mh{background-position:-144px -88px}.flag.flag-la{background-position:-160px -77px}.flag.flag-vn{background-position:-128px -154px}.flag.flag-py{background-position:-16px -121px}.flag.flag-br{background-position:-176px -11px}.flag.flag-ye{background-position:-224px -154px}.flag.flag-ie{background-position:0 -66px}.flag.flag-gh{background-position:-208px -44px}.flag.flag-cg{background-position:-80px -22px}.flag.flag-cu{background-position:-224px -22px}.flag.flag-hu{background-position:-224px -55px}.flag.flag-sg{background-position:-224px -121px}.flag.flag-at{background-position:-176px 0}.flag.flag-lk{background-position:-224px -77px}.flag.flag-vu{background-position:-144px -154px}.flag.flag-bo{background-position:-160px -11px}.flag.flag-jo{background-position:-208px -66px}.flag.flag-er{background-position:-208px -33px}.flag.flag-za{background-position:-256px -154px}.flag.flag-rs{background-position:-80px -121px}.flag.flag-nr{background-position:-16px -110px}.flag.flag-ls{background-position:-256px -77px}.flag.flag-jm{background-position:-192px -66px}.flag.flag-tz{background-position:-208px -143px}.flag.flag-ki{background-position:-16px -77px}.flag.flag-sj{background-position:0 -132px}.flag.flag-cz{background-position:-16px -33px}.flag.flag-pg{background-position:-128px -110px}.flag.flag-lv{background-position:-32px -88px}.flag.flag-do{background-position:-96px -33px}.flag.flag-lu{background-position:-16px -88px}.flag.flag-no{background-position:-256px -99px}.flag.flag-kw{background-position:-112px -77px}.flag.flag-mx{background-position:-96px -99px}.flag.flag-yt{background-position:-240px -154px}.flag.flag-ly{background-position:-48px -88px}.flag.flag-cy{background-position:0 -33px}.flag.flag-ph{background-position:-144px -110px}.flag.flag-my{background-position:-112px -99px}.flag.flag-sm{background-position:-48px -132px}.flag.flag-et{background-position:-240px -33px}.flag.flag-ru{background-position:-96px -121px}.flag.flag-tj{background-position:-48px -143px}.flag.flag-ai{background-position:-64px 0}.flag.flag-pl{background-position:-176px -110px}.flag.flag-kp{background-position:-64px -77px}.flag.flag-uy{background-position:-16px -154px}.flag.flag-gb{background-position:-112px -44px}.flag.flag-gs{background-position:-64px -55px}.flag.flag-kurdistan{background-position:-96px -77px}.flag.flag-rw{background-position:-112px -121px}.flag.flag-ec{background-position:-128px -33px}.flag.flag-mm{background-position:-192px -88px}.flag.flag-pa{background-position:-80px -110px}.flag.flag-wales{background-position:-160px -154px}.flag.flag-kg{background-position:-256px -66px}.flag.flag-ve{background-position:-80px -154px}.flag.flag-tk{background-position:-64px -143px}.flag.flag-ca{background-position:-16px -22px}.flag.flag-is{background-position:-128px -66px}.flag.flag-ke{background-position:-240px -66px}.flag.flag-ro{background-position:-64px -121px}.flag.flag-gq{background-position:-32px -55px}.flag.flag-pt{background-position:-256px -110px}.flag.flag-tf{background-position:-256px -132px}.flag.flag-ad{background-position:0 0}.flag.flag-sk{background-position:-16px -132px}.flag.flag-pm{background-position:-192px -110px}.flag.flag-om{background-position:-64px -110px}.flag.flag-an{background-position:-112px 0}.flag.flag-ws{background-position:-192px -154px}.flag.flag-sh{background-position:-240px -121px}.flag.flag-mp{background-position:-240px -88px}.flag.flag-gt{background-position:-80px -55px}.flag.flag-cf{background-position:-64px -22px}.flag.flag-zanzibar{background-position:0 -165px}.flag.flag-mw{background-position:-80px -99px}.flag.flag-catalonia{background-position:-32px -22px}.flag.flag-ug{background-position:-240px -143px}.flag.flag-je{background-position:-176px -66px}.flag.flag-km{background-position:-32px -77px}.flag.flag-in{background-position:-64px -66px}.flag.flag-bf{background-position:-48px -11px}.flag.flag-mc{background-position:-80px -88px}.flag.flag-sy{background-position:-192px -132px}.flag.flag-sn{background-position:-64px -132px}.flag.flag-kr{background-position:-80px -77px}.flag.flag-eu{background-position:-256px -33px}.flag.flag-bn{background-position:-144px -11px}.flag.flag-st{background-position:-144px -132px}.flag.flag-england{background-position:-192px -33px}.flag.flag-lc{background-position:-192px -77px}.flag.flag-dm{background-position:-80px -33px}.flag.flag-be{background-position:-32px -11px}.flag.flag-ni{background-position:-224px -99px}.flag.flag-ua{background-position:-224px -143px}.flag.flag-mz{background-position:-128px -99px}.flag.flag-pf{background-position:-112px -110px}.flag.flag-tn{background-position:-112px -143px}.flag.flag-ee{background-position:-144px -33px}.flag.flag-xk{background-position:-208px -154px}.flag.flag-sx{background-position:-176px -132px}.flag.flag-sd{background-position:-192px -121px}.flag.flag-gd{background-position:-128px -44px}.flag.flag-ci{background-position:-112px -22px}.flag.flag-sz{background-position:-208px -132px}.flag.flag-cl{background-position:-144px -22px}.flag.flag-fi{background-position:0 -44px}.flag.flag-ga{background-position:-96px -44px}.flag.flag-jp{background-position:-224px -66px}.flag.flag-de{background-position:-32px -33px}.flag.flag-np{background-position:0 -110px}.flag.flag-re{background-position:-48px -121px}.flag.flag-bg{background-position:-64px -11px}.flag.flag-sc{background-position:-160px -121px}.flag.flag-ng{background-position:-208px -99px}.flag.flag-qa{background-position:-32px -121px}.flag.flag-mk{background-position:-160px -88px}.flag.flag-aw{background-position:-208px 0}.flag.flag-kn{background-position:-48px -77px}.flag.flag-al{background-position:-80px 0}.flag.flag-bw{background-position:-240px -11px}.flag.flag-um{background-position:-256px -143px}.flag.flag-ky{background-position:-128px -77px}.flag.flag-tt{background-position:-160px -143px}.flag.flag-so{background-position:-80px -132px}.flag.flag-lt{background-position:0 -88px}.flag.flag-by{background-position:-256px -11px}.flag.flag-bb{background-position:0 -11px}.flag.flag-us{background-position:0 -154px}.flag.flag-md{background-position:-96px -88px}.flag.flag-ag{background-position:-48px 0}.flag.flag-hm{background-position:-160px -55px}.flag.flag-as{background-position:-160px 0}.flag.flag-eg{background-position:-160px -33px}.flag.flag-sv{background-position:-160px -132px}.flag.flag-sl{background-position:-32px -132px}.flag.flag-fk{background-position:-32px -44px}.flag.flag-am{background-position:-96px 0}.flag.flag-ck{background-position:-128px -22px}.flag.flag-tw{background-position:-192px -143px}.flag.flag-kh{background-position:0 -77px}.flag.flag-to{background-position:-128px -143px}.flag.flag-se{background-position:-208px -121px}.flag.flag-cd{background-position:-48px -22px}.flag.flag-pn{background-position:-208px -110px}.flag.flag-gr{background-position:-48px -55px}.flag.flag-id{background-position:-256px -55px}.flag.flag-vc{background-position:-64px -154px}.flag.flag-somaliland{background-position:-96px -132px}.flag.flag-bi{background-position:-96px -11px}.flag.flag-pk{background-position:-160px -110px}.flag.flag-pr{background-position:-224px -110px}.flag.flag-bd{background-position:-16px -11px}.flag.flag-co{background-position:-192px -22px}.flag.flag-fm{background-position:-48px -44px}.flag.flag-bm{background-position:-128px -11px}.flag.flag-ar{background-position:-144px 0}.flag.flag-bv{background-position:-224px -11px}.flag.flag-sb{background-position:-144px -121px}.flag.flag-mq{background-position:-256px -88px}.flag.flag-eh{background-position:-176px -33px}.flag.flag-bh{background-position:-80px -11px}.flag.flag-it{background-position:-144px -66px}.flag.flag-hr{background-position:-192px -55px}.flag.flag-sa{background-position:-128px -121px}.flag.flag-mv{background-position:-64px -99px}.flag.flag-mg{background-position:-128px -88px}.flag.flag-dz{background-position:-112px -33px}.flag.flag-gg{background-position:-192px -44px}.flag.flag-gm{background-position:-256px -44px}.flag.flag-af{background-position:-32px 0}.flag.flag-li{background-position:-208px -77px}.flag.flag-sr{background-position:-112px -132px}.flag.flag-vg{background-position:-96px -154px}.flag.flag-cr{background-position:-208px -22px}.flag.flag-tc{background-position:-224px -132px}.flag.flag-ao{background-position:-128px 0}.flag.flag-ma{background-position:-64px -88px}.flag.flag-mr{background-position:0 -99px}.flag.flag-gn{background-position:0 -55px}.flag.flag-ne{background-position:-176px -99px}.flag.flag-nf{background-position:-192px -99px}.flag.flag-wf{background-position:-176px -154px}.flag.flag-hk{background-position:-144px -55px}.flag.flag-gf{background-position:-160px -44px}.flag.flag-ps{background-position:-240px -110px}.flag.flag-ic{background-position:-240px -55px}.flag.flag-cw{background-position:-256px -22px}.flag.flag-ml{background-position:-176px -88px}.flag.flag-ax{background-position:-224px 0}.flag.flag-gl{background-position:-240px -44px}.flag.flag-dj{background-position:-48px -33px}.flag.flag-cn{background-position:-176px -22px}.flag.flag-ht{background-position:-208px -55px}.flag.flag-lr{background-position:-240px -77px}.flag.flag-tg{background-position:0 -143px}.flag.flag-ba{background-position:-256px 0}.flag.flag-ge{background-position:-144px -44px}.flag.flag-bz{background-position:0 -22px}.flag.flag-au{background-position:-192px 0}.flag.flag-iq{background-position:-96px -66px}.flag.flag-cm{background-position:-160px -22px}.flag.flag-gw{background-position:-112px -55px}.flag.flag-az{background-position:-240px 0}.flag.flag-na{background-position:-144px -99px}.flag.flag-fj{background-position:-16px -44px}.flag.flag-zw{background-position:-32px -165px}.flag.flag-bs{background-position:-192px -11px}.flag.flag-il{background-position:-16px -66px}.flag.flag-nz{background-position:-48px -110px}.flag.flag-me{background-position:-112px -88px}.flag.flag-si{background-position:-256px -121px}.flag.flag-nc{background-position:-160px -99px}.flag.flag-lb{background-position:-176px -77px}
74 |
75 |
--------------------------------------------------------------------------------