@piserve-tech/form-submission 0.0.0-watch
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 +24 -0
- package/element-type/element-type.module.d.ts +12 -0
- package/element-type/form-elements/form-elements.component.d.ts +7 -0
- package/element-type/question/question.component.d.ts +14 -0
- package/element-type/sub-form/sub-form.component.d.ts +6 -0
- package/esm2022/element-type/element-type.module.mjs +36 -0
- package/esm2022/element-type/form-elements/form-elements.component.mjs +23 -0
- package/esm2022/element-type/question/question.component.mjs +52 -0
- package/esm2022/element-type/sub-form/sub-form.component.mjs +17 -0
- package/esm2022/form-fields/check-box-fields/check-box-fields.component.mjs +198 -0
- package/esm2022/form-fields/date-time-fields/date-time-fields.component.mjs +155 -0
- package/esm2022/form-fields/drop-down-fields/drop-down-fields.component.mjs +147 -0
- package/esm2022/form-fields/file-picker-fields/file-picker-fields.component.mjs +77 -0
- package/esm2022/form-fields/form-fields.module.mjs +154 -0
- package/esm2022/form-fields/location-fields/location-fields.component.mjs +79 -0
- package/esm2022/form-fields/mail-fields/mail-fields.component.mjs +75 -0
- package/esm2022/form-fields/mobile-fields/mobile-fields.component.mjs +81 -0
- package/esm2022/form-fields/number-fields/number-fields.component.mjs +59 -0
- package/esm2022/form-fields/password-fields/password-fields.component.mjs +172 -0
- package/esm2022/form-fields/radio-button-fields/radio-button-fields.component.mjs +129 -0
- package/esm2022/form-fields/rich-text-editor-fields/rich-text-editor-fields.component.mjs +89 -0
- package/esm2022/form-fields/section-fields/section-fields.component.mjs +16 -0
- package/esm2022/form-fields/selection-matrix-fields/selection-matrix-fields.component.mjs +27 -0
- package/esm2022/form-fields/signature-fields/signature-fields.component.mjs +29 -0
- package/esm2022/form-fields/slider-fields/slider-fields.component.mjs +60 -0
- package/esm2022/form-fields/terms-and-condition-fields/terms-and-condition-fields.component.mjs +27 -0
- package/esm2022/form-fields/text-area-fields/text-area-fields.component.mjs +61 -0
- package/esm2022/form-fields/text-fields/text-fields.component.mjs +86 -0
- package/esm2022/form-fields/toggle-switch-fields/toggle-switch-fields.component.mjs +42 -0
- package/esm2022/form-fields/url-fields/url-fields.component.mjs +59 -0
- package/esm2022/form-submission/form-submission.module.mjs +42 -0
- package/esm2022/form-submission/header/header.component.mjs +16 -0
- package/esm2022/form-submission/logic/logic.component.mjs +17 -0
- package/esm2022/form-submission/navigation-tabs/navigation-tabs.component.mjs +27 -0
- package/esm2022/form-submission/next-prev-navigation/next-prev-navigation.component.mjs +42 -0
- package/esm2022/form-submission/submit-form/submit-form.component.mjs +157 -0
- package/esm2022/lib/form-submission.component.mjs +23 -0
- package/esm2022/lib/form-submission.module.mjs +45 -0
- package/esm2022/lib/form-submission.service.mjs +14 -0
- package/esm2022/logic/logic/logic.component.mjs +17 -0
- package/esm2022/logic/logic.module.mjs +20 -0
- package/esm2022/models/appearance.model.mjs +2 -0
- package/esm2022/models/elementOptionAPI.model.mjs +2 -0
- package/esm2022/models/elementOptionAPIData.model.mjs +2 -0
- package/esm2022/models/elementOptionDB.model.mjs +2 -0
- package/esm2022/models/elementOptionDBCriteria.model.mjs +2 -0
- package/esm2022/models/enum/condition.enum.mjs +18 -0
- package/esm2022/models/enum/elementType .enum.mjs +24 -0
- package/esm2022/models/enum/entityType.enum.mjs +12 -0
- package/esm2022/models/formConfiguration.model.mjs +2 -0
- package/esm2022/models/formElement.model.mjs +2 -0
- package/esm2022/models/formElementType.model.mjs +2 -0
- package/esm2022/models/grid.model.mjs +2 -0
- package/esm2022/models/logic.model.mjs +2 -0
- package/esm2022/models/option.model.mjs +2 -0
- package/esm2022/models/page.model.mjs +2 -0
- package/esm2022/models/publicForm.model.mjs +2 -0
- package/esm2022/models/question.model.mjs +2 -0
- package/esm2022/models/row.model.mjs +2 -0
- package/esm2022/models/section.model.mjs +2 -0
- package/esm2022/models/subForm.model.mjs +2 -0
- package/esm2022/models/validation.model.mjs +2 -0
- package/esm2022/piserve-tech-form-submission.mjs +5 -0
- package/esm2022/public-api.mjs +7 -0
- package/esm2022/services/countryService.mjs +65 -0
- package/esm2022/services/data.service.mjs +26 -0
- package/esm2022/services/form.service.mjs +43 -0
- package/esm2022/services/mapper.service.mjs +256 -0
- package/fesm2022/piserve-tech-form-submission.mjs +2558 -0
- package/fesm2022/piserve-tech-form-submission.mjs.map +1 -0
- package/form-fields/check-box-fields/check-box-fields.component.d.ts +42 -0
- package/form-fields/date-time-fields/date-time-fields.component.d.ts +41 -0
- package/form-fields/drop-down-fields/drop-down-fields.component.d.ts +45 -0
- package/form-fields/file-picker-fields/file-picker-fields.component.d.ts +24 -0
- package/form-fields/form-fields.module.d.ts +36 -0
- package/form-fields/location-fields/location-fields.component.d.ts +24 -0
- package/form-fields/mail-fields/mail-fields.component.d.ts +21 -0
- package/form-fields/mobile-fields/mobile-fields.component.d.ts +45 -0
- package/form-fields/number-fields/number-fields.component.d.ts +22 -0
- package/form-fields/password-fields/password-fields.component.d.ts +35 -0
- package/form-fields/radio-button-fields/radio-button-fields.component.d.ts +39 -0
- package/form-fields/rich-text-editor-fields/rich-text-editor-fields.component.d.ts +24 -0
- package/form-fields/section-fields/section-fields.component.d.ts +6 -0
- package/form-fields/selection-matrix-fields/selection-matrix-fields.component.d.ts +10 -0
- package/form-fields/signature-fields/signature-fields.component.d.ts +12 -0
- package/form-fields/slider-fields/slider-fields.component.d.ts +25 -0
- package/form-fields/terms-and-condition-fields/terms-and-condition-fields.component.d.ts +10 -0
- package/form-fields/text-area-fields/text-area-fields.component.d.ts +22 -0
- package/form-fields/text-fields/text-fields.component.d.ts +30 -0
- package/form-fields/toggle-switch-fields/toggle-switch-fields.component.d.ts +16 -0
- package/form-fields/url-fields/url-fields.component.d.ts +22 -0
- package/form-submission/form-submission.module.d.ts +14 -0
- package/form-submission/header/header.component.d.ts +6 -0
- package/form-submission/logic/logic.component.d.ts +6 -0
- package/form-submission/navigation-tabs/navigation-tabs.component.d.ts +10 -0
- package/form-submission/next-prev-navigation/next-prev-navigation.component.d.ts +15 -0
- package/form-submission/submit-form/submit-form.component.d.ts +43 -0
- package/index.d.ts +5 -0
- package/lib/form-submission.component.d.ts +10 -0
- package/lib/form-submission.module.d.ts +14 -0
- package/lib/form-submission.service.d.ts +6 -0
- package/logic/logic/logic.component.d.ts +6 -0
- package/logic/logic.module.d.ts +8 -0
- package/models/appearance.model.d.ts +48 -0
- package/models/elementOptionAPI.model.d.ts +11 -0
- package/models/elementOptionAPIData.model.d.ts +5 -0
- package/models/elementOptionDB.model.d.ts +7 -0
- package/models/elementOptionDBCriteria.model.d.ts +7 -0
- package/models/enum/condition.enum.d.ts +16 -0
- package/models/enum/elementType .enum.d.ts +22 -0
- package/models/enum/entityType.enum.d.ts +10 -0
- package/models/formConfiguration.model.d.ts +16 -0
- package/models/formElement.model.d.ts +12 -0
- package/models/formElementType.model.d.ts +5 -0
- package/models/grid.model.d.ts +8 -0
- package/models/logic.model.d.ts +8 -0
- package/models/option.model.d.ts +11 -0
- package/models/page.model.d.ts +5 -0
- package/models/publicForm.model.d.ts +7 -0
- package/models/question.model.d.ts +14 -0
- package/models/row.model.d.ts +4 -0
- package/models/section.model.d.ts +5 -0
- package/models/subForm.model.d.ts +8 -0
- package/models/validation.model.d.ts +44 -0
- package/package.json +43 -0
- package/public-api.d.ts +3 -0
- package/services/countryService.d.ts +21 -0
- package/services/data.service.d.ts +13 -0
- package/services/form.service.d.ts +17 -0
- package/services/mapper.service.d.ts +10 -0
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { CheckBoxFieldsComponent } from './check-box-fields/check-box-fields.component';
|
|
4
|
+
import { DateTimeFieldsComponent } from './date-time-fields/date-time-fields.component';
|
|
5
|
+
import { DropDownFieldsComponent } from './drop-down-fields/drop-down-fields.component';
|
|
6
|
+
import { FilePickerFieldsComponent } from './file-picker-fields/file-picker-fields.component';
|
|
7
|
+
import { LocationFieldsComponent } from './location-fields/location-fields.component';
|
|
8
|
+
import { RadioButtonFieldsComponent } from './radio-button-fields/radio-button-fields.component';
|
|
9
|
+
import { RichTextEditorFieldsComponent } from './rich-text-editor-fields/rich-text-editor-fields.component';
|
|
10
|
+
import { SelectionMatrixFieldsComponent } from './selection-matrix-fields/selection-matrix-fields.component';
|
|
11
|
+
import { SignatureFieldsComponent } from './signature-fields/signature-fields.component';
|
|
12
|
+
import { SliderFieldsComponent } from './slider-fields/slider-fields.component';
|
|
13
|
+
import { TermsAndConditionFieldsComponent } from './terms-and-condition-fields/terms-and-condition-fields.component';
|
|
14
|
+
import { TextAreaFieldsComponent } from './text-area-fields/text-area-fields.component';
|
|
15
|
+
import { TextFieldsComponent } from './text-fields/text-fields.component';
|
|
16
|
+
import { ToggleSwitchFieldsComponent } from './toggle-switch-fields/toggle-switch-fields.component';
|
|
17
|
+
import { UrlFieldsComponent } from './url-fields/url-fields.component';
|
|
18
|
+
import { FormsModule } from '@angular/forms';
|
|
19
|
+
import { MailFieldsComponent } from './mail-fields/mail-fields.component';
|
|
20
|
+
import { MobileFieldsComponent } from './mobile-fields/mobile-fields.component';
|
|
21
|
+
import { NumberFieldsComponent } from './number-fields/number-fields.component';
|
|
22
|
+
import { PasswordFieldsComponent } from './password-fields/password-fields.component';
|
|
23
|
+
import { MatSliderModule } from "@angular/material/slider";
|
|
24
|
+
import { BsDatepickerModule } from 'ngx-bootstrap/datepicker';
|
|
25
|
+
import { AngularEditorModule } from '@kolkov/angular-editor';
|
|
26
|
+
import { DocUploadModule } from '@piserve-tech/file-upload';
|
|
27
|
+
import { BrowserModule } from '@angular/platform-browser';
|
|
28
|
+
import { GoogleMapsModule } from '@angular/google-maps';
|
|
29
|
+
import { DropdownModule } from '@piserve-tech/drop-down';
|
|
30
|
+
import { FilePreviewModule } from '@piserve-tech/file-preview';
|
|
31
|
+
import { SectionFieldsComponent } from './section-fields/section-fields.component';
|
|
32
|
+
import * as i0 from "@angular/core";
|
|
33
|
+
import * as i1 from "ngx-bootstrap/datepicker";
|
|
34
|
+
export class FormFieldsModule {
|
|
35
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FormFieldsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
36
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: FormFieldsModule, declarations: [CheckBoxFieldsComponent,
|
|
37
|
+
DateTimeFieldsComponent,
|
|
38
|
+
DropDownFieldsComponent,
|
|
39
|
+
FilePickerFieldsComponent,
|
|
40
|
+
LocationFieldsComponent,
|
|
41
|
+
RadioButtonFieldsComponent,
|
|
42
|
+
RichTextEditorFieldsComponent,
|
|
43
|
+
SelectionMatrixFieldsComponent,
|
|
44
|
+
SignatureFieldsComponent,
|
|
45
|
+
SliderFieldsComponent,
|
|
46
|
+
TermsAndConditionFieldsComponent,
|
|
47
|
+
TextAreaFieldsComponent,
|
|
48
|
+
TextFieldsComponent,
|
|
49
|
+
ToggleSwitchFieldsComponent,
|
|
50
|
+
UrlFieldsComponent,
|
|
51
|
+
MailFieldsComponent,
|
|
52
|
+
MobileFieldsComponent,
|
|
53
|
+
NumberFieldsComponent,
|
|
54
|
+
PasswordFieldsComponent,
|
|
55
|
+
SectionFieldsComponent], imports: [CommonModule,
|
|
56
|
+
FormsModule,
|
|
57
|
+
MatSliderModule, i1.BsDatepickerModule, DropdownModule,
|
|
58
|
+
AngularEditorModule,
|
|
59
|
+
DocUploadModule,
|
|
60
|
+
BrowserModule,
|
|
61
|
+
GoogleMapsModule,
|
|
62
|
+
FilePreviewModule], exports: [CheckBoxFieldsComponent,
|
|
63
|
+
DateTimeFieldsComponent,
|
|
64
|
+
DropDownFieldsComponent,
|
|
65
|
+
FilePickerFieldsComponent,
|
|
66
|
+
LocationFieldsComponent,
|
|
67
|
+
MailFieldsComponent,
|
|
68
|
+
MobileFieldsComponent,
|
|
69
|
+
NumberFieldsComponent,
|
|
70
|
+
PasswordFieldsComponent,
|
|
71
|
+
RadioButtonFieldsComponent,
|
|
72
|
+
RichTextEditorFieldsComponent,
|
|
73
|
+
SelectionMatrixFieldsComponent,
|
|
74
|
+
SignatureFieldsComponent,
|
|
75
|
+
SliderFieldsComponent,
|
|
76
|
+
TermsAndConditionFieldsComponent,
|
|
77
|
+
TextAreaFieldsComponent,
|
|
78
|
+
TextFieldsComponent,
|
|
79
|
+
ToggleSwitchFieldsComponent,
|
|
80
|
+
UrlFieldsComponent,
|
|
81
|
+
SectionFieldsComponent] }); }
|
|
82
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FormFieldsModule, imports: [CommonModule,
|
|
83
|
+
FormsModule,
|
|
84
|
+
MatSliderModule,
|
|
85
|
+
BsDatepickerModule.forRoot(),
|
|
86
|
+
DropdownModule,
|
|
87
|
+
AngularEditorModule,
|
|
88
|
+
DocUploadModule,
|
|
89
|
+
BrowserModule,
|
|
90
|
+
GoogleMapsModule,
|
|
91
|
+
FilePreviewModule] }); }
|
|
92
|
+
}
|
|
93
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FormFieldsModule, decorators: [{
|
|
94
|
+
type: NgModule,
|
|
95
|
+
args: [{
|
|
96
|
+
declarations: [
|
|
97
|
+
CheckBoxFieldsComponent,
|
|
98
|
+
DateTimeFieldsComponent,
|
|
99
|
+
DropDownFieldsComponent,
|
|
100
|
+
FilePickerFieldsComponent,
|
|
101
|
+
LocationFieldsComponent,
|
|
102
|
+
RadioButtonFieldsComponent,
|
|
103
|
+
RichTextEditorFieldsComponent,
|
|
104
|
+
SelectionMatrixFieldsComponent,
|
|
105
|
+
SignatureFieldsComponent,
|
|
106
|
+
SliderFieldsComponent,
|
|
107
|
+
TermsAndConditionFieldsComponent,
|
|
108
|
+
TextAreaFieldsComponent,
|
|
109
|
+
TextFieldsComponent,
|
|
110
|
+
ToggleSwitchFieldsComponent,
|
|
111
|
+
UrlFieldsComponent,
|
|
112
|
+
MailFieldsComponent,
|
|
113
|
+
MobileFieldsComponent,
|
|
114
|
+
NumberFieldsComponent,
|
|
115
|
+
PasswordFieldsComponent,
|
|
116
|
+
SectionFieldsComponent
|
|
117
|
+
],
|
|
118
|
+
imports: [
|
|
119
|
+
CommonModule,
|
|
120
|
+
FormsModule,
|
|
121
|
+
MatSliderModule,
|
|
122
|
+
BsDatepickerModule.forRoot(),
|
|
123
|
+
DropdownModule,
|
|
124
|
+
AngularEditorModule,
|
|
125
|
+
DocUploadModule,
|
|
126
|
+
BrowserModule,
|
|
127
|
+
GoogleMapsModule,
|
|
128
|
+
FilePreviewModule
|
|
129
|
+
],
|
|
130
|
+
exports: [
|
|
131
|
+
CheckBoxFieldsComponent,
|
|
132
|
+
DateTimeFieldsComponent,
|
|
133
|
+
DropDownFieldsComponent,
|
|
134
|
+
FilePickerFieldsComponent,
|
|
135
|
+
LocationFieldsComponent,
|
|
136
|
+
MailFieldsComponent,
|
|
137
|
+
MobileFieldsComponent,
|
|
138
|
+
NumberFieldsComponent,
|
|
139
|
+
PasswordFieldsComponent,
|
|
140
|
+
RadioButtonFieldsComponent,
|
|
141
|
+
RichTextEditorFieldsComponent,
|
|
142
|
+
SelectionMatrixFieldsComponent,
|
|
143
|
+
SignatureFieldsComponent,
|
|
144
|
+
SliderFieldsComponent,
|
|
145
|
+
TermsAndConditionFieldsComponent,
|
|
146
|
+
TextAreaFieldsComponent,
|
|
147
|
+
TextFieldsComponent,
|
|
148
|
+
ToggleSwitchFieldsComponent,
|
|
149
|
+
UrlFieldsComponent,
|
|
150
|
+
SectionFieldsComponent
|
|
151
|
+
]
|
|
152
|
+
}]
|
|
153
|
+
}] });
|
|
154
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-fields.module.js","sourceRoot":"","sources":["../../../../projects/form-submission/src/form-fields/form-fields.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CheckBoxFieldsComponent } from './check-box-fields/check-box-fields.component';\r\nimport { DateTimeFieldsComponent } from './date-time-fields/date-time-fields.component';\r\nimport { DropDownFieldsComponent } from './drop-down-fields/drop-down-fields.component';\r\nimport { FilePickerFieldsComponent } from './file-picker-fields/file-picker-fields.component';\r\nimport { LocationFieldsComponent } from './location-fields/location-fields.component';\r\nimport { RadioButtonFieldsComponent } from './radio-button-fields/radio-button-fields.component';\r\nimport { RichTextEditorFieldsComponent } from './rich-text-editor-fields/rich-text-editor-fields.component';\r\nimport { SelectionMatrixFieldsComponent } from './selection-matrix-fields/selection-matrix-fields.component';\r\nimport { SignatureFieldsComponent } from './signature-fields/signature-fields.component';\r\nimport { SliderFieldsComponent } from './slider-fields/slider-fields.component';\r\nimport { TermsAndConditionFieldsComponent } from './terms-and-condition-fields/terms-and-condition-fields.component';\r\nimport { TextAreaFieldsComponent } from './text-area-fields/text-area-fields.component';\r\nimport { TextFieldsComponent } from './text-fields/text-fields.component';\r\nimport { ToggleSwitchFieldsComponent } from './toggle-switch-fields/toggle-switch-fields.component';\r\nimport { UrlFieldsComponent } from './url-fields/url-fields.component';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { MailFieldsComponent } from './mail-fields/mail-fields.component';\r\nimport { MobileFieldsComponent } from './mobile-fields/mobile-fields.component';\r\nimport { NumberFieldsComponent } from './number-fields/number-fields.component';\r\nimport { PasswordFieldsComponent } from './password-fields/password-fields.component';\r\nimport {MatSliderModule} from \"@angular/material/slider\";\r\nimport { BsDatepickerModule } from 'ngx-bootstrap/datepicker';\r\nimport { AngularEditorModule } from '@kolkov/angular-editor';\r\nimport { DocUploadModule } from '@piserve-tech/file-upload';\r\n\r\nimport { BrowserModule } from '@angular/platform-browser';\r\nimport { GoogleMapsModule } from '@angular/google-maps';\r\nimport { DropdownModule } from '@piserve-tech/drop-down';\r\nimport { FilePreviewModule } from '@piserve-tech/file-preview';\r\nimport { SectionFieldsComponent } from './section-fields/section-fields.component';\r\n\r\n\r\n\r\n\r\n\r\n\r\n@NgModule({\r\n  declarations: [\r\n    CheckBoxFieldsComponent,\r\n    DateTimeFieldsComponent,\r\n    DropDownFieldsComponent,\r\n    FilePickerFieldsComponent,\r\n    LocationFieldsComponent,\r\n    RadioButtonFieldsComponent,\r\n    RichTextEditorFieldsComponent,\r\n    SelectionMatrixFieldsComponent,\r\n    SignatureFieldsComponent,\r\n    SliderFieldsComponent,\r\n    TermsAndConditionFieldsComponent,\r\n    TextAreaFieldsComponent,\r\n    TextFieldsComponent,\r\n    ToggleSwitchFieldsComponent,\r\n    UrlFieldsComponent,\r\n    MailFieldsComponent,\r\n    MobileFieldsComponent,\r\n    NumberFieldsComponent,\r\n    PasswordFieldsComponent,\r\n    SectionFieldsComponent\r\n  ],\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    MatSliderModule,\r\n    BsDatepickerModule.forRoot(),\r\n    DropdownModule,\r\n    AngularEditorModule,\r\n    DocUploadModule,\r\n    BrowserModule,\r\n    GoogleMapsModule,\r\n    FilePreviewModule\r\n  ],\r\n  exports: [\r\n    CheckBoxFieldsComponent,\r\n    DateTimeFieldsComponent,\r\n    DropDownFieldsComponent,\r\n    FilePickerFieldsComponent,\r\n    LocationFieldsComponent,\r\n    MailFieldsComponent,\r\n    MobileFieldsComponent,\r\n    NumberFieldsComponent,\r\n    PasswordFieldsComponent,\r\n    RadioButtonFieldsComponent,\r\n    RichTextEditorFieldsComponent,\r\n    SelectionMatrixFieldsComponent,\r\n    SignatureFieldsComponent,\r\n    SliderFieldsComponent,\r\n    TermsAndConditionFieldsComponent,\r\n    TextAreaFieldsComponent,\r\n    TextFieldsComponent,\r\n    ToggleSwitchFieldsComponent,\r\n    UrlFieldsComponent,\r\n    SectionFieldsComponent\r\n\r\n  ]\r\n})\r\nexport class FormFieldsModule { }\r\n"]}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { Component, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import { GoogleMap } from '@angular/google-maps';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "@angular/google-maps";
|
|
6
|
+
export class LocationFieldsComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.question = {};
|
|
9
|
+
this.count = 0;
|
|
10
|
+
this.required = false;
|
|
11
|
+
this.hint = '';
|
|
12
|
+
this.defaultZoomLevel = 0;
|
|
13
|
+
this.setCurrentPosition = false;
|
|
14
|
+
this.allowFullScreen = false;
|
|
15
|
+
this.latitude = 0;
|
|
16
|
+
this.longitude = 0;
|
|
17
|
+
this.regionBoundary = false;
|
|
18
|
+
this.region = '';
|
|
19
|
+
this.mapConfigurations = {};
|
|
20
|
+
}
|
|
21
|
+
ngOnInit() {
|
|
22
|
+
this.count = this.question.count;
|
|
23
|
+
this.required = this.question.required;
|
|
24
|
+
this.hint = this.question.hint;
|
|
25
|
+
this.defaultZoomLevel =
|
|
26
|
+
this.question.formElement.appearance.defaultZoomLevel;
|
|
27
|
+
this.setCurrentPosition =
|
|
28
|
+
this.question.formElement.appearance.setCurrentPosition;
|
|
29
|
+
this.allowFullScreen = this.question.formElement.appearance.allowFullScreen;
|
|
30
|
+
this.latitude = this.question.formElement.appearance.latitude;
|
|
31
|
+
this.longitude = this.question.formElement.appearance.longitude;
|
|
32
|
+
this.regionBoundary = this.question.formElement.validation.regionBoundary;
|
|
33
|
+
this.region = this.question.formElement.validation.region;
|
|
34
|
+
this.mapConfigurations = {
|
|
35
|
+
disableDefaultUI: true,
|
|
36
|
+
fullscreenControl: this.allowFullScreen,
|
|
37
|
+
zoomControl: true,
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
ngAfterViewInit() {
|
|
41
|
+
const searchBox = new google.maps.places.SearchBox(this.searchField.nativeElement);
|
|
42
|
+
this.map.controls[google.maps.ControlPosition.TOP_CENTER].push(this.searchField.nativeElement);
|
|
43
|
+
searchBox.addListener('places_changed', () => {
|
|
44
|
+
const places = searchBox.getPlaces();
|
|
45
|
+
if (places?.length === 0) {
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
const bounds = new google.maps.LatLngBounds();
|
|
49
|
+
places?.forEach((place) => {
|
|
50
|
+
if (!place.geometry || !place.geometry.location) {
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
if (place.geometry.viewport) {
|
|
54
|
+
// Only geocodes have viewport.
|
|
55
|
+
bounds.union(place.geometry.viewport);
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
bounds.extend(place.geometry.location);
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
this.map.fitBounds(bounds);
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LocationFieldsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
65
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: LocationFieldsComponent, selector: "lib-location-fields", inputs: { question: "question" }, viewQueries: [{ propertyName: "searchField", first: true, predicate: ["mapSearchField"], descendants: true }, { propertyName: "map", first: true, predicate: GoogleMap, descendants: true }], ngImport: i0, template: "<div [ngClass]=\"'col-' + count\" class=\"mb-4 px-3\">\r\n <div class=\"input-wrapper\">\r\n <label>{{ question.question }}</label> \r\n <span class=\"text-danger\" *ngIf=\"required\">*</span>\r\n <div class=\"svg-wrapper mb-2 hintIcon\" [attr.data-title]=\"hint\" *ngIf=\"hint\">\r\n <svg class=\"hintSvg\" viewBox=\"0 0 30 30\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M15 26.25V26.25C8.78625 26.25 3.75 21.2138 3.75 15V15C3.75 8.78625 8.78625 3.75 15 3.75V3.75C21.2138 3.75 26.25 8.78625 26.25 15V15C26.25 21.2138 21.2138 26.25 15 26.25Z\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M15 16.5623V16.2498C15 15.2285 15.6312 14.6748 16.2637 14.2498C16.8812 13.8335 17.5 13.291 17.5 12.291C17.5 10.9098 16.3813 9.79102 15 9.79102C13.6187 9.79102 12.5 10.9098 12.5 12.291\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M14.9988 20C14.8263 20 14.6863 20.14 14.6875 20.3125C14.6875 20.485 14.8275 20.625 15 20.625C15.1725 20.625 15.3125 20.485 15.3125 20.3125C15.3125 20.14 15.1725 20 14.9988 20\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n </div>\r\n</div>\r\n <div class=\"input-group\">\r\n <input\r\n type=\"text\"\r\n class=\"form-control location-input\"\r\n placeholder=\"Enter location\"\r\n #locationInput\r\n />\r\n </div>\r\n\r\n <input #mapSearchField class=\"my-map-search-field\" type=\"text\"/>\r\n <google-map\r\n width=\"100%\"\r\n [options]=\"mapConfigurations\"\r\n ></google-map>\r\n</div>", styles: [".input-wrapper{display:flex;align-items:flex-start}.svg-wrapper{margin-left:auto;z-index:999}.hintIcon{position:relative;cursor:pointer}.hintIcon:hover:before{content:attr(data-title);position:absolute;top:calc(100% + 2px);left:50%;transform:translate(-50%);padding:4px 8px;border-radius:4px;background-color:#1d252d;color:#8e9aa0;font-size:14px;white-space:nowrap}.hintIcon:hover:after{content:\"\";position:absolute;top:calc(100% - 26px);left:50%;border:solid transparent;border-width:18px;border-bottom-color:#1d252d;transform:translate(-50%)}.height{height:42px}.invalid{border-color:red}.hintSvg{width:30px;height:30px;fill:none}.validationSvg{width:24px;height:24px;fill:none}.location-input{position:relative}.input-group-append{cursor:pointer;position:absolute;top:50%;right:10px;transform:translateY(-50%)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.GoogleMap, selector: "google-map", inputs: ["height", "width", "mapTypeId", "center", "zoom", "options"], outputs: ["mapInitialized", "authFailure", "boundsChanged", "centerChanged", "mapClick", "mapDblclick", "mapDrag", "mapDragend", "mapDragstart", "headingChanged", "idle", "maptypeidChanged", "mapMousemove", "mapMouseout", "mapMouseover", "projectionChanged", "mapRightclick", "tilesloaded", "tiltChanged", "zoomChanged"], exportAs: ["googleMap"] }] }); }
|
|
66
|
+
}
|
|
67
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LocationFieldsComponent, decorators: [{
|
|
68
|
+
type: Component,
|
|
69
|
+
args: [{ selector: 'lib-location-fields', template: "<div [ngClass]=\"'col-' + count\" class=\"mb-4 px-3\">\r\n <div class=\"input-wrapper\">\r\n <label>{{ question.question }}</label> \r\n <span class=\"text-danger\" *ngIf=\"required\">*</span>\r\n <div class=\"svg-wrapper mb-2 hintIcon\" [attr.data-title]=\"hint\" *ngIf=\"hint\">\r\n <svg class=\"hintSvg\" viewBox=\"0 0 30 30\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M15 26.25V26.25C8.78625 26.25 3.75 21.2138 3.75 15V15C3.75 8.78625 8.78625 3.75 15 3.75V3.75C21.2138 3.75 26.25 8.78625 26.25 15V15C26.25 21.2138 21.2138 26.25 15 26.25Z\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M15 16.5623V16.2498C15 15.2285 15.6312 14.6748 16.2637 14.2498C16.8812 13.8335 17.5 13.291 17.5 12.291C17.5 10.9098 16.3813 9.79102 15 9.79102C13.6187 9.79102 12.5 10.9098 12.5 12.291\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M14.9988 20C14.8263 20 14.6863 20.14 14.6875 20.3125C14.6875 20.485 14.8275 20.625 15 20.625C15.1725 20.625 15.3125 20.485 15.3125 20.3125C15.3125 20.14 15.1725 20 14.9988 20\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n </div>\r\n</div>\r\n <div class=\"input-group\">\r\n <input\r\n type=\"text\"\r\n class=\"form-control location-input\"\r\n placeholder=\"Enter location\"\r\n #locationInput\r\n />\r\n </div>\r\n\r\n <input #mapSearchField class=\"my-map-search-field\" type=\"text\"/>\r\n <google-map\r\n width=\"100%\"\r\n [options]=\"mapConfigurations\"\r\n ></google-map>\r\n</div>", styles: [".input-wrapper{display:flex;align-items:flex-start}.svg-wrapper{margin-left:auto;z-index:999}.hintIcon{position:relative;cursor:pointer}.hintIcon:hover:before{content:attr(data-title);position:absolute;top:calc(100% + 2px);left:50%;transform:translate(-50%);padding:4px 8px;border-radius:4px;background-color:#1d252d;color:#8e9aa0;font-size:14px;white-space:nowrap}.hintIcon:hover:after{content:\"\";position:absolute;top:calc(100% - 26px);left:50%;border:solid transparent;border-width:18px;border-bottom-color:#1d252d;transform:translate(-50%)}.height{height:42px}.invalid{border-color:red}.hintSvg{width:30px;height:30px;fill:none}.validationSvg{width:24px;height:24px;fill:none}.location-input{position:relative}.input-group-append{cursor:pointer;position:absolute;top:50%;right:10px;transform:translateY(-50%)}\n"] }]
|
|
70
|
+
}], propDecorators: { question: [{
|
|
71
|
+
type: Input
|
|
72
|
+
}], searchField: [{
|
|
73
|
+
type: ViewChild,
|
|
74
|
+
args: ['mapSearchField']
|
|
75
|
+
}], map: [{
|
|
76
|
+
type: ViewChild,
|
|
77
|
+
args: [GoogleMap]
|
|
78
|
+
}] } });
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"location-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/location-fields/location-fields.component.ts","../../../../../projects/form-submission/src/form-fields/location-fields/location-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ViewChild, ElementRef } from '@angular/core';\r\nimport { GoogleMap } from '@angular/google-maps';\r\n\r\n@Component({\r\n  selector: 'lib-location-fields',\r\n  templateUrl: './location-fields.component.html',\r\n  styleUrls: ['./location-fields.component.scss'],\r\n})\r\nexport class LocationFieldsComponent {\r\n  @Input() question: any = {};\r\n  @ViewChild('mapSearchField')\r\n  searchField!: ElementRef;\r\n  @ViewChild(GoogleMap) map!: GoogleMap;\r\n\r\n  count: number = 0;\r\n  required: boolean = false;\r\n  hint: string = '';\r\n  defaultZoomLevel: number = 0;\r\n  setCurrentPosition: boolean = false;\r\n  allowFullScreen: boolean = false;\r\n  latitude: number = 0;\r\n  longitude: number = 0;\r\n  regionBoundary: boolean = false;\r\n  region: string = '';\r\n  showGoogleMap!: boolean;\r\n  mapConfigurations: any = {};\r\n\r\n  ngOnInit() {\r\n    this.count = this.question.count;\r\n    this.required = this.question.required;\r\n    this.hint = this.question.hint;\r\n    this.defaultZoomLevel =\r\n      this.question.formElement.appearance.defaultZoomLevel;\r\n    this.setCurrentPosition =\r\n      this.question.formElement.appearance.setCurrentPosition;\r\n    this.allowFullScreen = this.question.formElement.appearance.allowFullScreen;\r\n    this.latitude = this.question.formElement.appearance.latitude;\r\n    this.longitude = this.question.formElement.appearance.longitude;\r\n    this.regionBoundary = this.question.formElement.validation.regionBoundary;\r\n    this.region = this.question.formElement.validation.region;\r\n    this.mapConfigurations = {\r\n      disableDefaultUI: true,\r\n      fullscreenControl: this.allowFullScreen,\r\n      zoomControl: true,\r\n    };\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const searchBox = new google.maps.places.SearchBox(\r\n      this.searchField.nativeElement\r\n    );\r\n\r\n    this.map.controls[google.maps.ControlPosition.TOP_CENTER].push(\r\n      this.searchField.nativeElement\r\n    );\r\n\r\n    searchBox.addListener('places_changed', () => {\r\n      const places = searchBox.getPlaces();\r\n      if (places?.length === 0) {\r\n        return;\r\n      }\r\n\r\n      const bounds = new google.maps.LatLngBounds();\r\n      places?.forEach((place) => {\r\n        if (!place.geometry || !place.geometry.location) {\r\n          return;\r\n        }\r\n\r\n        if (place.geometry.viewport) {\r\n          // Only geocodes have viewport.\r\n          bounds.union(place.geometry.viewport);\r\n        } else {\r\n          bounds.extend(place.geometry.location);\r\n        }\r\n      });\r\n\r\n      this.map.fitBounds(bounds);\r\n    });\r\n  }\r\n}\r\n","<div [ngClass]=\"'col-' + count\" class=\"mb-4 px-3\">\r\n  <div  class=\"input-wrapper\">\r\n  <label>{{ question.question }}</label>&nbsp;\r\n  <span class=\"text-danger\" *ngIf=\"required\">*</span>\r\n  <div class=\"svg-wrapper  mb-2 hintIcon\" [attr.data-title]=\"hint\" *ngIf=\"hint\">\r\n    <svg class=\"hintSvg\"  viewBox=\"0 0 30 30\"  xmlns=\"http://www.w3.org/2000/svg\">\r\n      <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M15 26.25V26.25C8.78625 26.25 3.75 21.2138 3.75 15V15C3.75 8.78625 8.78625 3.75 15 3.75V3.75C21.2138 3.75 26.25 8.78625 26.25 15V15C26.25 21.2138 21.2138 26.25 15 26.25Z\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n      <path d=\"M15 16.5623V16.2498C15 15.2285 15.6312 14.6748 16.2637 14.2498C16.8812 13.8335 17.5 13.291 17.5 12.291C17.5 10.9098 16.3813 9.79102 15 9.79102C13.6187 9.79102 12.5 10.9098 12.5 12.291\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n      <path d=\"M14.9988 20C14.8263 20 14.6863 20.14 14.6875 20.3125C14.6875 20.485 14.8275 20.625 15 20.625C15.1725 20.625 15.3125 20.485 15.3125 20.3125C15.3125 20.14 15.1725 20 14.9988 20\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n    </svg>\r\n  </div>\r\n</div>\r\n  <div class=\"input-group\">\r\n    <input\r\n      type=\"text\"\r\n      class=\"form-control location-input\"\r\n      placeholder=\"Enter location\"\r\n      #locationInput\r\n    />\r\n  </div>\r\n\r\n  <input #mapSearchField class=\"my-map-search-field\" type=\"text\"/>\r\n  <google-map\r\n    width=\"100%\"\r\n    [options]=\"mapConfigurations\"\r\n  ></google-map>\r\n</div>"]}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "@angular/forms";
|
|
5
|
+
export class MailFieldsComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.question = {};
|
|
8
|
+
this.count = 0;
|
|
9
|
+
this.required = false;
|
|
10
|
+
this.hint = '';
|
|
11
|
+
this.placeholder = '';
|
|
12
|
+
this.expectedDomains = [];
|
|
13
|
+
this.regularExpression = '';
|
|
14
|
+
this.email = '';
|
|
15
|
+
this.validationFailed = false;
|
|
16
|
+
this.validationMessage = '';
|
|
17
|
+
this.validate = new EventEmitter();
|
|
18
|
+
}
|
|
19
|
+
ngOnInit() {
|
|
20
|
+
this.valueAssigned();
|
|
21
|
+
}
|
|
22
|
+
valueAssigned() {
|
|
23
|
+
this.count = this.question.count;
|
|
24
|
+
this.required = this.question.required;
|
|
25
|
+
this.hint = this.question.hint;
|
|
26
|
+
this.placeholder = this.question.formElement.appearance.placeholder;
|
|
27
|
+
this.expectedDomains =
|
|
28
|
+
this.question?.formElement?.validation?.expectedDomains
|
|
29
|
+
?.split(',')
|
|
30
|
+
.map((domain) => domain.trim());
|
|
31
|
+
this.regularExpression =
|
|
32
|
+
this.question.formElement.validation.regularExpression;
|
|
33
|
+
}
|
|
34
|
+
validateEmail() {
|
|
35
|
+
this.validationFailed = false;
|
|
36
|
+
this.validationMessage = '';
|
|
37
|
+
const enteredEmail = this.email.trim().toLowerCase();
|
|
38
|
+
if (this.required && !this.email) {
|
|
39
|
+
this.validationFailed = true;
|
|
40
|
+
this.validationMessage = 'This is a required question';
|
|
41
|
+
this.validate.emit(this.validationFailed);
|
|
42
|
+
this.question.validation = false;
|
|
43
|
+
}
|
|
44
|
+
else if (this.expectedDomains) {
|
|
45
|
+
const isValidEmail = this.expectedDomains?.some((domain) => enteredEmail.endsWith(domain));
|
|
46
|
+
this.validationFailed = !isValidEmail;
|
|
47
|
+
this.validationMessage = 'Please enter valid email address';
|
|
48
|
+
if (this.validationFailed) {
|
|
49
|
+
this.validate.emit(this.validationFailed);
|
|
50
|
+
this.question.validation = false;
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
this.question.validation = true;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
this.question.validation = true;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
validateInput(event) {
|
|
61
|
+
this.question.answer = event.target.value;
|
|
62
|
+
this.validateEmail();
|
|
63
|
+
}
|
|
64
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MailFieldsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
65
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: MailFieldsComponent, selector: "lib-mail-fields", inputs: { question: "question" }, outputs: { validate: "validate" }, ngImport: i0, template: "<div [ngClass]=\"'col-' + count\" class=\"mb-4 px-3\">\r\n <div class=\"input-wrapper\">\r\n <label>{{ question.question }}</label> \r\n <span class=\"text-danger\" *ngIf=\"required\">*</span>\r\n <div class=\"svg-wrapper mb-2 hintIcon\" [attr.data-title]=\"hint\" *ngIf=\"hint\">\r\n <svg class=\"hintSvg\" viewBox=\"0 0 30 30\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M15 26.25V26.25C8.78625 26.25 3.75 21.2138 3.75 15V15C3.75 8.78625 8.78625 3.75 15 3.75V3.75C21.2138 3.75 26.25 8.78625 26.25 15V15C26.25 21.2138 21.2138 26.25 15 26.25Z\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M15 16.5623V16.2498C15 15.2285 15.6312 14.6748 16.2637 14.2498C16.8812 13.8335 17.5 13.291 17.5 12.291C17.5 10.9098 16.3813 9.79102 15 9.79102C13.6187 9.79102 12.5 10.9098 12.5 12.291\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M14.9988 20C14.8263 20 14.6863 20.14 14.6875 20.3125C14.6875 20.485 14.8275 20.625 15 20.625C15.1725 20.625 15.3125 20.485 15.3125 20.3125C15.3125 20.14 15.1725 20 14.9988 20\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n </div>\r\n</div>\r\n <input\r\n type=\"email\"\r\n class=\"form-control mb-2 height\"\r\n [placeholder]=\"placeholder\"\r\n [(ngModel)]=\"email\"\r\n (blur)=\"validateEmail()\"\r\n (input)=\"validateInput($event)\"\r\n [class.invalid]=\"validationFailed\"\r\n />\r\n <div *ngIf=\"validationFailed\" class=\"text-danger\">\r\n <svg class=\"validationSvg\" viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M12.001 16.75C12.139 16.75 12.251 16.638 12.25 16.5C12.25 16.362 12.138 16.25 12 16.25C11.862 16.25 11.75 16.362 11.75 16.5C11.75 16.638 11.862 16.75 12.001 16.75\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 21C7.029 21 3 16.971 3 12C3 7.029 7.029 3 12 3C16.971 3 21 7.029 21 12C21 16.971 16.971 21 12 21Z\" fill=\"#FF0000\" stroke=\"#FF0000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M12 12.75L12 7.75\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\"/>\r\n </svg>\r\n {{validationMessage}}</div>\r\n</div>\r\n", styles: [".input-wrapper{display:flex;align-items:flex-start}.svg-wrapper{margin-left:auto;z-index:999}.hintIcon{position:relative;cursor:pointer}.hintIcon:hover:before{content:attr(data-title);position:absolute;top:calc(100% + 2px);left:50%;transform:translate(-50%);padding:4px 8px;border-radius:4px;background-color:#1d252d;color:#8e9aa0;font-size:14px;white-space:nowrap}.hintIcon:hover:after{content:\"\";position:absolute;top:calc(100% - 26px);left:50%;border:solid transparent;border-width:18px;border-bottom-color:#1d252d;transform:translate(-50%)}.height{height:42px}.invalid{border-color:red}.hintSvg{width:30px;height:30px;fill:none}.validationSvg{width:24px;height:24px;fill:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
|
|
66
|
+
}
|
|
67
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MailFieldsComponent, decorators: [{
|
|
68
|
+
type: Component,
|
|
69
|
+
args: [{ selector: 'lib-mail-fields', template: "<div [ngClass]=\"'col-' + count\" class=\"mb-4 px-3\">\r\n <div class=\"input-wrapper\">\r\n <label>{{ question.question }}</label> \r\n <span class=\"text-danger\" *ngIf=\"required\">*</span>\r\n <div class=\"svg-wrapper mb-2 hintIcon\" [attr.data-title]=\"hint\" *ngIf=\"hint\">\r\n <svg class=\"hintSvg\" viewBox=\"0 0 30 30\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M15 26.25V26.25C8.78625 26.25 3.75 21.2138 3.75 15V15C3.75 8.78625 8.78625 3.75 15 3.75V3.75C21.2138 3.75 26.25 8.78625 26.25 15V15C26.25 21.2138 21.2138 26.25 15 26.25Z\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M15 16.5623V16.2498C15 15.2285 15.6312 14.6748 16.2637 14.2498C16.8812 13.8335 17.5 13.291 17.5 12.291C17.5 10.9098 16.3813 9.79102 15 9.79102C13.6187 9.79102 12.5 10.9098 12.5 12.291\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M14.9988 20C14.8263 20 14.6863 20.14 14.6875 20.3125C14.6875 20.485 14.8275 20.625 15 20.625C15.1725 20.625 15.3125 20.485 15.3125 20.3125C15.3125 20.14 15.1725 20 14.9988 20\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n </div>\r\n</div>\r\n <input\r\n type=\"email\"\r\n class=\"form-control mb-2 height\"\r\n [placeholder]=\"placeholder\"\r\n [(ngModel)]=\"email\"\r\n (blur)=\"validateEmail()\"\r\n (input)=\"validateInput($event)\"\r\n [class.invalid]=\"validationFailed\"\r\n />\r\n <div *ngIf=\"validationFailed\" class=\"text-danger\">\r\n <svg class=\"validationSvg\" viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M12.001 16.75C12.139 16.75 12.251 16.638 12.25 16.5C12.25 16.362 12.138 16.25 12 16.25C11.862 16.25 11.75 16.362 11.75 16.5C11.75 16.638 11.862 16.75 12.001 16.75\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 21C7.029 21 3 16.971 3 12C3 7.029 7.029 3 12 3C16.971 3 21 7.029 21 12C21 16.971 16.971 21 12 21Z\" fill=\"#FF0000\" stroke=\"#FF0000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M12 12.75L12 7.75\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\"/>\r\n </svg>\r\n {{validationMessage}}</div>\r\n</div>\r\n", styles: [".input-wrapper{display:flex;align-items:flex-start}.svg-wrapper{margin-left:auto;z-index:999}.hintIcon{position:relative;cursor:pointer}.hintIcon:hover:before{content:attr(data-title);position:absolute;top:calc(100% + 2px);left:50%;transform:translate(-50%);padding:4px 8px;border-radius:4px;background-color:#1d252d;color:#8e9aa0;font-size:14px;white-space:nowrap}.hintIcon:hover:after{content:\"\";position:absolute;top:calc(100% - 26px);left:50%;border:solid transparent;border-width:18px;border-bottom-color:#1d252d;transform:translate(-50%)}.height{height:42px}.invalid{border-color:red}.hintSvg{width:30px;height:30px;fill:none}.validationSvg{width:24px;height:24px;fill:none}\n"] }]
|
|
70
|
+
}], propDecorators: { question: [{
|
|
71
|
+
type: Input
|
|
72
|
+
}], validate: [{
|
|
73
|
+
type: Output
|
|
74
|
+
}] } });
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mail-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/mail-fields/mail-fields.component.ts","../../../../../projects/form-submission/src/form-fields/mail-fields/mail-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'lib-mail-fields',\r\n  templateUrl: './mail-fields.component.html',\r\n  styleUrls: ['./mail-fields.component.scss'],\r\n})\r\nexport class MailFieldsComponent {\r\n  @Input() question: any = {};\r\n  count: number = 0;\r\n  required: boolean = false;\r\n  hint: string = '';\r\n  placeholder: string = '';\r\n  expectedDomains: string[] = [];\r\n  regularExpression: string = '';\r\n  email: string = '';\r\n  validationFailed: boolean = false;\r\n  validationMessage: string = '';\r\n\r\n  @Output() validate: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n  ngOnInit() {\r\n    this.valueAssigned();\r\n  }\r\n\r\n  valueAssigned() {\r\n    this.count = this.question.count;\r\n    this.required = this.question.required;\r\n    this.hint = this.question.hint;\r\n    this.placeholder = this.question.formElement.appearance.placeholder;\r\n    this.expectedDomains =\r\n      this.question?.formElement?.validation?.expectedDomains\r\n        ?.split(',')\r\n        .map((domain: any) => domain.trim());\r\n    this.regularExpression =\r\n      this.question.formElement.validation.regularExpression;\r\n  }\r\n\r\n  validateEmail() {\r\n    this.validationFailed = false;\r\n    this.validationMessage = '';\r\n    const enteredEmail = this.email.trim().toLowerCase();\r\n    if (this.required && !this.email) {\r\n      this.validationFailed = true;\r\n      this.validationMessage = 'This is a required question';\r\n      this.validate.emit(this.validationFailed);\r\n      this.question.validation = false;\r\n    } else if (this.expectedDomains) {\r\n      const isValidEmail = this.expectedDomains?.some((domain) =>\r\n        enteredEmail.endsWith(domain)\r\n      );\r\n      this.validationFailed = !isValidEmail;\r\n      this.validationMessage = 'Please enter valid email address';\r\n      if (this.validationFailed) {\r\n        this.validate.emit(this.validationFailed);\r\n        this.question.validation = false;\r\n      }\r\n      else {\r\n        this.question.validation = true;\r\n      }\r\n    }\r\n    else {\r\n      this.question.validation = true;\r\n    }\r\n  }\r\n  validateInput(event: any) {\r\n    this.question.answer = event.target.value;\r\n    this.validateEmail();\r\n  }\r\n}\r\n","<div [ngClass]=\"'col-' + count\" class=\"mb-4 px-3\">\r\n  <div  class=\"input-wrapper\">\r\n  <label>{{ question.question }}</label>&nbsp;\r\n  <span class=\"text-danger\" *ngIf=\"required\">*</span>\r\n  <div class=\"svg-wrapper  mb-2 hintIcon\" [attr.data-title]=\"hint\" *ngIf=\"hint\">\r\n    <svg class=\"hintSvg\"  viewBox=\"0 0 30 30\"  xmlns=\"http://www.w3.org/2000/svg\">\r\n      <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M15 26.25V26.25C8.78625 26.25 3.75 21.2138 3.75 15V15C3.75 8.78625 8.78625 3.75 15 3.75V3.75C21.2138 3.75 26.25 8.78625 26.25 15V15C26.25 21.2138 21.2138 26.25 15 26.25Z\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n      <path d=\"M15 16.5623V16.2498C15 15.2285 15.6312 14.6748 16.2637 14.2498C16.8812 13.8335 17.5 13.291 17.5 12.291C17.5 10.9098 16.3813 9.79102 15 9.79102C13.6187 9.79102 12.5 10.9098 12.5 12.291\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n      <path d=\"M14.9988 20C14.8263 20 14.6863 20.14 14.6875 20.3125C14.6875 20.485 14.8275 20.625 15 20.625C15.1725 20.625 15.3125 20.485 15.3125 20.3125C15.3125 20.14 15.1725 20 14.9988 20\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n    </svg>\r\n  </div>\r\n</div>\r\n  <input\r\n    type=\"email\"\r\n    class=\"form-control mb-2 height\"\r\n    [placeholder]=\"placeholder\"\r\n    [(ngModel)]=\"email\"\r\n    (blur)=\"validateEmail()\"\r\n    (input)=\"validateInput($event)\"\r\n    [class.invalid]=\"validationFailed\"\r\n  />\r\n  <div *ngIf=\"validationFailed\" class=\"text-danger\">\r\n    <svg class=\"validationSvg\"  viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\">\r\n      <path d=\"M12.001 16.75C12.139 16.75 12.251 16.638 12.25 16.5C12.25 16.362 12.138 16.25 12 16.25C11.862 16.25 11.75 16.362 11.75 16.5C11.75 16.638 11.862 16.75 12.001 16.75\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n      <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 21C7.029 21 3 16.971 3 12C3 7.029 7.029 3 12 3C16.971 3 21 7.029 21 12C21 16.971 16.971 21 12 21Z\" fill=\"#FF0000\" stroke=\"#FF0000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n      <path d=\"M12 12.75L12 7.75\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n      <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\"/>\r\n      </svg>\r\n      {{validationMessage}}</div>\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../../services/countryService";
|
|
4
|
+
import * as i2 from "@angular/common";
|
|
5
|
+
import * as i3 from "@angular/forms";
|
|
6
|
+
import * as i4 from "@piserve-tech/drop-down";
|
|
7
|
+
export class MobileFieldsComponent {
|
|
8
|
+
constructor(countryService) {
|
|
9
|
+
this.countryService = countryService;
|
|
10
|
+
this.question = {};
|
|
11
|
+
this.count = 0;
|
|
12
|
+
this.required = false;
|
|
13
|
+
this.hint = '';
|
|
14
|
+
this.placeholder = '';
|
|
15
|
+
this.displayCountryCode = true;
|
|
16
|
+
this.displayFlag = true;
|
|
17
|
+
this.displayCode = true;
|
|
18
|
+
this.showCountryName = true;
|
|
19
|
+
this.beautifyNumbers = true;
|
|
20
|
+
this.countryWiseValidation = true;
|
|
21
|
+
this.restrictCountry = true;
|
|
22
|
+
this.allowedCountry = [];
|
|
23
|
+
this.blockedCountry = [];
|
|
24
|
+
this.countryDetails = [];
|
|
25
|
+
this.selectedCountry = [];
|
|
26
|
+
this.validationFailed = false;
|
|
27
|
+
this.validationMessage = '';
|
|
28
|
+
this.mobileNumber = '';
|
|
29
|
+
this.filteredCountry = [];
|
|
30
|
+
this.validate = new EventEmitter();
|
|
31
|
+
}
|
|
32
|
+
ngOnInit() {
|
|
33
|
+
this.valueAssigned();
|
|
34
|
+
}
|
|
35
|
+
valueAssigned() {
|
|
36
|
+
this.count = this.question.count;
|
|
37
|
+
this.required = this.question.required;
|
|
38
|
+
this.hint = this.question.hint;
|
|
39
|
+
this.placeholder = this.question.formElement.appearance.placeholder;
|
|
40
|
+
this.displayCountryCode =
|
|
41
|
+
this.question.formElement.appearance.displayCountryCode;
|
|
42
|
+
this.displayFlag = this.question.formElement.appearance.displayFlag;
|
|
43
|
+
this.displayCode = this.question.formElement.appearance.displayCode;
|
|
44
|
+
this.showCountryName = this.question.formElement.appearance.showCountryName;
|
|
45
|
+
this.beautifyNumbers = this.question.formElement.appearance.beautifyNumbers;
|
|
46
|
+
this.countryWiseValidation =
|
|
47
|
+
this.question.formElement.validation.countryWiseValidation;
|
|
48
|
+
this.restrictCountry = this.question.formElement.validation.restrictCountry;
|
|
49
|
+
this.allowedCountry = this.question.formElement.validation.allowedCountry;
|
|
50
|
+
this.blockedCountry = this.question.formElement.validation.blockedCountry;
|
|
51
|
+
this.countryService.loadCountryDetails().subscribe((data) => {
|
|
52
|
+
this.filteredCountry = data.result;
|
|
53
|
+
if (this.restrictCountry && (this.allowedCountry || this.blockedCountry)) {
|
|
54
|
+
this.filteredCountry = this.filteredCountry.filter(country => {
|
|
55
|
+
return (this.allowedCountry.includes(country.name) || !this.blockedCountry.includes(country.name));
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
this.countryDetails = this.countryService.processCountryDetails(this.filteredCountry, this.displayFlag, this.displayCode, this.showCountryName);
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
validateMobile() {
|
|
62
|
+
this.validationFailed = false;
|
|
63
|
+
this.validationMessage = '';
|
|
64
|
+
if (this.required && (!this.mobileNumber || this.selectedCountry.length === 0)) {
|
|
65
|
+
this.validationFailed = true;
|
|
66
|
+
this.validationMessage = 'This is a required question';
|
|
67
|
+
this.validate.emit(this.validationFailed);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MobileFieldsComponent, deps: [{ token: i1.CountryService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
71
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: MobileFieldsComponent, selector: "lib-mobile-fields", inputs: { question: "question" }, outputs: { validate: "validate" }, ngImport: i0, template: "<div [ngClass]=\"'col-' + count\" class=\"mb-4 px-3\">\r\n <div class=\"input-wrapper\">\r\n <label>{{ question.question }}</label> \r\n <span class=\"text-danger\" *ngIf=\"required\">*</span>\r\n <div class=\"svg-wrapper mb-2 hintIcon\" [attr.data-title]=\"hint\" *ngIf=\"hint\">\r\n <svg class=\"hintSvg\" viewBox=\"0 0 30 30\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M15 26.25V26.25C8.78625 26.25 3.75 21.2138 3.75 15V15C3.75 8.78625 8.78625 3.75 15 3.75V3.75C21.2138 3.75 26.25 8.78625 26.25 15V15C26.25 21.2138 21.2138 26.25 15 26.25Z\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M15 16.5623V16.2498C15 15.2285 15.6312 14.6748 16.2637 14.2498C16.8812 13.8335 17.5 13.291 17.5 12.291C17.5 10.9098 16.3813 9.79102 15 9.79102C13.6187 9.79102 12.5 10.9098 12.5 12.291\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M14.9988 20C14.8263 20 14.6863 20.14 14.6875 20.3125C14.6875 20.485 14.8275 20.625 15 20.625C15.1725 20.625 15.3125 20.485 15.3125 20.3125C15.3125 20.14 15.1725 20 14.9988 20\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n </div>\r\n</div>\r\n <div class=\"input-group mb-2\">\r\n <div class=\"col-xs-5 col-5 col-md-3 px-0 pe-2\">\r\n <lib-dropdown\r\n [items]=\"countryDetails\"\r\n [multiple] = \"false\"\r\n [(selectedItems)]=\"selectedCountry\"></lib-dropdown>\r\n </div>\r\n <input\r\n type=\"number\"\r\n class=\"form-control col-xs-7 col-7 col-md-9 height mobileField\" \r\n [placeholder]=\"placeholder\"\r\n aria-label=\"Mobile Number\"\r\n [class.invalid]=\"validationFailed\"\r\n (blur)=\"validateMobile()\"\r\n [(ngModel)]=\"mobileNumber\"\r\n />\r\n </div>\r\n <div *ngIf=\"validationFailed\" class=\"text-danger\">\r\n <svg class=\"validationSvg\" viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M12.001 16.75C12.139 16.75 12.251 16.638 12.25 16.5C12.25 16.362 12.138 16.25 12 16.25C11.862 16.25 11.75 16.362 11.75 16.5C11.75 16.638 11.862 16.75 12.001 16.75\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 21C7.029 21 3 16.971 3 12C3 7.029 7.029 3 12 3C16.971 3 21 7.029 21 12C21 16.971 16.971 21 12 21Z\" fill=\"#FF0000\" stroke=\"#FF0000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M12 12.75L12 7.75\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\"/>\r\n </svg>\r\n {{validationMessage}}</div>\r\n</div>\r\n", styles: [".input-wrapper{display:flex;align-items:flex-start}.svg-wrapper{margin-left:auto;z-index:999}.hintIcon{position:relative;cursor:pointer}.hintIcon:hover:before{content:attr(data-title);position:absolute;top:calc(100% + 2px);left:50%;transform:translate(-50%);padding:4px 8px;border-radius:4px;background-color:#1d252d;color:#8e9aa0;font-size:14px;white-space:nowrap}.hintIcon:hover:after{content:\"\";position:absolute;top:calc(100% - 26px);left:50%;border:solid transparent;border-width:18px;border-bottom-color:#1d252d;transform:translate(-50%)}.height{height:42px}.invalid{border-color:red}.hintSvg{width:30px;height:30px;fill:none}.validationSvg{width:24px;height:24px;fill:none}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.mobileField{border-radius:6px!important}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.DropdownComponent, selector: "lib-dropdown", inputs: ["multiple", "scrollable", "selectedItems", "placeholder", "items", "showCreateNew", "selectedValues", "customButtons", "showBorder"], outputs: ["buttonClick", "selectedItemsChange", "onScroll", "onCreateNew", "onSearch"] }] }); }
|
|
72
|
+
}
|
|
73
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MobileFieldsComponent, decorators: [{
|
|
74
|
+
type: Component,
|
|
75
|
+
args: [{ selector: 'lib-mobile-fields', template: "<div [ngClass]=\"'col-' + count\" class=\"mb-4 px-3\">\r\n <div class=\"input-wrapper\">\r\n <label>{{ question.question }}</label> \r\n <span class=\"text-danger\" *ngIf=\"required\">*</span>\r\n <div class=\"svg-wrapper mb-2 hintIcon\" [attr.data-title]=\"hint\" *ngIf=\"hint\">\r\n <svg class=\"hintSvg\" viewBox=\"0 0 30 30\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M15 26.25V26.25C8.78625 26.25 3.75 21.2138 3.75 15V15C3.75 8.78625 8.78625 3.75 15 3.75V3.75C21.2138 3.75 26.25 8.78625 26.25 15V15C26.25 21.2138 21.2138 26.25 15 26.25Z\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M15 16.5623V16.2498C15 15.2285 15.6312 14.6748 16.2637 14.2498C16.8812 13.8335 17.5 13.291 17.5 12.291C17.5 10.9098 16.3813 9.79102 15 9.79102C13.6187 9.79102 12.5 10.9098 12.5 12.291\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M14.9988 20C14.8263 20 14.6863 20.14 14.6875 20.3125C14.6875 20.485 14.8275 20.625 15 20.625C15.1725 20.625 15.3125 20.485 15.3125 20.3125C15.3125 20.14 15.1725 20 14.9988 20\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n </div>\r\n</div>\r\n <div class=\"input-group mb-2\">\r\n <div class=\"col-xs-5 col-5 col-md-3 px-0 pe-2\">\r\n <lib-dropdown\r\n [items]=\"countryDetails\"\r\n [multiple] = \"false\"\r\n [(selectedItems)]=\"selectedCountry\"></lib-dropdown>\r\n </div>\r\n <input\r\n type=\"number\"\r\n class=\"form-control col-xs-7 col-7 col-md-9 height mobileField\" \r\n [placeholder]=\"placeholder\"\r\n aria-label=\"Mobile Number\"\r\n [class.invalid]=\"validationFailed\"\r\n (blur)=\"validateMobile()\"\r\n [(ngModel)]=\"mobileNumber\"\r\n />\r\n </div>\r\n <div *ngIf=\"validationFailed\" class=\"text-danger\">\r\n <svg class=\"validationSvg\" viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M12.001 16.75C12.139 16.75 12.251 16.638 12.25 16.5C12.25 16.362 12.138 16.25 12 16.25C11.862 16.25 11.75 16.362 11.75 16.5C11.75 16.638 11.862 16.75 12.001 16.75\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 21C7.029 21 3 16.971 3 12C3 7.029 7.029 3 12 3C16.971 3 21 7.029 21 12C21 16.971 16.971 21 12 21Z\" fill=\"#FF0000\" stroke=\"#FF0000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M12 12.75L12 7.75\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\"/>\r\n </svg>\r\n {{validationMessage}}</div>\r\n</div>\r\n", styles: [".input-wrapper{display:flex;align-items:flex-start}.svg-wrapper{margin-left:auto;z-index:999}.hintIcon{position:relative;cursor:pointer}.hintIcon:hover:before{content:attr(data-title);position:absolute;top:calc(100% + 2px);left:50%;transform:translate(-50%);padding:4px 8px;border-radius:4px;background-color:#1d252d;color:#8e9aa0;font-size:14px;white-space:nowrap}.hintIcon:hover:after{content:\"\";position:absolute;top:calc(100% - 26px);left:50%;border:solid transparent;border-width:18px;border-bottom-color:#1d252d;transform:translate(-50%)}.height{height:42px}.invalid{border-color:red}.hintSvg{width:30px;height:30px;fill:none}.validationSvg{width:24px;height:24px;fill:none}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.mobileField{border-radius:6px!important}\n"] }]
|
|
76
|
+
}], ctorParameters: function () { return [{ type: i1.CountryService }]; }, propDecorators: { question: [{
|
|
77
|
+
type: Input
|
|
78
|
+
}], validate: [{
|
|
79
|
+
type: Output
|
|
80
|
+
}] } });
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mobile-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/mobile-fields/mobile-fields.component.ts","../../../../../projects/form-submission/src/form-fields/mobile-fields/mobile-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, OnInit} from '@angular/core';\r\nimport { CountryService } from '../../services/countryService';\r\n\r\ninterface CountryData {\r\n  value: string;\r\n  label: string;\r\n  image: string;\r\n}\r\n\r\ninterface filteredCountry{\r\n  name:string;\r\n  flag: string;\r\n  isd:{};\r\n  languages:{};\r\n}\r\n\r\n@Component({\r\n  selector: 'lib-mobile-fields',\r\n  templateUrl: './mobile-fields.component.html',\r\n  styleUrls: ['./mobile-fields.component.scss'],\r\n})\r\nexport class MobileFieldsComponent implements OnInit{\r\n  @Input() question: any = {};\r\n  count: number = 0;\r\n  required: boolean = false;\r\n  hint: string = '';\r\n  placeholder: string = '';\r\n  displayCountryCode: boolean = true;\r\n  displayFlag: boolean = true;\r\n  displayCode: boolean = true;\r\n  showCountryName: boolean = true;\r\n  beautifyNumbers: boolean = true;\r\n  countryWiseValidation: boolean = true;\r\n  restrictCountry: boolean = true;\r\n  allowedCountry: string[] = [];\r\n  blockedCountry: string[] = [];\r\n  countryDetails: CountryData[] = [];\r\n  selectedCountry:CountryData[]=[];\r\n  validationFailed:boolean=false;\r\n  validationMessage:string='';\r\n  mobileNumber:string='';\r\n  filteredCountry:filteredCountry[]=[];\r\n\r\n  @Output() validate : EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n  constructor(private countryService: CountryService) {}\r\n\r\n  ngOnInit() {\r\n    this.valueAssigned();\r\n  }\r\n\r\n  valueAssigned() {\r\n    this.count = this.question.count;\r\n    this.required = this.question.required;\r\n    this.hint = this.question.hint;\r\n    this.placeholder = this.question.formElement.appearance.placeholder;\r\n    this.displayCountryCode =\r\n      this.question.formElement.appearance.displayCountryCode;\r\n    this.displayFlag = this.question.formElement.appearance.displayFlag;\r\n    this.displayCode = this.question.formElement.appearance.displayCode;\r\n    this.showCountryName = this.question.formElement.appearance.showCountryName;\r\n    this.beautifyNumbers = this.question.formElement.appearance.beautifyNumbers;\r\n    this.countryWiseValidation =\r\n      this.question.formElement.validation.countryWiseValidation;\r\n    this.restrictCountry = this.question.formElement.validation.restrictCountry;\r\n    \r\n    this.allowedCountry = this.question.formElement.validation.allowedCountry;\r\n    \r\n    this.blockedCountry = this.question.formElement.validation.blockedCountry;\r\n    \r\n\r\n    this.countryService.loadCountryDetails().subscribe((data) => {\r\n      this.filteredCountry=data.result;\r\n      if(this.restrictCountry && ( this.allowedCountry || this.blockedCountry )){\r\n        this.filteredCountry = this.filteredCountry.filter(country =>{          \r\n         return (this.allowedCountry.includes(country.name) || !this.blockedCountry.includes(country.name))\r\n        });\r\n      }\r\n      this.countryDetails = this.countryService.processCountryDetails(\r\n        this.filteredCountry,\r\n        this.displayFlag,\r\n        this.displayCode,\r\n        this.showCountryName\r\n      );\r\n      });\r\n  }\r\n\r\n  validateMobile(){\r\n    this.validationFailed = false; \r\n    this.validationMessage = '';\r\n    if(this.required && (!this.mobileNumber || this.selectedCountry.length===0)){\r\n      this.validationFailed=true;\r\n      this.validationMessage='This is a required question';\r\n      this.validate.emit(this.validationFailed);\r\n    }\r\n  }\r\n}\r\n","<div [ngClass]=\"'col-' + count\" class=\"mb-4 px-3\">\r\n  <div  class=\"input-wrapper\">\r\n  <label>{{ question.question }}</label>&nbsp;\r\n  <span class=\"text-danger\" *ngIf=\"required\">*</span>\r\n  <div class=\"svg-wrapper  mb-2 hintIcon\" [attr.data-title]=\"hint\" *ngIf=\"hint\">\r\n    <svg class=\"hintSvg\"  viewBox=\"0 0 30 30\"  xmlns=\"http://www.w3.org/2000/svg\">\r\n      <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M15 26.25V26.25C8.78625 26.25 3.75 21.2138 3.75 15V15C3.75 8.78625 8.78625 3.75 15 3.75V3.75C21.2138 3.75 26.25 8.78625 26.25 15V15C26.25 21.2138 21.2138 26.25 15 26.25Z\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n      <path d=\"M15 16.5623V16.2498C15 15.2285 15.6312 14.6748 16.2637 14.2498C16.8812 13.8335 17.5 13.291 17.5 12.291C17.5 10.9098 16.3813 9.79102 15 9.79102C13.6187 9.79102 12.5 10.9098 12.5 12.291\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n      <path d=\"M14.9988 20C14.8263 20 14.6863 20.14 14.6875 20.3125C14.6875 20.485 14.8275 20.625 15 20.625C15.1725 20.625 15.3125 20.485 15.3125 20.3125C15.3125 20.14 15.1725 20 14.9988 20\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n    </svg>\r\n  </div>\r\n</div>\r\n  <div class=\"input-group mb-2\">\r\n    <div class=\"col-xs-5 col-5 col-md-3 px-0 pe-2\">\r\n      <lib-dropdown\r\n       [items]=\"countryDetails\"\r\n      [multiple] = \"false\"\r\n      [(selectedItems)]=\"selectedCountry\"></lib-dropdown>\r\n    </div>\r\n    <input\r\n      type=\"number\"\r\n      class=\"form-control col-xs-7 col-7 col-md-9  height mobileField\" \r\n      [placeholder]=\"placeholder\"\r\n      aria-label=\"Mobile Number\"\r\n      [class.invalid]=\"validationFailed\"\r\n      (blur)=\"validateMobile()\"\r\n      [(ngModel)]=\"mobileNumber\"\r\n    />\r\n  </div>\r\n  <div *ngIf=\"validationFailed\" class=\"text-danger\">\r\n    <svg class=\"validationSvg\"  viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\">\r\n      <path d=\"M12.001 16.75C12.139 16.75 12.251 16.638 12.25 16.5C12.25 16.362 12.138 16.25 12 16.25C11.862 16.25 11.75 16.362 11.75 16.5C11.75 16.638 11.862 16.75 12.001 16.75\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n      <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 21C7.029 21 3 16.971 3 12C3 7.029 7.029 3 12 3C16.971 3 21 7.029 21 12C21 16.971 16.971 21 12 21Z\" fill=\"#FF0000\" stroke=\"#FF0000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n      <path d=\"M12 12.75L12 7.75\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n      <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\"/>\r\n      </svg>\r\n      {{validationMessage}}</div>\r\n</div>\r\n"]}
|