ng-ptplibraries
Version:
192 lines (188 loc) • 14.9 kB
JavaScript
/**
* @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"> +{{ 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"> {{ country.name }}
<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"]}