UNPKG

ng-ptplibraries

Version:

192 lines (188 loc) 14.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import { Component, Input, forwardRef } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { CountriesService } from '../../services/countries.service'; import { find } from 'lodash'; export class PTPPhoneNumberComponent { /** * @param {?} countriesService */ constructor(countriesService) { this.countriesService = countriesService; this.countryCode = null; this.countries = null; this.selectedCountry = null; this.propagateChange = (_) => { }; this.onTouched = () => { }; } /** * @return {?} */ ngOnInit() { this.initializeCountries(); } /** * @return {?} */ get phoneNumber() { return this._phoneNumber; } /** * @param {?} val * @return {?} */ set phoneNumber(val) { this._phoneNumber = val; this.propagateChange(this._phoneNumber); } /** * Resets Phone number component * @return {?} */ reset() { this.initializeCountries(); this._phoneNumber = null; this.propagateChange(this._phoneNumber); } /** * @param {?} value * @return {?} */ writeValue(value) { if (value !== undefined) { this.phoneNumber = value; } } /** * @param {?} fn * @return {?} */ registerOnChange(fn) { this.propagateChange = fn; } /** * @param {?} fn * @return {?} */ registerOnTouched(fn) { this.onTouched = fn; } /** * @param {?} country * @return {?} */ getCountry(country) { this.selectedCountry = country; this.countryCode = this.selectedCountry.callingCodes[0]; this.propagateChange(this._phoneNumber); } /** * @return {?} */ getPhoneNumber() { return '+(' + this.countryCode + ')' + this._phoneNumber; } /** * @return {?} */ initializeCountries() { this.countriesService.GetCountries() .subscribe(res => { this.countries = res; this.selectedCountry = find(res, { alpha2Code: 'US' }); this.countryCode = this.selectedCountry.callingCodes[0]; }, err => { console.log(err); }); } } PTPPhoneNumberComponent.decorators = [ { type: Component, args: [{ selector: 'ptp-phonenumber-field', template: `<label>{{ label }}</label> <div class="input-group"> <div class="input-group-prepend"> <button class="btn btn-light btn-sm dropdown-toggle border" type="button" data-toggle="dropdown"> <img src="{{ selectedCountry?.flag }}" style="width: 2em">&nbsp;+{{ selectedCountry?.callingCodes }} </button> <div class="dropdown-menu pb-0" style="width: 115%;"> <li class="p-2 border-right-1"> <input type="text" class="form-control form-control-sm" placeholder="Search" [(ngModel)]="searchCountry"> </li> <div style="height: 200px; overflow-y: scroll;"> <div *ngFor="let country of countries | searchfilter: searchCountry as result"> <li style="cursor: pointer;" class="dropdown-item p-2" (click)="getCountry(country)"> <img src="{{ country.flag }}" style="width: 2em">&nbsp; {{ country.name }}&nbsp;&nbsp; <span class="text-dark">(+{{ country.callingCodes }})</span> </li> </div> </div> </div> </div> <input type="text" class="form-control form-control-sm" maxlength="15" [numberOnly]="true" [(ngModel)]="phoneNumber" [ngClass]="{'is-invalid': validators?.required && isTouched }" (blur)="onTouched($event)" data-toggle="popover" data-trigger="focus" [attr.data-content]="helpMessage" placeholder="{{placeholder}}" > <div *ngIf="validators?.required && isTouched" class="invalid-feedback"> {{ validators?.required }} </div> </div> `, // tslint:disable-next-line:use-host-property-decorator host: { '(blur)': 'onTouched($event)' }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => PTPPhoneNumberComponent), multi: true } ] },] }, ]; /** @nocollapse */ PTPPhoneNumberComponent.ctorParameters = () => [ { type: CountriesService } ]; PTPPhoneNumberComponent.propDecorators = { _phoneNumber: [{ type: Input, args: ['phoneNumber',] }], searchCountry: [{ type: Input, args: ['searchCountry',] }], validators: [{ type: Input }], isTouched: [{ type: Input }], helpMessage: [{ type: Input, args: ['helpMessage',] }], placeholder: [{ type: Input, args: ['placeholder',] }], label: [{ type: Input, args: ['label',] }] }; if (false) { /** @type {?} */ PTPPhoneNumberComponent.prototype.countryCode; /** @type {?} */ PTPPhoneNumberComponent.prototype.countries; /** @type {?} */ PTPPhoneNumberComponent.prototype.selectedCountry; /** @type {?} */ PTPPhoneNumberComponent.prototype._phoneNumber; /** @type {?} */ PTPPhoneNumberComponent.prototype.searchCountry; /** @type {?} */ PTPPhoneNumberComponent.prototype.validators; /** @type {?} */ PTPPhoneNumberComponent.prototype.isTouched; /** @type {?} */ PTPPhoneNumberComponent.prototype.helpMessage; /** @type {?} */ PTPPhoneNumberComponent.prototype.placeholder; /** @type {?} */ PTPPhoneNumberComponent.prototype.label; /** @type {?} */ PTPPhoneNumberComponent.prototype.propagateChange; /** @type {?} */ PTPPhoneNumberComponent.prototype.onTouched; /** @type {?} */ PTPPhoneNumberComponent.prototype.countriesService; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"phone-number.component.js","sourceRoot":"ng://ng-ptplibraries/","sources":["lib/components/phonenumber-field/phone-number.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, forwardRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { CountriesService } from '../../services/countries.service';\nimport { find } from 'lodash';\n\n\n@Component({\n    selector: 'ptp-phonenumber-field',\n    template: `<label>{{ label }}</label>\n<div class=\"input-group\">\n    <div class=\"input-group-prepend\">\n        <button class=\"btn btn-light btn-sm dropdown-toggle border\" type=\"button\" data-toggle=\"dropdown\">\n            <img src=\"{{ selectedCountry?.flag }}\" style=\"width: 2em\">&nbsp;+{{ selectedCountry?.callingCodes }} </button>\n        <div class=\"dropdown-menu pb-0\" style=\"width: 115%;\">\n            <li class=\"p-2 border-right-1\">\n                <input type=\"text\" class=\"form-control form-control-sm\" placeholder=\"Search\" [(ngModel)]=\"searchCountry\">\n            </li>\n            <div style=\"height: 200px; overflow-y: scroll;\">\n                <div *ngFor=\"let country of countries | searchfilter: searchCountry as result\">\n                    <li style=\"cursor: pointer;\" class=\"dropdown-item p-2\" (click)=\"getCountry(country)\">\n                        <img src=\"{{ country.flag }}\" style=\"width: 2em\">&nbsp; {{ country.name }}&nbsp;&nbsp;\n                        <span class=\"text-dark\">(+{{ country.callingCodes }})</span>\n                    </li>\n                </div>\n            </div>  \n        </div>\n    </div>\n    <input type=\"text\" class=\"form-control form-control-sm\" \n    maxlength=\"15\"\n    [numberOnly]=\"true\"\n    [(ngModel)]=\"phoneNumber\" \n    [ngClass]=\"{'is-invalid': validators?.required && isTouched }\" \n    (blur)=\"onTouched($event)\"\n    data-toggle=\"popover\" \n    data-trigger=\"focus\" \n    [attr.data-content]=\"helpMessage\" \n    placeholder=\"{{placeholder}}\"\n    >\n    <div *ngIf=\"validators?.required && isTouched\" class=\"invalid-feedback\">\n        {{ validators?.required }}\n    </div>\n  </div>\n\n\n\n`,\n    // tslint:disable-next-line:use-host-property-decorator\n    host: {'(blur)': 'onTouched($event)'},\n    providers: [\n        { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => PTPPhoneNumberComponent), multi: true }\n    ]\n})\n\nexport class PTPPhoneNumberComponent implements OnInit, ControlValueAccessor  {\n\n    countryCode = null;\n    countries = null;\n    selectedCountry = null;\n\n    // tslint:disable-next-line:no-input-rename\n    @Input('phoneNumber') _phoneNumber;\n    @Input('searchCountry') searchCountry;\n\n    @Input() public validators: any;\n    @Input() public isTouched: boolean;\n    @Input('helpMessage') public helpMessage: string;\n    @Input('placeholder') public placeholder: string;\n    @Input('label') public label: string;\n\n    propagateChange = (_: any) => { };\n    onTouched: any = () => { };\n\n    constructor(\n        private countriesService: CountriesService\n    ) {}\n\n    ngOnInit() {\n        this.initializeCountries();\n    }\n\n    get phoneNumber() {\n        return this._phoneNumber;\n    }\n\n    set phoneNumber(val) {\n        this._phoneNumber = val;\n        this.propagateChange(this._phoneNumber);\n    }\n\n    /** Resets Phone number component */\n    reset() {\n        this.initializeCountries();\n        this._phoneNumber = null;\n        this.propagateChange(this._phoneNumber);\n    }\n\n    writeValue(value: any) {\n        if (value !== undefined) {\n            this.phoneNumber = value;\n        }\n    }\n\n    registerOnChange(fn) {\n        this.propagateChange = fn;\n    }\n\n    registerOnTouched(fn) {\n        this.onTouched = fn;\n    }\n\n    getCountry(country: Object) {\n        this.selectedCountry = country;\n        this.countryCode = this.selectedCountry.callingCodes[0];\n        this.propagateChange(this._phoneNumber);\n    }\n\n    getPhoneNumber() {\n        return '+(' + this.countryCode + ')' + this._phoneNumber;\n    }\n\n    initializeCountries() {\n        this.countriesService.GetCountries()\n            .subscribe(res => {\n                this.countries = res;\n                this.selectedCountry = find(res, { alpha2Code: 'US' });\n                this.countryCode = this.selectedCountry.callingCodes[0];\n            }, err => {\n                console.log(err);\n            });\n    }\n\n}\n"]}