@smart-webcomponents-angular/phoneinput 10.3.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +66 -0
- package/bundles/smart-webcomponents-angular-phoneinput.umd.js +1001 -0
- package/bundles/smart-webcomponents-angular-phoneinput.umd.min.js +25 -0
- package/common/i18n.phonenumbers.min.js +501 -0
- package/common/runtime.js +748 -0
- package/esm2015/phoneinput/public_api.js +3 -0
- package/esm2015/phoneinput/smart-webcomponents-angular-phoneinput.js +15 -0
- package/esm2015/phoneinput/smart.element.js +83 -0
- package/esm2015/phoneinput/smart.phoneinput.js +434 -0
- package/esm2015/phoneinput/smart.phoneinput.module.js +13 -0
- package/fesm2015/smart-webcomponents-angular-phoneinput.js +540 -0
- package/fesm2015/smart-webcomponents-angular-phoneinput.js.map +1 -0
- package/images/dropable_zone_image.svg +25 -0
- package/images/error.png +0 -0
- package/images/flags.png +0 -0
- package/images/icons-sprite.svg +85 -0
- package/images/icons-stack.svg +132 -0
- package/images/info.png +0 -0
- package/images/magnifier.png +0 -0
- package/images/mail.png +0 -0
- package/images/radial.svg +1 -0
- package/images/success.png +0 -0
- package/images/time.png +0 -0
- package/images/warning.png +0 -0
- package/index.d.ts +31510 -0
- package/package.json +64 -0
- package/phoneinput/public_api.d.ts +2 -0
- package/phoneinput/smart-webcomponents-angular-phoneinput.d.ts +5 -0
- package/phoneinput/smart-webcomponents-angular-phoneinput.metadata.json +1 -0
- package/phoneinput/smart.element.d.ts +36 -0
- package/phoneinput/smart.phoneinput.d.ts +144 -0
- package/phoneinput/smart.phoneinput.module.d.ts +2 -0
- package/source/modules/smart.input.js +15 -0
- package/source/modules/smart.phoneinput.js +18 -0
- package/source/smart.button.js +6 -0
- package/source/smart.countryinput.js +6 -0
- package/source/smart.element.js +6 -0
- package/source/smart.input.js +6 -0
- package/source/smart.phoneinput.js +6 -0
- package/source/smart.scrollbar.js +6 -0
- package/styles/font/smart-icons.eot +0 -0
- package/styles/font/smart-icons.svg +278 -0
- package/styles/font/smart-icons.ttf +0 -0
- package/styles/font/smart-icons.woff +0 -0
- package/styles/font/smart-icons.woff2 +0 -0
- package/styles/smart.base.css +4 -0
- package/styles/smart.common.css +1 -0
- package/styles/smart.phoneinput.css +3 -0
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './smart.phoneinput';
|
|
2
|
+
export * from './smart.phoneinput.module';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Bob25laW5wdXQvc3JjL3B1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiXG5leHBvcnQgKiBmcm9tICcuL3NtYXJ0LnBob25laW5wdXQnO1xuZXhwb3J0ICogZnJvbSAnLi9zbWFydC5waG9uZWlucHV0Lm1vZHVsZSc7XG4iXX0=
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
|
|
2
|
+
if (!window['Smart']) {
|
|
3
|
+
window['Smart'] = { RenderMode: 'manual' };
|
|
4
|
+
}
|
|
5
|
+
else {
|
|
6
|
+
window['Smart'].RenderMode = 'manual';
|
|
7
|
+
}
|
|
8
|
+
import './../../source/modules/smart.phoneinput';
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Generated bundle index. Do not edit.
|
|
12
|
+
*/
|
|
13
|
+
export * from './public_api';
|
|
14
|
+
export { BaseElement as ɵa } from './smart.element';
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnQtd2ViY29tcG9uZW50cy1hbmd1bGFyLXBob25laW5wdXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9waG9uZWlucHV0L3NyYy9zbWFydC13ZWJjb21wb25lbnRzLWFuZ3VsYXItcGhvbmVpbnB1dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyxXQUFXLElBQUksRUFBRSxFQUFDLE1BQU0saUJBQWlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljX2FwaSc7XG5cbmV4cG9ydCB7QmFzZUVsZW1lbnQgYXMgybVhfSBmcm9tICcuL3NtYXJ0LmVsZW1lbnQnOyJdfQ==
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { Input, Output, EventEmitter } from '@angular/core';
|
|
2
|
+
export class BaseElement {
|
|
3
|
+
constructor(ref) {
|
|
4
|
+
this.onCreate = new EventEmitter();
|
|
5
|
+
this.onReady = new EventEmitter();
|
|
6
|
+
this.onAttach = new EventEmitter();
|
|
7
|
+
this.onDetach = new EventEmitter();
|
|
8
|
+
const that = this;
|
|
9
|
+
this.nativeElement = ref.nativeElement;
|
|
10
|
+
that.nativeElement.onAttached = () => {
|
|
11
|
+
that.onAttach.emit(that.nativeElement);
|
|
12
|
+
};
|
|
13
|
+
that.nativeElement.onDetached = () => {
|
|
14
|
+
that.onDetach.emit(that.nativeElement);
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
addEventListener(type, listener, options = false) {
|
|
18
|
+
this.nativeElement.addEventListener(type, listener, options);
|
|
19
|
+
}
|
|
20
|
+
removeEventListener(type, listener, options = false) {
|
|
21
|
+
this.nativeElement.removeEventListener(type, listener, options);
|
|
22
|
+
}
|
|
23
|
+
dispatchEvent(event) {
|
|
24
|
+
return this.nativeElement.dispatchEvent(event);
|
|
25
|
+
}
|
|
26
|
+
blur() {
|
|
27
|
+
this.nativeElement.blur();
|
|
28
|
+
}
|
|
29
|
+
click() {
|
|
30
|
+
this.nativeElement.click();
|
|
31
|
+
}
|
|
32
|
+
focus(options) {
|
|
33
|
+
this.nativeElement.focus(options);
|
|
34
|
+
}
|
|
35
|
+
/** @description Sets or gets the language. Used in conjunction with the property messages. */
|
|
36
|
+
get locale() {
|
|
37
|
+
return this.nativeElement ? this.nativeElement.locale : undefined;
|
|
38
|
+
}
|
|
39
|
+
set locale(value) {
|
|
40
|
+
this.nativeElement ? this.nativeElement.locale = value : undefined;
|
|
41
|
+
}
|
|
42
|
+
/** @description Callback used to customize the format of the messages that are returned from the Localization Module. */
|
|
43
|
+
get localizeFormatFunction() {
|
|
44
|
+
return this.nativeElement ? this.nativeElement.localizeFormatFunction : undefined;
|
|
45
|
+
}
|
|
46
|
+
set localizeFormatFunction(value) {
|
|
47
|
+
this.nativeElement ? this.nativeElement.localizeFormatFunction = value : undefined;
|
|
48
|
+
}
|
|
49
|
+
/** @description Sets or gets an object specifying strings used in the widget that can be localized. Used in conjunction with the property locale. */
|
|
50
|
+
get messages() {
|
|
51
|
+
return this.nativeElement ? this.nativeElement.messages : undefined;
|
|
52
|
+
}
|
|
53
|
+
set messages(value) {
|
|
54
|
+
this.nativeElement ? this.nativeElement.messages = value : undefined;
|
|
55
|
+
}
|
|
56
|
+
/** @description Sets or gets the value indicating whether the element is aligned to support locales using right-to-left fonts. */
|
|
57
|
+
get rightToLeft() {
|
|
58
|
+
return this.nativeElement ? this.nativeElement.rightToLeft : undefined;
|
|
59
|
+
}
|
|
60
|
+
set rightToLeft(value) {
|
|
61
|
+
this.nativeElement ? this.nativeElement.rightToLeft = value : undefined;
|
|
62
|
+
}
|
|
63
|
+
/** @description Determines the theme. Theme defines the look of the element */
|
|
64
|
+
get theme() {
|
|
65
|
+
return this.nativeElement ? this.nativeElement.theme : undefined;
|
|
66
|
+
}
|
|
67
|
+
set theme(value) {
|
|
68
|
+
this.nativeElement ? this.nativeElement.theme = value : undefined;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
BaseElement.propDecorators = {
|
|
72
|
+
onCreate: [{ type: Output }],
|
|
73
|
+
onReady: [{ type: Output }],
|
|
74
|
+
onAttach: [{ type: Output }],
|
|
75
|
+
onDetach: [{ type: Output }],
|
|
76
|
+
locale: [{ type: Input }],
|
|
77
|
+
localizeFormatFunction: [{ type: Input }],
|
|
78
|
+
messages: [{ type: Input }],
|
|
79
|
+
rightToLeft: [{ type: Input }],
|
|
80
|
+
theme: [{ type: Input }]
|
|
81
|
+
};
|
|
82
|
+
export const Smart = window.Smart;
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart.element.js","sourceRoot":"","sources":["../../../phoneinput/src/smart.element.ts"],"names":[],"mappings":"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","sourcesContent":["\ndeclare global {\n    interface Window {\n        Smart: any;\n}\n}\n\n\nimport { ElementRef, Input, Output, EventEmitter } from '@angular/core';\nimport { ElementRenderMode } from './../index';\n\nexport class BaseElement {\n    constructor(ref: ElementRef) {\n        const that = this;\n        this.nativeElement = ref.nativeElement as any;\n\n        that.nativeElement.onAttached = () => {\n            that.onAttach.emit(that.nativeElement);\n        }\n\n        that.nativeElement.onDetached = () => {\n            that.onDetach.emit(that.nativeElement);\n        }\n    }\n\n    @Output() onCreate: EventEmitter<any> = new EventEmitter();\n    @Output() onReady: EventEmitter<any> = new EventEmitter();\n    @Output() onAttach: EventEmitter<any> = new EventEmitter();\n    @Output() onDetach: EventEmitter<any> = new EventEmitter();\n\n    public nativeElement: any;\n\n    public addEventListener(type: string, listener: EventListenerOrEventListenerObject, options: boolean | AddEventListenerOptions = false): void {\n        this.nativeElement.addEventListener(type, listener, options);\n\t}\n\n\tpublic removeEventListener(type: string, listener: EventListenerOrEventListenerObject, options: boolean | AddEventListenerOptions = false): void {\n\t\tthis.nativeElement.removeEventListener(type, listener, options);\n\t}\n\n\tpublic dispatchEvent(event: Event): boolean {\n\t\treturn this.nativeElement.dispatchEvent(event);\n\t}\n\n\tpublic blur(): void {\n\t\tthis.nativeElement.blur();\n\t}\n\n\tpublic click(): void {\n\t\tthis.nativeElement.click();\n\t}\n\n\tpublic focus(options?: FocusOptions): void {\n\t\tthis.nativeElement.focus(options);\n\t}\n\n/** @description Sets or gets the language. Used in conjunction with the property messages.  */\n\t@Input()\n\tget locale(): string {\n\t\treturn this.nativeElement ? this.nativeElement.locale : undefined;\n\t}\n\tset locale(value: string) {\n\t\tthis.nativeElement ? this.nativeElement.locale = value : undefined;\n\t}\n\n\t/** @description Callback used to customize the format of the messages that are returned from the Localization Module. */\n\t@Input()\n\tget localizeFormatFunction(): any {\n\t\treturn this.nativeElement ? this.nativeElement.localizeFormatFunction : undefined;\n\t}\n\tset localizeFormatFunction(value: any) {\n\t\tthis.nativeElement ? this.nativeElement.localizeFormatFunction = value : undefined;\n\t}\n\n\t/** @description Sets or gets an object specifying strings used in the widget that can be localized. Used in conjunction with the property locale.  */\n\t@Input()\n\tget messages(): any {\n\t\treturn this.nativeElement ? this.nativeElement.messages : undefined;\n\t}\n\tset messages(value: any) {\n\t\tthis.nativeElement ? this.nativeElement.messages = value : undefined;\n\t}\n\n\t/** @description Sets or gets the value indicating whether the element is aligned to support locales using right-to-left fonts. */\n\t@Input()\n\tget rightToLeft(): boolean {\n\t\treturn this.nativeElement ? this.nativeElement.rightToLeft : undefined;\n\t}\n\tset rightToLeft(value: boolean) {\n\t\tthis.nativeElement ? this.nativeElement.rightToLeft = value : undefined;\n\t}\n\n\t/** @description Determines the theme. Theme defines the look of the element */\n\t@Input()\n\tget theme(): string {\n\t\treturn this.nativeElement ? this.nativeElement.theme : undefined;\n\t}\n\tset theme(value: string) {\n\t\tthis.nativeElement ? this.nativeElement.theme = value : undefined;\n\t}\n}\n\nexport const Smart: any = window.Smart;\n\n"]}
|
|
@@ -0,0 +1,434 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { Directive, ElementRef, Input, forwardRef, Output, EventEmitter } from '@angular/core';
|
|
3
|
+
import { BaseElement, Smart } from './smart.element';
|
|
4
|
+
export { Smart } from './smart.element';
|
|
5
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
6
|
+
const CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR = {
|
|
7
|
+
provide: NG_VALUE_ACCESSOR,
|
|
8
|
+
useExisting: forwardRef(() => PhoneInputComponent),
|
|
9
|
+
multi: true
|
|
10
|
+
};
|
|
11
|
+
export class PhoneInputComponent extends BaseElement {
|
|
12
|
+
constructor(ref) {
|
|
13
|
+
super(ref);
|
|
14
|
+
this.eventHandlers = [];
|
|
15
|
+
/**
|
|
16
|
+
* @description
|
|
17
|
+
* The registered callback function called when a change event occurs on the form elements.
|
|
18
|
+
*/
|
|
19
|
+
this._onChange = () => { };
|
|
20
|
+
/**
|
|
21
|
+
* @description
|
|
22
|
+
* The registered callback function called when a blur event occurs on the form elements.
|
|
23
|
+
*/
|
|
24
|
+
this._onTouched = () => { };
|
|
25
|
+
/** @description This event is triggered when the selection is changed.
|
|
26
|
+
* @param event. The custom event. Custom event was created with: event.detail( label, oldLabel, oldValue, value)
|
|
27
|
+
* label - The label of the new selected item.
|
|
28
|
+
* oldLabel - The label of the item that was previously selected before the event was triggered.
|
|
29
|
+
* oldValue - The value of the item that was previously selected before the event was triggered.
|
|
30
|
+
* value - The value of the new selected item.
|
|
31
|
+
*/
|
|
32
|
+
this.onChange = new EventEmitter();
|
|
33
|
+
/** @description This event is triggered on each key up event of the Input, if the value is changed.
|
|
34
|
+
* @param event. The custom event. Custom event was created with: event.detail( oldValue, value)
|
|
35
|
+
* oldValue - The previous value before it was changed.
|
|
36
|
+
* value - The new value.
|
|
37
|
+
*/
|
|
38
|
+
this.onChanging = new EventEmitter();
|
|
39
|
+
/** @description This event is triggered when the user clicks on an item from the popup list.
|
|
40
|
+
* @param event. The custom event. Custom event was created with: event.detail( item, label, value)
|
|
41
|
+
* item - The item that was clicked.
|
|
42
|
+
* label - The label of the item that was clicked.
|
|
43
|
+
* value - The value of the item that was clicked.
|
|
44
|
+
*/
|
|
45
|
+
this.onItemClick = new EventEmitter();
|
|
46
|
+
this._initialChange = true;
|
|
47
|
+
this.nativeElement = ref.nativeElement;
|
|
48
|
+
}
|
|
49
|
+
/** @description Creates the component on demand.
|
|
50
|
+
* @param properties An optional object of properties, which will be added to the template binded ones.
|
|
51
|
+
*/
|
|
52
|
+
createComponent(properties = {}) {
|
|
53
|
+
this.nativeElement = document.createElement('smart-phone-input');
|
|
54
|
+
for (let propertyName in properties) {
|
|
55
|
+
this.nativeElement[propertyName] = properties[propertyName];
|
|
56
|
+
}
|
|
57
|
+
return this.nativeElement;
|
|
58
|
+
}
|
|
59
|
+
/** @description Enables or disables the element. */
|
|
60
|
+
get disabled() {
|
|
61
|
+
return this.nativeElement ? this.nativeElement.disabled : undefined;
|
|
62
|
+
}
|
|
63
|
+
set disabled(value) {
|
|
64
|
+
this.nativeElement ? this.nativeElement.disabled = value : undefined;
|
|
65
|
+
}
|
|
66
|
+
/** @description Sets additional class names to the Input drop down. */
|
|
67
|
+
get dropDownClassList() {
|
|
68
|
+
return this.nativeElement ? this.nativeElement.dropDownClassList : undefined;
|
|
69
|
+
}
|
|
70
|
+
set dropDownClassList(value) {
|
|
71
|
+
this.nativeElement ? this.nativeElement.dropDownClassList = value : undefined;
|
|
72
|
+
}
|
|
73
|
+
/** @description Determines the position of the drop down button. */
|
|
74
|
+
get dropDownButtonPosition() {
|
|
75
|
+
return this.nativeElement ? this.nativeElement.dropDownButtonPosition : undefined;
|
|
76
|
+
}
|
|
77
|
+
set dropDownButtonPosition(value) {
|
|
78
|
+
this.nativeElement ? this.nativeElement.dropDownButtonPosition = value : undefined;
|
|
79
|
+
}
|
|
80
|
+
/** @description Sets the height of the drop down. By default it's set to an empty string. In this case the height of the drop down is controlled by a CSS variable. */
|
|
81
|
+
get dropDownHeight() {
|
|
82
|
+
return this.nativeElement ? this.nativeElement.dropDownHeight : undefined;
|
|
83
|
+
}
|
|
84
|
+
set dropDownHeight(value) {
|
|
85
|
+
this.nativeElement ? this.nativeElement.dropDownHeight = value : undefined;
|
|
86
|
+
}
|
|
87
|
+
/** @description Sets the width of the drop down. By default it's set to an empty string. In this case the width of the drop down is controlled by a CSS variable. */
|
|
88
|
+
get dropDownWidth() {
|
|
89
|
+
return this.nativeElement ? this.nativeElement.dropDownWidth : undefined;
|
|
90
|
+
}
|
|
91
|
+
set dropDownWidth(value) {
|
|
92
|
+
this.nativeElement ? this.nativeElement.dropDownWidth = value : undefined;
|
|
93
|
+
}
|
|
94
|
+
/** @description Sets or gets an object specifying strings used in the widget that can be localized. Used in conjunction with the property locale. */
|
|
95
|
+
get messages() {
|
|
96
|
+
return this.nativeElement ? this.nativeElement.messages : undefined;
|
|
97
|
+
}
|
|
98
|
+
set messages(value) {
|
|
99
|
+
this.nativeElement ? this.nativeElement.messages = value : undefined;
|
|
100
|
+
}
|
|
101
|
+
/** @description Sets or gets the name attribute for the element. Name is used when submiting data inside an HTML form. */
|
|
102
|
+
get name() {
|
|
103
|
+
return this.nativeElement ? this.nativeElement.name : undefined;
|
|
104
|
+
}
|
|
105
|
+
set name(value) {
|
|
106
|
+
this.nativeElement ? this.nativeElement.name = value : undefined;
|
|
107
|
+
}
|
|
108
|
+
/** @description Determines whether the input will be in international or national mode i.e whether the input will start with '+'. */
|
|
109
|
+
get nationalMode() {
|
|
110
|
+
return this.nativeElement ? this.nativeElement.nationalMode : undefined;
|
|
111
|
+
}
|
|
112
|
+
set nationalMode(value) {
|
|
113
|
+
this.nativeElement ? this.nativeElement.nationalMode = value : undefined;
|
|
114
|
+
}
|
|
115
|
+
/** @description Determines whether the drop down is opened or not. */
|
|
116
|
+
get opened() {
|
|
117
|
+
return this.nativeElement ? this.nativeElement.opened : undefined;
|
|
118
|
+
}
|
|
119
|
+
set opened(value) {
|
|
120
|
+
this.nativeElement ? this.nativeElement.opened = value : undefined;
|
|
121
|
+
}
|
|
122
|
+
/** @description Sets or gets an array of country codes which will be used instead of the default one with all countries. The country code should be ISO 3166-1 alpha-2 codes(https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2). */
|
|
123
|
+
get onlyCountries() {
|
|
124
|
+
return this.nativeElement ? this.nativeElement.onlyCountries : undefined;
|
|
125
|
+
}
|
|
126
|
+
set onlyCountries(value) {
|
|
127
|
+
this.nativeElement ? this.nativeElement.onlyCountries = value : undefined;
|
|
128
|
+
}
|
|
129
|
+
/** @description Determines the placeholder of the input. */
|
|
130
|
+
get placeholder() {
|
|
131
|
+
return this.nativeElement ? this.nativeElement.placeholder : undefined;
|
|
132
|
+
}
|
|
133
|
+
set placeholder(value) {
|
|
134
|
+
this.nativeElement ? this.nativeElement.placeholder = value : undefined;
|
|
135
|
+
}
|
|
136
|
+
/** @description Sets or gets the selected country of the element. The country code should be ISO 3166-1 alpha-2 codes(https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2). */
|
|
137
|
+
get selectedCountry() {
|
|
138
|
+
return this.nativeElement ? this.nativeElement.selectedCountry : undefined;
|
|
139
|
+
}
|
|
140
|
+
set selectedCountry(value) {
|
|
141
|
+
this.nativeElement ? this.nativeElement.selectedCountry = value : undefined;
|
|
142
|
+
}
|
|
143
|
+
/** @description Sets or gets the value indicating whether the element is aligned to support locales using right-to-left fonts. */
|
|
144
|
+
get rightToLeft() {
|
|
145
|
+
return this.nativeElement ? this.nativeElement.rightToLeft : undefined;
|
|
146
|
+
}
|
|
147
|
+
set rightToLeft(value) {
|
|
148
|
+
this.nativeElement ? this.nativeElement.rightToLeft = value : undefined;
|
|
149
|
+
}
|
|
150
|
+
/** @description Determines the theme for the element. Themes define the look of the elements. */
|
|
151
|
+
get theme() {
|
|
152
|
+
return this.nativeElement ? this.nativeElement.theme : undefined;
|
|
153
|
+
}
|
|
154
|
+
set theme(value) {
|
|
155
|
+
this.nativeElement ? this.nativeElement.theme = value : undefined;
|
|
156
|
+
}
|
|
157
|
+
/** @description If is set to true, the element cannot be focused. */
|
|
158
|
+
get unfocusable() {
|
|
159
|
+
return this.nativeElement ? this.nativeElement.unfocusable : undefined;
|
|
160
|
+
}
|
|
161
|
+
set unfocusable(value) {
|
|
162
|
+
this.nativeElement ? this.nativeElement.unfocusable = value : undefined;
|
|
163
|
+
}
|
|
164
|
+
/** @description Sets or gets the value of the element. */
|
|
165
|
+
get value() {
|
|
166
|
+
return this.nativeElement ? this.nativeElement.value : undefined;
|
|
167
|
+
}
|
|
168
|
+
set value(value) {
|
|
169
|
+
this.nativeElement ? this.nativeElement.value = value : undefined;
|
|
170
|
+
}
|
|
171
|
+
/** @description Closes the drop down.
|
|
172
|
+
*/
|
|
173
|
+
close() {
|
|
174
|
+
if (this.nativeElement.isRendered) {
|
|
175
|
+
this.nativeElement.close();
|
|
176
|
+
}
|
|
177
|
+
else {
|
|
178
|
+
this.nativeElement.whenRendered(() => {
|
|
179
|
+
this.nativeElement.close();
|
|
180
|
+
});
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
/** @description Ensures that the active ( selected ) item is always visible.
|
|
184
|
+
*/
|
|
185
|
+
ensureVisible() {
|
|
186
|
+
if (this.nativeElement.isRendered) {
|
|
187
|
+
this.nativeElement.ensureVisible();
|
|
188
|
+
}
|
|
189
|
+
else {
|
|
190
|
+
this.nativeElement.whenRendered(() => {
|
|
191
|
+
this.nativeElement.ensureVisible();
|
|
192
|
+
});
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
/** @description Returns the entered phone number with formatting.
|
|
196
|
+
* @param {boolean} isInternational?. When you use 'false', the national phone number will be returned and the international phone number, when you use 'true' as parameter.
|
|
197
|
+
* @returns {string}
|
|
198
|
+
*/
|
|
199
|
+
getNumber(isInternational) {
|
|
200
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
201
|
+
const getResultOnRender = () => {
|
|
202
|
+
return new Promise(resolve => {
|
|
203
|
+
this.nativeElement.whenRendered(() => {
|
|
204
|
+
const result = this.nativeElement.getNumber(isInternational);
|
|
205
|
+
resolve(result);
|
|
206
|
+
});
|
|
207
|
+
});
|
|
208
|
+
};
|
|
209
|
+
const result = yield getResultOnRender();
|
|
210
|
+
return result;
|
|
211
|
+
});
|
|
212
|
+
}
|
|
213
|
+
/** @description Returns an item by its country dial code. The item is an object with 'label', 'value', 'iso2' and 'dialCode' properties.
|
|
214
|
+
* @param {string} dialCode?. Returns the national or international phone number
|
|
215
|
+
* @returns {any}
|
|
216
|
+
*/
|
|
217
|
+
getItemByDialCode(dialCode) {
|
|
218
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
219
|
+
const getResultOnRender = () => {
|
|
220
|
+
return new Promise(resolve => {
|
|
221
|
+
this.nativeElement.whenRendered(() => {
|
|
222
|
+
const result = this.nativeElement.getItemByDialCode(dialCode);
|
|
223
|
+
resolve(result);
|
|
224
|
+
});
|
|
225
|
+
});
|
|
226
|
+
};
|
|
227
|
+
const result = yield getResultOnRender();
|
|
228
|
+
return result;
|
|
229
|
+
});
|
|
230
|
+
}
|
|
231
|
+
/** @description Returns the selected item. The item is an object with 'label', 'value', 'iso2' and 'dialCode' properties.
|
|
232
|
+
* @returns {any}
|
|
233
|
+
*/
|
|
234
|
+
getSelectedItem() {
|
|
235
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
236
|
+
const getResultOnRender = () => {
|
|
237
|
+
return new Promise(resolve => {
|
|
238
|
+
this.nativeElement.whenRendered(() => {
|
|
239
|
+
const result = this.nativeElement.getSelectedItem();
|
|
240
|
+
resolve(result);
|
|
241
|
+
});
|
|
242
|
+
});
|
|
243
|
+
};
|
|
244
|
+
const result = yield getResultOnRender();
|
|
245
|
+
return result;
|
|
246
|
+
});
|
|
247
|
+
}
|
|
248
|
+
/** @description Returns true or false depending on whether the entered phone number is valid.
|
|
249
|
+
* @returns {boolean}
|
|
250
|
+
*/
|
|
251
|
+
isValidNumber() {
|
|
252
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
253
|
+
const getResultOnRender = () => {
|
|
254
|
+
return new Promise(resolve => {
|
|
255
|
+
this.nativeElement.whenRendered(() => {
|
|
256
|
+
const result = this.nativeElement.isValidNumber();
|
|
257
|
+
resolve(result);
|
|
258
|
+
});
|
|
259
|
+
});
|
|
260
|
+
};
|
|
261
|
+
const result = yield getResultOnRender();
|
|
262
|
+
return result;
|
|
263
|
+
});
|
|
264
|
+
}
|
|
265
|
+
/** @description Validates the entered phone number.
|
|
266
|
+
*/
|
|
267
|
+
validate() {
|
|
268
|
+
if (this.nativeElement.isRendered) {
|
|
269
|
+
this.nativeElement.validate();
|
|
270
|
+
}
|
|
271
|
+
else {
|
|
272
|
+
this.nativeElement.whenRendered(() => {
|
|
273
|
+
this.nativeElement.validate();
|
|
274
|
+
});
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
/** @description Opens the drop down.
|
|
278
|
+
*/
|
|
279
|
+
open() {
|
|
280
|
+
if (this.nativeElement.isRendered) {
|
|
281
|
+
this.nativeElement.open();
|
|
282
|
+
}
|
|
283
|
+
else {
|
|
284
|
+
this.nativeElement.whenRendered(() => {
|
|
285
|
+
this.nativeElement.open();
|
|
286
|
+
});
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
/** @description Selects the text inside the input or if it is readonly then the element is focused.
|
|
290
|
+
*/
|
|
291
|
+
select() {
|
|
292
|
+
if (this.nativeElement.isRendered) {
|
|
293
|
+
this.nativeElement.select();
|
|
294
|
+
}
|
|
295
|
+
else {
|
|
296
|
+
this.nativeElement.whenRendered(() => {
|
|
297
|
+
this.nativeElement.select();
|
|
298
|
+
});
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
get isRendered() {
|
|
302
|
+
return this.nativeElement ? this.nativeElement.isRendered : false;
|
|
303
|
+
}
|
|
304
|
+
ngOnInit() {
|
|
305
|
+
}
|
|
306
|
+
ngAfterViewInit() {
|
|
307
|
+
const that = this;
|
|
308
|
+
that.onCreate.emit(that.nativeElement);
|
|
309
|
+
Smart.Render();
|
|
310
|
+
this.nativeElement.classList.add('smart-angular');
|
|
311
|
+
this.nativeElement.whenRendered(() => { that.onReady.emit(that.nativeElement); });
|
|
312
|
+
this.listen();
|
|
313
|
+
}
|
|
314
|
+
ngOnDestroy() {
|
|
315
|
+
this.unlisten();
|
|
316
|
+
}
|
|
317
|
+
get ngValue() {
|
|
318
|
+
if (!this.nativeElement) {
|
|
319
|
+
return null;
|
|
320
|
+
}
|
|
321
|
+
const value = this.nativeElement.value;
|
|
322
|
+
return value;
|
|
323
|
+
}
|
|
324
|
+
set ngValue(value) {
|
|
325
|
+
if (this.nativeElement) {
|
|
326
|
+
this.writeValue(value);
|
|
327
|
+
}
|
|
328
|
+
}
|
|
329
|
+
writeValue(value) {
|
|
330
|
+
const that = this;
|
|
331
|
+
const normalizedValue = value == null ? '' : value;
|
|
332
|
+
that.nativeElement.whenRendered(() => {
|
|
333
|
+
that.value = normalizedValue;
|
|
334
|
+
if (that._initialChange === false) {
|
|
335
|
+
that._onChange(that.value);
|
|
336
|
+
}
|
|
337
|
+
});
|
|
338
|
+
}
|
|
339
|
+
registerOnChange(fn) {
|
|
340
|
+
this._onChange = fn;
|
|
341
|
+
}
|
|
342
|
+
registerOnTouched(fn) {
|
|
343
|
+
this._onTouched = fn;
|
|
344
|
+
}
|
|
345
|
+
ngOnChanges(changes) {
|
|
346
|
+
if (this.nativeElement && this.nativeElement.isRendered) {
|
|
347
|
+
for (const propName in changes) {
|
|
348
|
+
if (changes.hasOwnProperty(propName)) {
|
|
349
|
+
this.nativeElement[propName] = changes[propName].currentValue;
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
/** @description Add event listeners. */
|
|
355
|
+
listen() {
|
|
356
|
+
const that = this;
|
|
357
|
+
that.eventHandlers['changeHandler'] = (event) => { that.onChange.emit(event); };
|
|
358
|
+
that.nativeElement.addEventListener('change', that.eventHandlers['changeHandler']);
|
|
359
|
+
that.eventHandlers['changingHandler'] = (event) => { that.onChanging.emit(event); };
|
|
360
|
+
that.nativeElement.addEventListener('changing', that.eventHandlers['changingHandler']);
|
|
361
|
+
that.eventHandlers['itemClickHandler'] = (event) => { that.onItemClick.emit(event); };
|
|
362
|
+
that.nativeElement.addEventListener('itemClick', that.eventHandlers['itemClickHandler']);
|
|
363
|
+
that.eventHandlers['changeModelHandler'] = (event) => {
|
|
364
|
+
that._initialChange = false;
|
|
365
|
+
that._onChange(that.nativeElement.value);
|
|
366
|
+
};
|
|
367
|
+
that.eventHandlers['blurModelHandler'] = (event) => {
|
|
368
|
+
that._onTouched();
|
|
369
|
+
};
|
|
370
|
+
that.nativeElement.whenRendered(() => {
|
|
371
|
+
if (that.nativeElement.querySelector('input')) {
|
|
372
|
+
that.eventHandlers['keyupModelHandler'] = (event) => {
|
|
373
|
+
setTimeout(() => { that.eventHandlers['changeModelHandler'](event); }, 50);
|
|
374
|
+
};
|
|
375
|
+
that.nativeElement.querySelector('input').addEventListener('keyup', that.eventHandlers['keyupModelHandler']);
|
|
376
|
+
}
|
|
377
|
+
});
|
|
378
|
+
that.nativeElement.addEventListener('change', that.eventHandlers['changeModelHandler']);
|
|
379
|
+
that.nativeElement.addEventListener('blur', that.eventHandlers['blurModelHandler']);
|
|
380
|
+
}
|
|
381
|
+
/** @description Remove event listeners. */
|
|
382
|
+
unlisten() {
|
|
383
|
+
const that = this;
|
|
384
|
+
if (that.eventHandlers['changeHandler']) {
|
|
385
|
+
that.nativeElement.removeEventListener('change', that.eventHandlers['changeHandler']);
|
|
386
|
+
}
|
|
387
|
+
if (that.eventHandlers['changingHandler']) {
|
|
388
|
+
that.nativeElement.removeEventListener('changing', that.eventHandlers['changingHandler']);
|
|
389
|
+
}
|
|
390
|
+
if (that.eventHandlers['itemClickHandler']) {
|
|
391
|
+
that.nativeElement.removeEventListener('itemClick', that.eventHandlers['itemClickHandler']);
|
|
392
|
+
}
|
|
393
|
+
if (that.eventHandlers['changeModelHandler']) {
|
|
394
|
+
that.nativeElement.removeEventListener('change', that.eventHandlers['changeModelHandler']);
|
|
395
|
+
if (that.nativeElement.querySelector('input')) {
|
|
396
|
+
that.nativeElement.querySelector('input').removeEventListener('keyup', that.eventHandlers['keyupModelHandler']);
|
|
397
|
+
}
|
|
398
|
+
}
|
|
399
|
+
if (that.eventHandlers['blurModelHandler']) {
|
|
400
|
+
that.nativeElement.removeEventListener('blur', that.eventHandlers['blurModelHandler']);
|
|
401
|
+
}
|
|
402
|
+
}
|
|
403
|
+
}
|
|
404
|
+
PhoneInputComponent.decorators = [
|
|
405
|
+
{ type: Directive, args: [{
|
|
406
|
+
selector: 'smart-phone-input, [smart-phone-input]',
|
|
407
|
+
providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR]
|
|
408
|
+
},] }
|
|
409
|
+
];
|
|
410
|
+
PhoneInputComponent.ctorParameters = () => [
|
|
411
|
+
{ type: ElementRef }
|
|
412
|
+
];
|
|
413
|
+
PhoneInputComponent.propDecorators = {
|
|
414
|
+
disabled: [{ type: Input }],
|
|
415
|
+
dropDownClassList: [{ type: Input }],
|
|
416
|
+
dropDownButtonPosition: [{ type: Input }],
|
|
417
|
+
dropDownHeight: [{ type: Input }],
|
|
418
|
+
dropDownWidth: [{ type: Input }],
|
|
419
|
+
messages: [{ type: Input }],
|
|
420
|
+
name: [{ type: Input }],
|
|
421
|
+
nationalMode: [{ type: Input }],
|
|
422
|
+
opened: [{ type: Input }],
|
|
423
|
+
onlyCountries: [{ type: Input }],
|
|
424
|
+
placeholder: [{ type: Input }],
|
|
425
|
+
selectedCountry: [{ type: Input }],
|
|
426
|
+
rightToLeft: [{ type: Input }],
|
|
427
|
+
theme: [{ type: Input }],
|
|
428
|
+
unfocusable: [{ type: Input }],
|
|
429
|
+
value: [{ type: Input }],
|
|
430
|
+
onChange: [{ type: Output }],
|
|
431
|
+
onChanging: [{ type: Output }],
|
|
432
|
+
onItemClick: [{ type: Output }]
|
|
433
|
+
};
|
|
434
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart.phoneinput.js","sourceRoot":"","sources":["../../../phoneinput/src/smart.phoneinput.ts"],"names":[],"mappings":"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","sourcesContent":["import { PhoneInput } from './../index';\nimport { DropDownButtonPosition, ElementRenderMode} from './../index';\nimport { Component, Directive, AfterViewInit, ElementRef, Input, OnInit, OnChanges, OnDestroy, SimpleChanges, forwardRef, ChangeDetectionStrategy, Output, EventEmitter } from '@angular/core';\nimport { BaseElement, Smart } from './smart.element';\nexport { DropDownButtonPosition, ElementRenderMode} from './../index';\nexport { Smart } from './smart.element';\nexport { PhoneInput } from './../index';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n\n\nconst CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => PhoneInputComponent),\n    multi: true\n}\n\n@Directive({\n\tselector: 'smart-phone-input, [smart-phone-input]',\n\tproviders: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR]\n\n})\n\nexport class PhoneInputComponent extends BaseElement implements OnInit, AfterViewInit, OnDestroy, OnChanges, ControlValueAccessor {\n\tconstructor(ref: ElementRef<PhoneInput>) {\n\t\tsuper(ref);\n\t\tthis.nativeElement = ref.nativeElement as PhoneInput;\n\t}\n\n\tprivate eventHandlers: any[] = [];\n\n\tpublic nativeElement: PhoneInput;\n\t/** @description Creates the component on demand.\n\t * @param properties An optional object of properties, which will be added to the template binded ones.\n\t */\n\tpublic createComponent(properties = {}): any {\n    \tthis.nativeElement = <PhoneInput>document.createElement('smart-phone-input');\n\t\tfor (let propertyName in properties) { \n \t\t\tthis.nativeElement[propertyName] = properties[propertyName];\n\t\t}\n\t\treturn this.nativeElement;\n\t}\n        /**\n        * @description\n        * The registered callback function called when a change event occurs on the form elements.\n        */\n       _onChange: (value: any) => void = () => {};\n        /**\n        * @description\n        * The registered callback function called when a blur event occurs on the form elements.\n        */\n       _onTouched: () => any = () => {};\n\n\n\t/** @description Enables or disables the element. */\n\t@Input()\n\tget disabled(): boolean {\n\t\treturn this.nativeElement ? this.nativeElement.disabled : undefined;\n\t}\n\tset disabled(value: boolean) {\n\t\tthis.nativeElement ? this.nativeElement.disabled = value : undefined;\n\t}\n\n\t/** @description Sets additional class names to the Input drop down. */\n\t@Input()\n\tget dropDownClassList(): any {\n\t\treturn this.nativeElement ? this.nativeElement.dropDownClassList : undefined;\n\t}\n\tset dropDownClassList(value: any) {\n\t\tthis.nativeElement ? this.nativeElement.dropDownClassList = value : undefined;\n\t}\n\n\t/** @description Determines the position of the drop down button. */\n\t@Input()\n\tget dropDownButtonPosition(): DropDownButtonPosition {\n\t\treturn this.nativeElement ? this.nativeElement.dropDownButtonPosition : undefined;\n\t}\n\tset dropDownButtonPosition(value: DropDownButtonPosition) {\n\t\tthis.nativeElement ? this.nativeElement.dropDownButtonPosition = value : undefined;\n\t}\n\n\t/** @description Sets the height of the drop down. By default it's set to an empty string. In this case the height of the drop down is controlled by a CSS variable. */\n\t@Input()\n\tget dropDownHeight(): string | number {\n\t\treturn this.nativeElement ? this.nativeElement.dropDownHeight : undefined;\n\t}\n\tset dropDownHeight(value: string | number) {\n\t\tthis.nativeElement ? this.nativeElement.dropDownHeight = value : undefined;\n\t}\n\n\t/** @description Sets the width of the drop down. By default it's set to an empty string. In this case the width of the drop down is controlled by a CSS variable. */\n\t@Input()\n\tget dropDownWidth(): string | number {\n\t\treturn this.nativeElement ? this.nativeElement.dropDownWidth : undefined;\n\t}\n\tset dropDownWidth(value: string | number) {\n\t\tthis.nativeElement ? this.nativeElement.dropDownWidth = value : undefined;\n\t}\n\n\t/** @description Sets or gets an object specifying strings used in the widget that can be localized. Used in conjunction with the property locale.  */\n\t@Input()\n\tget messages(): any {\n\t\treturn this.nativeElement ? this.nativeElement.messages : undefined;\n\t}\n\tset messages(value: any) {\n\t\tthis.nativeElement ? this.nativeElement.messages = value : undefined;\n\t}\n\n\t/** @description Sets or gets the name attribute for the element. Name is used when submiting data inside an HTML form. */\n\t@Input()\n\tget name(): string {\n\t\treturn this.nativeElement ? this.nativeElement.name : undefined;\n\t}\n\tset name(value: string) {\n\t\tthis.nativeElement ? this.nativeElement.name = value : undefined;\n\t}\n\n\t/** @description Determines whether the input will be in international or national mode i.e whether the input will start with '+'. */\n\t@Input()\n\tget nationalMode(): boolean {\n\t\treturn this.nativeElement ? this.nativeElement.nationalMode : undefined;\n\t}\n\tset nationalMode(value: boolean) {\n\t\tthis.nativeElement ? this.nativeElement.nationalMode = value : undefined;\n\t}\n\n\t/** @description Determines whether the drop down is opened or not. */\n\t@Input()\n\tget opened(): boolean {\n\t\treturn this.nativeElement ? this.nativeElement.opened : undefined;\n\t}\n\tset opened(value: boolean) {\n\t\tthis.nativeElement ? this.nativeElement.opened = value : undefined;\n\t}\n\n\t/** @description Sets or gets an array of country codes which will be used instead of the default one with all countries. The country code should be ISO 3166-1 alpha-2 codes(https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2). */\n\t@Input()\n\tget onlyCountries(): any {\n\t\treturn this.nativeElement ? this.nativeElement.onlyCountries : undefined;\n\t}\n\tset onlyCountries(value: any) {\n\t\tthis.nativeElement ? this.nativeElement.onlyCountries = value : undefined;\n\t}\n\n\t/** @description Determines the placeholder of the input. */\n\t@Input()\n\tget placeholder(): string {\n\t\treturn this.nativeElement ? this.nativeElement.placeholder : undefined;\n\t}\n\tset placeholder(value: string) {\n\t\tthis.nativeElement ? this.nativeElement.placeholder = value : undefined;\n\t}\n\n\t/** @description Sets or gets the selected country of the element. The country code should be ISO 3166-1 alpha-2 codes(https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2). */\n\t@Input()\n\tget selectedCountry(): string {\n\t\treturn this.nativeElement ? this.nativeElement.selectedCountry : undefined;\n\t}\n\tset selectedCountry(value: string) {\n\t\tthis.nativeElement ? this.nativeElement.selectedCountry = value : undefined;\n\t}\n\n\t/** @description Sets or gets the value indicating whether the element is aligned to support locales using right-to-left fonts. */\n\t@Input()\n\tget rightToLeft(): boolean {\n\t\treturn this.nativeElement ? this.nativeElement.rightToLeft : undefined;\n\t}\n\tset rightToLeft(value: boolean) {\n\t\tthis.nativeElement ? this.nativeElement.rightToLeft = value : undefined;\n\t}\n\n\t/** @description Determines the theme for the element. Themes define the look of the elements. */\n\t@Input()\n\tget theme(): string {\n\t\treturn this.nativeElement ? this.nativeElement.theme : undefined;\n\t}\n\tset theme(value: string) {\n\t\tthis.nativeElement ? this.nativeElement.theme = value : undefined;\n\t}\n\n\t/** @description If is set to true, the element cannot be focused. */\n\t@Input()\n\tget unfocusable(): boolean {\n\t\treturn this.nativeElement ? this.nativeElement.unfocusable : undefined;\n\t}\n\tset unfocusable(value: boolean) {\n\t\tthis.nativeElement ? this.nativeElement.unfocusable = value : undefined;\n\t}\n\n\t/** @description Sets or gets the value of the element. */\n\t@Input()\n\tget value(): string {\n\t\treturn this.nativeElement ? this.nativeElement.value : undefined;\n\t}\n\tset value(value: string) {\n\t\tthis.nativeElement ? this.nativeElement.value = value : undefined;\n\t}\n\n\t/** @description This event is triggered when the selection is changed.\n\t*  @param event. The custom event. \tCustom event was created with: event.detail(\tlabel, \toldLabel, \toldValue, \tvalue)\n\t*   label - The label of the new selected item.\n\t*   oldLabel - The label of the item that was previously selected before the event was triggered.\n\t*   oldValue - The value of the item that was previously selected before the event was triggered.\n\t*   value - The value of the new selected item.\n\t*/\n\t@Output() onChange: EventEmitter<CustomEvent> = new EventEmitter();\n\n\t/** @description This event is triggered on each key up event of the Input, if the value is changed.\n\t*  @param event. The custom event. \tCustom event was created with: event.detail(\toldValue, \tvalue)\n\t*   oldValue - The previous value before it was changed.\n\t*   value - The new value.\n\t*/\n\t@Output() onChanging: EventEmitter<CustomEvent> = new EventEmitter();\n\n\t/** @description This event is triggered when the user clicks on an item from the popup list.\n\t*  @param event. The custom event. \tCustom event was created with: event.detail(\titem, \tlabel, \tvalue)\n\t*   item - The item that was clicked.\n\t*   label - The label of the item that was clicked.\n\t*   value - The value of the item that was clicked.\n\t*/\n\t@Output() onItemClick: EventEmitter<CustomEvent> = new EventEmitter();\n\n\t/** @description Closes the drop down. \n\t*/\n    public close(): void {\n        if (this.nativeElement.isRendered) {\n            this.nativeElement.close();\n        }\n        else\n        {\n            this.nativeElement.whenRendered(() => {\n                this.nativeElement.close();\n            });\n        }\n    }\n\n\t/** @description Ensures that the active ( selected ) item is always visible. \n\t*/\n    public ensureVisible(): void {\n        if (this.nativeElement.isRendered) {\n            this.nativeElement.ensureVisible();\n        }\n        else\n        {\n            this.nativeElement.whenRendered(() => {\n                this.nativeElement.ensureVisible();\n            });\n        }\n    }\n\n\t/** @description Returns the entered phone number with formatting. \n\t* @param {boolean} isInternational?. When you use 'false', the national phone number will be returned and the international phone number, when you use 'true' as parameter.\n\t* @returns {string}\n  */\n\tpublic async getNumber(isInternational?): Promise<any> {\n\t\tconst getResultOnRender = () => {\n            return new Promise(resolve => {\n                this.nativeElement.whenRendered(() => {\n                    const result = this.nativeElement.getNumber(isInternational);\n                    resolve(result)\n                });\n            });\n        };\n        const result = await getResultOnRender();\n\n        return result;\n    }\n\n\t/** @description Returns an item by its country dial code. The item is an object with 'label', 'value', 'iso2' and 'dialCode' properties. \n\t* @param {string} dialCode?. Returns the national or international phone number\n\t* @returns {any}\n  */\n\tpublic async getItemByDialCode(dialCode?): Promise<any> {\n\t\tconst getResultOnRender = () => {\n            return new Promise(resolve => {\n                this.nativeElement.whenRendered(() => {\n                    const result = this.nativeElement.getItemByDialCode(dialCode);\n                    resolve(result)\n                });\n            });\n        };\n        const result = await getResultOnRender();\n\n        return result;\n    }\n\n\t/** @description Returns the selected item. The item is an object with 'label', 'value', 'iso2' and 'dialCode' properties. \n\t* @returns {any}\n  */\n\tpublic async getSelectedItem(): Promise<any> {\n\t\tconst getResultOnRender = () => {\n            return new Promise(resolve => {\n                this.nativeElement.whenRendered(() => {\n                    const result = this.nativeElement.getSelectedItem();\n                    resolve(result)\n                });\n            });\n        };\n        const result = await getResultOnRender();\n\n        return result;\n    }\n\n\t/** @description Returns true or false depending on whether the entered phone number is valid. \n\t* @returns {boolean}\n  */\n\tpublic async isValidNumber(): Promise<any> {\n\t\tconst getResultOnRender = () => {\n            return new Promise(resolve => {\n                this.nativeElement.whenRendered(() => {\n                    const result = this.nativeElement.isValidNumber();\n                    resolve(result)\n                });\n            });\n        };\n        const result = await getResultOnRender();\n\n        return result;\n    }\n\n\t/** @description Validates the entered phone number. \n\t*/\n    public validate(): void {\n        if (this.nativeElement.isRendered) {\n            this.nativeElement.validate();\n        }\n        else\n        {\n            this.nativeElement.whenRendered(() => {\n                this.nativeElement.validate();\n            });\n        }\n    }\n\n\t/** @description Opens the drop down. \n\t*/\n    public open(): void {\n        if (this.nativeElement.isRendered) {\n            this.nativeElement.open();\n        }\n        else\n        {\n            this.nativeElement.whenRendered(() => {\n                this.nativeElement.open();\n            });\n        }\n    }\n\n\t/** @description Selects the text inside the input or if it is readonly then the element is focused. \n\t*/\n    public select(): void {\n        if (this.nativeElement.isRendered) {\n            this.nativeElement.select();\n        }\n        else\n        {\n            this.nativeElement.whenRendered(() => {\n                this.nativeElement.select();\n            });\n        }\n    }\n\n\n\tget isRendered(): boolean {\n\t\treturn this.nativeElement ? this.nativeElement.isRendered : false;\n\t}\n\n\tngOnInit() {\n\t}\n\n    ngAfterViewInit() {\n      const that = this;\n\n      that.onCreate.emit(that.nativeElement);\n\n\t\tSmart.Render();\n\n\t\tthis.nativeElement.classList.add('smart-angular');\n\n\t\tthis.nativeElement.whenRendered(() => { that.onReady.emit(that.nativeElement); });\n\t\tthis.listen();\n\t}\n\n\tngOnDestroy() {\n\t\tthis.unlisten();\n\t}\n\n\t_initialChange = true; \n\n\tget ngValue(): any {\n\t\tif (!this.nativeElement) {\n\t\t\treturn null;\n\t\t}\n\n\t\tconst value = this.nativeElement.value;\n\t\treturn value;\n\t}\n\n\tset ngValue(value: any) {\n\t\tif (this.nativeElement) {\n\t\t    this.writeValue(value);\n\t\t}\n\t}\n\n\twriteValue(value: any): void {\n        const that = this;\n        const normalizedValue = value == null ? '' : value;\n\n\t\tthat.nativeElement.whenRendered(() => {\n\t\t\tthat.value = normalizedValue;\n\t\t\tif (that._initialChange === false) {\n\t    \t\tthat._onChange(that.value);\n            }\n\t\t});\n\t}\n\n\tregisterOnChange(fn: any): void {\n\t\tthis._onChange = fn;\n\t}\n\n\tregisterOnTouched(fn: any): void {\n\t\tthis._onTouched = fn;\n\t}\n\n\tngOnChanges(changes: SimpleChanges) {\n\t\tif (this.nativeElement && this.nativeElement.isRendered) {\n\t\t\tfor (const propName in changes) {\n\t\t\t\tif (changes.hasOwnProperty(propName)) {\n\t\t\t\t\tthis.nativeElement[propName] = changes[propName].currentValue;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t/** @description Add event listeners. */\n\tprivate listen(): void {\n        const that = this;\n\t\tthat.eventHandlers['changeHandler'] = (event: CustomEvent) => { that.onChange.emit(event); }\n\t\tthat.nativeElement.addEventListener('change', that.eventHandlers['changeHandler']);\n\n\t\tthat.eventHandlers['changingHandler'] = (event: CustomEvent) => { that.onChanging.emit(event); }\n\t\tthat.nativeElement.addEventListener('changing', that.eventHandlers['changingHandler']);\n\n\t\tthat.eventHandlers['itemClickHandler'] = (event: CustomEvent) => { that.onItemClick.emit(event); }\n\t\tthat.nativeElement.addEventListener('itemClick', that.eventHandlers['itemClickHandler']);\n\n\n        that.eventHandlers['changeModelHandler'] = (event: Event) => {\n            that._initialChange = false;\n            that._onChange(that.nativeElement.value);\n        };\n        that.eventHandlers['blurModelHandler'] = (event: Event) => {\n            that._onTouched();\n        };\n        that.nativeElement.whenRendered(() => {\n            if (that.nativeElement.querySelector('input')) {\n                that.eventHandlers['keyupModelHandler'] = (event) => {\n                    setTimeout(() => { that.eventHandlers['changeModelHandler'](event); }, 50);\n                };\n\n                that.nativeElement.querySelector('input').addEventListener('keyup', that.eventHandlers['keyupModelHandler']);\n            }\n        });\n\t\tthat.nativeElement.addEventListener('change', that.eventHandlers['changeModelHandler']);\n\t\tthat.nativeElement.addEventListener('blur', that.eventHandlers['blurModelHandler']);\n\t}\n\n\t/** @description Remove event listeners. */\n\tprivate unlisten(): void {\n        const that = this;\n\t\tif (that.eventHandlers['changeHandler']) {\n\t\t\tthat.nativeElement.removeEventListener('change', that.eventHandlers['changeHandler']);\n\t\t}\n\n\t\tif (that.eventHandlers['changingHandler']) {\n\t\t\tthat.nativeElement.removeEventListener('changing', that.eventHandlers['changingHandler']);\n\t\t}\n\n\t\tif (that.eventHandlers['itemClickHandler']) {\n\t\t\tthat.nativeElement.removeEventListener('itemClick', that.eventHandlers['itemClickHandler']);\n\t\t}\n\n\t\tif (that.eventHandlers['changeModelHandler']) {\n\t\t\tthat.nativeElement.removeEventListener('change', that.eventHandlers['changeModelHandler']);\n            if (that.nativeElement.querySelector('input')) {\n                  that.nativeElement.querySelector('input').removeEventListener('keyup', that.eventHandlers['keyupModelHandler']);\n            }\n\t\t}\n\t\tif (that.eventHandlers['blurModelHandler']) {\n\t\t\tthat.nativeElement.removeEventListener('blur', that.eventHandlers['blurModelHandler']);\n\t\t}\n\t}\n}\n"]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { PhoneInputComponent } from './smart.phoneinput';
|
|
3
|
+
import { CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
|
|
4
|
+
export class PhoneInputModule {
|
|
5
|
+
}
|
|
6
|
+
PhoneInputModule.decorators = [
|
|
7
|
+
{ type: NgModule, args: [{
|
|
8
|
+
declarations: [PhoneInputComponent],
|
|
9
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
10
|
+
exports: [PhoneInputComponent]
|
|
11
|
+
},] }
|
|
12
|
+
];
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnQucGhvbmVpbnB1dC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9waG9uZWlucHV0L3NyYy9zbWFydC5waG9uZWlucHV0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxzQkFBc0IsRUFBRyxNQUFNLGVBQWUsQ0FBQztBQVF4RCxNQUFNLE9BQU8sZ0JBQWdCOzs7WUFONUIsUUFBUSxTQUFDO2dCQUNOLFlBQVksRUFBRSxDQUFDLG1CQUFtQixDQUFDO2dCQUN0QyxPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztnQkFDakMsT0FBTyxFQUFFLENBQUMsbUJBQW1CLENBQUM7YUFDOUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBQaG9uZUlucHV0Q29tcG9uZW50IH0gZnJvbSAnLi9zbWFydC5waG9uZWlucHV0JztcbmltcG9ydCB7IENVU1RPTV9FTEVNRU5UU19TQ0hFTUEgIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbUGhvbmVJbnB1dENvbXBvbmVudF0sXG5cdHNjaGVtYXM6IFtDVVNUT01fRUxFTUVOVFNfU0NIRU1BXSxcblx0ZXhwb3J0czogW1Bob25lSW5wdXRDb21wb25lbnRdXG59KVxuXG5leHBvcnQgY2xhc3MgUGhvbmVJbnB1dE1vZHVsZSB7IH1cbiJdfQ==
|