@rangertechnologies/ngnxt 2.1.78 → 2.1.80
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 +27 -30
- package/esm2022/lib/ar.i18n.mjs +29 -29
- package/esm2022/lib/components/custom-button/custom-button.component.mjs +39 -39
- package/esm2022/lib/components/custom-calendar/custom-calendar.component.mjs +366 -366
- package/esm2022/lib/components/custom-date/custom-date.component.mjs +47 -47
- package/esm2022/lib/components/custom-date-picker/custom-date-picker.component.mjs +48 -48
- package/esm2022/lib/components/custom-dropdown/custom-dropdown.component.mjs +219 -219
- package/esm2022/lib/components/custom-image/custom-image.component.mjs +34 -34
- package/esm2022/lib/components/custom-input/custom-input.component.mjs +93 -93
- package/esm2022/lib/components/custom-label/custom-label.component.mjs +21 -21
- package/esm2022/lib/components/custom-model/custom-model.component.mjs +48 -48
- package/esm2022/lib/components/custom-radio/custom-radio.component.mjs +115 -115
- package/esm2022/lib/components/custom-rich-text/custom-rich-text.component.mjs +156 -0
- package/esm2022/lib/components/custom-table/custom-table.component.mjs +169 -169
- package/esm2022/lib/components/custom-text-area/custom-text-area.component.mjs +65 -65
- package/esm2022/lib/components/custom-time/custom-time.component.mjs +61 -61
- package/esm2022/lib/components/dependent-table/dependent-table.component.mjs +42 -42
- package/esm2022/lib/components/dropdown-with-flag/dropdown-with-flag.component.mjs +39 -39
- package/esm2022/lib/components/file-upload/file-upload.component.mjs +233 -233
- package/esm2022/lib/components/file-view/file-view.component.mjs +46 -46
- package/esm2022/lib/components/loader/loader.component.mjs +23 -23
- package/esm2022/lib/components/pick-location/pick-location.component.mjs +188 -188
- package/esm2022/lib/components/search-box/search-box.component.mjs +130 -130
- package/esm2022/lib/components/table-appendix/table-appendix.component.mjs +123 -123
- package/esm2022/lib/directives/componenthost/componenthost.directive.mjs +19 -19
- package/esm2022/lib/en.i18n.mjs +29 -29
- package/esm2022/lib/i18n-config.service.mjs +4 -4
- package/esm2022/lib/i18n.component.mjs +47 -47
- package/esm2022/lib/i18n.module.mjs +38 -38
- package/esm2022/lib/i18n.pipe.mjs +25 -25
- package/esm2022/lib/i18n.service.mjs +56 -56
- package/esm2022/lib/interfaces/actionMeta.mjs +2 -2
- package/esm2022/lib/interfaces/apimeta.mjs +2 -2
- package/esm2022/lib/interfaces/dependencyMeta.mjs +2 -2
- package/esm2022/lib/model/bookletWrapper.mjs +9 -9
- package/esm2022/lib/model/changeWrapper.mjs +11 -11
- package/esm2022/lib/model/errorWrapper.mjs +6 -6
- package/esm2022/lib/model/tableWrapper.mjs +20 -20
- package/esm2022/lib/nxt-app.component.mjs +22 -22
- package/esm2022/lib/nxt-app.module.mjs +364 -352
- package/esm2022/lib/nxt-app.service.mjs +14 -14
- package/esm2022/lib/pages/booklet/booklet.component.mjs +540 -541
- package/esm2022/lib/pages/questionbook/questionbook.component.mjs +428 -407
- package/esm2022/lib/pages/questionnaire/questionnaire.component.mjs +2387 -2373
- package/esm2022/lib/pages/summary-page/summary-page.component.mjs +76 -76
- package/esm2022/lib/pipe/get-value.pipe.mjs +50 -50
- package/esm2022/lib/sample.mjs +3715 -3431
- package/esm2022/lib/services/change.service.mjs +53 -53
- package/esm2022/lib/services/data.service.mjs +80 -80
- package/esm2022/lib/services/salesforce.service.mjs +46 -46
- package/esm2022/lib/services/shared.service.mjs +100 -100
- package/esm2022/lib/services/storage.service.mjs +44 -44
- package/esm2022/lib/tam.i18n.mjs +29 -29
- package/esm2022/lib/wrapper.mjs +175 -175
- package/esm2022/public-api.mjs +15 -15
- package/esm2022/rangertechnologies-ngnxt.mjs +4 -4
- package/fesm2022/rangertechnologies-ngnxt.mjs +10306 -9830
- package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
- package/index.d.ts +5 -5
- package/lib/ar.i18n.d.ts +24 -24
- package/lib/components/custom-button/custom-button.component.d.ts +16 -16
- package/lib/components/custom-calendar/custom-calendar.component.d.ts +65 -65
- package/lib/components/custom-date/custom-date.component.d.ts +18 -18
- package/lib/components/custom-date-picker/custom-date-picker.component.d.ts +19 -19
- package/lib/components/custom-dropdown/custom-dropdown.component.d.ts +39 -39
- package/lib/components/custom-image/custom-image.component.d.ts +13 -13
- package/lib/components/custom-input/custom-input.component.d.ts +31 -31
- package/lib/components/custom-label/custom-label.component.d.ts +10 -10
- package/lib/components/custom-model/custom-model.component.d.ts +19 -19
- package/lib/components/custom-radio/custom-radio.component.d.ts +33 -33
- package/lib/components/custom-rich-text/custom-rich-text.component.d.ts +29 -0
- package/lib/components/custom-table/custom-table.component.d.ts +43 -43
- package/lib/components/custom-text-area/custom-text-area.component.d.ts +22 -22
- package/lib/components/custom-time/custom-time.component.d.ts +18 -18
- package/lib/components/dependent-table/dependent-table.component.d.ts +15 -15
- package/lib/components/dropdown-with-flag/dropdown-with-flag.component.d.ts +16 -16
- package/lib/components/file-upload/file-upload.component.d.ts +42 -42
- package/lib/components/file-view/file-view.component.d.ts +16 -16
- package/lib/components/loader/loader.component.d.ts +11 -11
- package/lib/components/pick-location/pick-location.component.d.ts +42 -42
- package/lib/components/search-box/search-box.component.d.ts +40 -40
- package/lib/components/table-appendix/table-appendix.component.d.ts +30 -30
- package/lib/directives/componenthost/componenthost.directive.d.ts +8 -8
- package/lib/en.i18n.d.ts +24 -24
- package/lib/i18n-config.service.d.ts +2 -2
- package/lib/i18n.component.d.ts +11 -11
- package/lib/i18n.module.d.ts +9 -9
- package/lib/i18n.pipe.d.ts +10 -10
- package/lib/i18n.service.d.ts +14 -14
- package/lib/interfaces/actionMeta.d.ts +5 -5
- package/lib/interfaces/apimeta.d.ts +14 -14
- package/lib/interfaces/dependencyMeta.d.ts +8 -8
- package/lib/model/bookletWrapper.d.ts +5 -5
- package/lib/model/changeWrapper.d.ts +10 -10
- package/lib/model/errorWrapper.d.ts +5 -5
- package/lib/model/tableWrapper.d.ts +18 -18
- package/lib/nxt-app.component.d.ts +8 -8
- package/lib/nxt-app.module.d.ts +47 -46
- package/lib/nxt-app.service.d.ts +6 -6
- package/lib/pages/booklet/booklet.component.d.ts +68 -68
- package/lib/pages/questionbook/questionbook.component.d.ts +66 -66
- package/lib/pages/questionnaire/questionnaire.component.d.ts +220 -218
- package/lib/pages/summary-page/summary-page.component.d.ts +20 -20
- package/lib/pipe/get-value.pipe.d.ts +7 -7
- package/lib/sample.d.ts +11 -10
- package/lib/services/change.service.d.ts +22 -22
- package/lib/services/data.service.d.ts +13 -13
- package/lib/services/salesforce.service.d.ts +11 -11
- package/lib/services/shared.service.d.ts +15 -15
- package/lib/services/storage.service.d.ts +13 -13
- package/lib/tam.i18n.d.ts +24 -24
- package/lib/wrapper.d.ts +203 -203
- package/package.json +3 -3
- package/public-api.d.ts +10 -10
- package/rangertechnologies-ngnxt-2.1.80.tgz +0 -0
- package/rangertechnologies-ngnxt-2.1.78.tgz +0 -0
|
@@ -1,188 +1,188 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
-
// VD 21DEC23 - dependent field change
|
|
3
|
-
import { ChangeWrapper } from '../../model/changeWrapper';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "../../i18n.service";
|
|
6
|
-
import * as i2 from "@angular/common";
|
|
7
|
-
import * as i3 from "@angular/forms";
|
|
8
|
-
import * as i4 from "@angular/google-maps";
|
|
9
|
-
import * as i5 from "../../i18n.pipe";
|
|
10
|
-
export class PickLocationComponent {
|
|
11
|
-
i18nService;
|
|
12
|
-
ngZone;
|
|
13
|
-
latitude = null;
|
|
14
|
-
longitude = null;
|
|
15
|
-
zoom = 10;
|
|
16
|
-
geoCoder;
|
|
17
|
-
// public formGroup: FormGroup;
|
|
18
|
-
searchElementRef;
|
|
19
|
-
showModal = false;
|
|
20
|
-
address;
|
|
21
|
-
// VD 21DEC23 - dependent field change
|
|
22
|
-
question;
|
|
23
|
-
locationSelected = new EventEmitter();
|
|
24
|
-
navigatorGeolocation;
|
|
25
|
-
markerPosition;
|
|
26
|
-
center;
|
|
27
|
-
markerOptions;
|
|
28
|
-
apiKey; // HA10012024 declared Api key to src
|
|
29
|
-
constructor(
|
|
30
|
-
// private mapsAPILoader: MapsAPILoader,
|
|
31
|
-
i18nService, ngZone) {
|
|
32
|
-
this.i18nService = i18nService;
|
|
33
|
-
this.ngZone = ngZone;
|
|
34
|
-
// HA09012024 is to avoid google is undefined error and calling the below created function
|
|
35
|
-
}
|
|
36
|
-
ngOnInit() {
|
|
37
|
-
// HA-11-01-2024 Changed the map Call from constructor to ngOnInit as it was giving undefined values in the outsourced
|
|
38
|
-
if (this.apiKey) {
|
|
39
|
-
this.loadGoogleMapsScript().then(() => {
|
|
40
|
-
this.geoCoder = new google.maps.Geocoder();
|
|
41
|
-
this.markerOptions = new google.maps.Marker({
|
|
42
|
-
draggable: true,
|
|
43
|
-
animation: google.maps.Animation.DROP
|
|
44
|
-
});
|
|
45
|
-
this.initAutocomplete();
|
|
46
|
-
this.onMarkerDragEnd();
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
// HA09012024 is to avoid google is undefined error
|
|
51
|
-
loadGoogleMapsScript() {
|
|
52
|
-
const script = document.createElement('script');
|
|
53
|
-
script.type = 'text/javascript';
|
|
54
|
-
// HA10012024 Assigned Api key to src
|
|
55
|
-
script.src = `https://maps.googleapis.com/maps/api/js?key=${this.apiKey}&libraries=geometry,places`;
|
|
56
|
-
script.async = true;
|
|
57
|
-
script.defer = true;
|
|
58
|
-
document.body.appendChild(script);
|
|
59
|
-
return new Promise((resolve, reject) => {
|
|
60
|
-
script.onload = () => {
|
|
61
|
-
resolve();
|
|
62
|
-
};
|
|
63
|
-
script.onerror = (error) => {
|
|
64
|
-
reject(error);
|
|
65
|
-
};
|
|
66
|
-
});
|
|
67
|
-
}
|
|
68
|
-
initAutocomplete() {
|
|
69
|
-
if (this.geoCoder) {
|
|
70
|
-
const autocomplete = new google.maps.places.Autocomplete(this.searchElementRef?.nativeElement, {
|
|
71
|
-
types: []
|
|
72
|
-
});
|
|
73
|
-
autocomplete.addListener('place_changed', () => {
|
|
74
|
-
this.ngZone.run(() => {
|
|
75
|
-
const place = autocomplete.getPlace();
|
|
76
|
-
if (place.geometry === undefined || place.geometry === null) {
|
|
77
|
-
return;
|
|
78
|
-
}
|
|
79
|
-
this.latitude = place.geometry.location.lat();
|
|
80
|
-
this.longitude = place.geometry.location.lng();
|
|
81
|
-
this.zoom = 18;
|
|
82
|
-
this.address = place.formatted_address;
|
|
83
|
-
// VD 21DEC23 - dependent field change
|
|
84
|
-
let change = new ChangeWrapper();
|
|
85
|
-
// RS 09DEC24 Changed keys
|
|
86
|
-
change.fromQuestionId = this.question.id;
|
|
87
|
-
let addObj = {};
|
|
88
|
-
addObj['address'] = this.address;
|
|
89
|
-
addObj['latitude'] = this.latitude;
|
|
90
|
-
addObj['longitude'] = this.longitude;
|
|
91
|
-
change.valueObj = addObj;
|
|
92
|
-
this.locationSelected.emit(change);
|
|
93
|
-
});
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
onMarkerDragEnd() {
|
|
98
|
-
google.maps.event.addListener(this.markerOptions, 'dragend', (event) => {
|
|
99
|
-
console.log('dragable working', event);
|
|
100
|
-
this.latitude = event.latLng.lat();
|
|
101
|
-
this.longitude = event.latLng.lng();
|
|
102
|
-
this.getAddress(this.latitude, this.longitude);
|
|
103
|
-
});
|
|
104
|
-
}
|
|
105
|
-
onMapClick(event) {
|
|
106
|
-
console.log('onMapClick', event);
|
|
107
|
-
this.latitude = event.latLng.lat();
|
|
108
|
-
this.longitude = event.latLng.lng();
|
|
109
|
-
this.getAddress(this.latitude, this.longitude);
|
|
110
|
-
}
|
|
111
|
-
setCurrentLocation() {
|
|
112
|
-
if ('geolocation' in navigator) {
|
|
113
|
-
navigator.geolocation.getCurrentPosition((position) => {
|
|
114
|
-
this.latitude = position.coords.latitude;
|
|
115
|
-
this.longitude = position.coords.longitude;
|
|
116
|
-
this.markerPosition = { lat: this.latitude, lng: this.longitude };
|
|
117
|
-
this.center = { lat: this.latitude, lng: this.longitude };
|
|
118
|
-
this.zoom = 8;
|
|
119
|
-
this.getAddress(this.latitude, this.longitude);
|
|
120
|
-
});
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
getAddress(latitude, longitude) {
|
|
124
|
-
if (this.geoCoder) {
|
|
125
|
-
this.geoCoder.geocode({ location: { lat: latitude, lng: longitude } }, (results, status) => {
|
|
126
|
-
console.log('results', results);
|
|
127
|
-
console.log('status', status);
|
|
128
|
-
if (status === 'OK') {
|
|
129
|
-
if (results[0]) {
|
|
130
|
-
// this.zoom = 18;
|
|
131
|
-
this.address = results[0].formatted_address;
|
|
132
|
-
// VD 21DEC23 - dependent field change
|
|
133
|
-
let change = new ChangeWrapper();
|
|
134
|
-
// RS 09DEC24 Changed keys
|
|
135
|
-
change.fromQuestionId = this.question.id;
|
|
136
|
-
let addObj1 = {};
|
|
137
|
-
addObj1['address'] = this.address;
|
|
138
|
-
addObj1['latitude'] = latitude;
|
|
139
|
-
addObj1['longitude'] = longitude;
|
|
140
|
-
change.valueObj = addObj1;
|
|
141
|
-
this.locationSelected.emit(change);
|
|
142
|
-
}
|
|
143
|
-
else {
|
|
144
|
-
console.log('No results found');
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
else {
|
|
148
|
-
console.log('Geocoder failed due to: ' + status);
|
|
149
|
-
}
|
|
150
|
-
});
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
openMap() {
|
|
154
|
-
this.showModal = true;
|
|
155
|
-
if (!this.address) {
|
|
156
|
-
this.latitude = this.longitude = null;
|
|
157
|
-
}
|
|
158
|
-
if (!(this.latitude && this.longitude)) {
|
|
159
|
-
this.setCurrentLocation();
|
|
160
|
-
}
|
|
161
|
-
else {
|
|
162
|
-
this.markerPosition = { lat: this.latitude, lng: this.longitude };
|
|
163
|
-
this.center = { lat: this.latitude, lng: this.longitude };
|
|
164
|
-
this.zoom = 8;
|
|
165
|
-
}
|
|
166
|
-
}
|
|
167
|
-
closeModal() {
|
|
168
|
-
this.showModal = false;
|
|
169
|
-
}
|
|
170
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
171
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
172
|
-
}
|
|
173
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
174
|
-
type: Component,
|
|
175
|
-
args: [{ selector: 'app-pick-location', template: "<div>\
|
|
176
|
-
}], ctorParameters:
|
|
177
|
-
type: ViewChild,
|
|
178
|
-
args: ['search', { static: true }]
|
|
179
|
-
}], address: [{
|
|
180
|
-
type: Input
|
|
181
|
-
}], question: [{
|
|
182
|
-
type: Input
|
|
183
|
-
}], locationSelected: [{
|
|
184
|
-
type: Output
|
|
185
|
-
}], apiKey: [{
|
|
186
|
-
type: Input
|
|
187
|
-
}] } });
|
|
188
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pick-location.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/pick-location/pick-location.component.ts","../../../../../../projects/nxt-app/src/lib/components/pick-location/pick-location.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, NgModule, NgZone, OnInit, Output, ViewChild } from '@angular/core';\r\n// HA 19DEC23 imported translation service\r\nimport { I18nService } from '../../i18n.service';\r\n // VD 21DEC23 - dependent field change\r\nimport { ChangeWrapper } from '../../model/changeWrapper';\r\nimport { Question } from '../../wrapper';\r\ndeclare var $: any;\r\n\r\n@Component({\r\n  selector: 'app-pick-location',\r\n  templateUrl: './pick-location.component.html',\r\n  styleUrls: ['./pick-location.component.css']\r\n})\r\nexport class PickLocationComponent implements OnInit {\r\n  latitude = null;\r\n  longitude = null;\r\n  zoom: number = 10;\r\n  private geoCoder;\r\n // public formGroup: FormGroup;\r\n  @ViewChild('search', { static: true })\r\n  public searchElementRef: ElementRef<HTMLInputElement>;\r\n  showModal: boolean = false;\r\n  @Input() address:string;\r\n   // VD 21DEC23 - dependent field change\r\n  @Input() question: Question\r\n  @Output() locationSelected: EventEmitter<ChangeWrapper> = new EventEmitter<ChangeWrapper>();\r\n  navigatorGeolocation: any;\r\n  markerPosition: { lat: any; lng: any; };\r\n  center: { lat: any; lng: any; };\r\n  markerOptions:any;\r\n  @Input() apiKey: any; // HA10012024 declared Api key to src\r\n\r\n  constructor(\r\n   // private mapsAPILoader: MapsAPILoader,\r\n   public i18nService: I18nService,\r\n    private ngZone: NgZone) { \r\n      // HA09012024 is to avoid google is undefined error and calling the below created function\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    // HA-11-01-2024 Changed the map Call from constructor to ngOnInit as it was giving undefined values in the outsourced\r\n    if(this.apiKey){\r\n      this.loadGoogleMapsScript().then(() => {\r\n        this.geoCoder = new google.maps.Geocoder();\r\n        this.markerOptions = new google.maps.Marker ({\r\n          draggable: true,\r\n          animation: google.maps.Animation.DROP\r\n        });\r\n        this.initAutocomplete();\r\n        this.onMarkerDragEnd();\r\n      });\r\n    }\r\n  }\r\n  // HA09012024 is to avoid google is undefined error\r\n  private loadGoogleMapsScript(): Promise<void> {\r\n    const script = document.createElement('script');\r\n    script.type = 'text/javascript';\r\n    // HA10012024 Assigned Api key to src\r\n    script.src = `https://maps.googleapis.com/maps/api/js?key=${this.apiKey}&libraries=geometry,places`;\r\n    script.async = true;\r\n    script.defer = true;\r\n    document.body.appendChild(script);\r\n\r\n    return new Promise<void>((resolve, reject) => {\r\n      script.onload = () => {\r\n        resolve();\r\n      };\r\n      script.onerror = (error: any) => {\r\n        reject(error);\r\n      };\r\n    });\r\n  }\r\n  \r\n  initAutocomplete(): void {\r\n    if (this.geoCoder) {\r\n      const autocomplete = new google.maps.places.Autocomplete(this.searchElementRef?.nativeElement, {\r\n        types: []\r\n      });\r\n      autocomplete.addListener('place_changed', () => {\r\n        this.ngZone.run(() => {\r\n          const place: google.maps.places.PlaceResult = autocomplete.getPlace();\r\n\r\n          if (place.geometry === undefined || place.geometry === null) {\r\n            return;\r\n          }\r\n          this.latitude = place.geometry.location.lat();\r\n          this.longitude = place.geometry.location.lng();\r\n          this.zoom = 18;\r\n          this.address = place.formatted_address;\r\n          // VD 21DEC23 - dependent field change\r\n          let change = new ChangeWrapper();\r\n          // RS 09DEC24 Changed keys\r\n          change.fromQuestionId = this.question.id;\r\n          let addObj = {};\r\n          addObj['address'] = this.address;\r\n          addObj['latitude'] = this.latitude;\r\n          addObj['longitude'] = this.longitude;\r\n          change.valueObj = addObj;\r\n         this.locationSelected.emit(change);\r\n        });\r\n      });\r\n    }\r\n  }\r\n\r\n  onMarkerDragEnd(): void {\r\n    google.maps.event.addListener(this.markerOptions, 'dragend', (event) => {\r\n      console.log('dragable working',event);\r\n      this.latitude = event.latLng.lat();\r\n      this.longitude = event.latLng.lng();\r\n      this.getAddress(this.latitude, this.longitude);\r\n  });\r\n  }\r\n\r\n  onMapClick(event: google.maps.MapMouseEvent): void {\r\n    console.log('onMapClick',event);\r\n    this.latitude = event.latLng.lat();\r\n    this.longitude = event.latLng.lng();\r\n    this.getAddress(this.latitude, this.longitude);\r\n  }\r\n\r\n\r\n  private setCurrentLocation() {\r\n    if ('geolocation' in navigator) {\r\n      navigator.geolocation.getCurrentPosition((position) => {\r\n        this.latitude = position.coords.latitude;\r\n        this.longitude = position.coords.longitude;\r\n        this.markerPosition = { lat: this.latitude, lng: this.longitude };\r\n        this.center = { lat: this.latitude, lng: this.longitude };\r\n        this.zoom = 8;\r\n        this.getAddress(this.latitude, this.longitude);\r\n      });\r\n    }\r\n  }\r\n\r\n\r\n  getAddress(latitude: number, longitude: number) {\r\n    if (this.geoCoder) {\r\n      this.geoCoder.geocode({ location: { lat: latitude, lng: longitude } }, (results, status) => {\r\n        console.log('results',results);\r\n        console.log('status',status);\r\n        if (status === 'OK') {\r\n          if (results[0]) {\r\n           // this.zoom = 18;\r\n            this.address = results[0].formatted_address;\r\n             // VD 21DEC23 - dependent field change\r\n            let change = new ChangeWrapper();\r\n            // RS 09DEC24 Changed keys\r\n            change.fromQuestionId = this.question.id;\r\n            let addObj1 = {};\r\n            addObj1['address'] = this.address;\r\n            addObj1['latitude'] = latitude;\r\n            addObj1['longitude'] = longitude;\r\n            change.valueObj = addObj1;\r\n            this.locationSelected.emit(change);\r\n          } else {\r\n            console.log('No results found');\r\n          }\r\n        } else {\r\n          console.log('Geocoder failed due to: ' + status);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  openMap() {\r\n    this.showModal = true;\r\n    if(!this.address){\r\n      this.latitude = this.longitude = null;\r\n    }\r\n    if (!(this.latitude && this.longitude)) {\r\n      this.setCurrentLocation();\r\n    }else{\r\n      this.markerPosition = { lat: this.latitude, lng: this.longitude };\r\n      this.center = { lat: this.latitude, lng: this.longitude };\r\n      this.zoom = 8;\r\n    }\r\n  }\r\n\r\n  closeModal() {\r\n    this.showModal = false;\r\n  }\r\n\r\n\r\n}\r\n","<div>\r\n     <!-- <label class=\"she-label\">Location</label> -->\r\n    <!-- HA 19DEC23 For translation -->\r\n     <input #search class=\"she-line-input form-control\" type=\"text\" placeholder=\"{{ 'enterLocation' | i18n:i18nService.currentLanguage }}\"\r\n        (keydown.enter)=\"$event.preventDefault()\" placeholder=\"{{ 'searchNearestLocation' | i18n:i18nService.currentLanguage }}\" autocorrect=\"off\"\r\n        autocapitalize=\"off\" spellcheck=\"off\" type=\"text\"  [(ngModel)]=\"address\"\r\n        >\r\n        <a (click)=\"openMap()\"\r\n        style=\"color:#48B7FF;position:relative;top:5px;cursor: pointer;\">\r\n        <i class=\"fa fa-location-arrow\" aria-hidden=\"true\">\r\n        <!-- HA 19DEC23 For translation -->\r\n        </i> {{ 'pickLocation' | i18n:i18nService.currentLanguage }}</a>\r\n</div>\r\n\r\n<div class=\"map-overlay\" *ngIf=\"showModal\">\r\n  <div class=\"map-modal\">\r\n    <div class=\"map-modal-content\">\r\n      <div class=\"map-modal-header\">\r\n        <!-- HA 19DEC23 For translation -->\r\n        <h4>{{ 'pickYourLocation' | i18n:i18nService.currentLanguage }}</h4>\r\n        <button class=\"close-button\" (click)=\"closeModal()\">X</button>\r\n      </div>\r\n      <!-- Modal content goes here -->\r\n    <!-- <agm-map [latitude]=\"latitude\" [longitude]=\"longitude\" [zoom]=\"zoom\" (mapClick)=\"markerDragEnd($event)\"\r\n    [fullscreenControl]=\"true\">\r\n    <agm-marker [latitude]=\"latitude\" [longitude]=\"longitude\" [markerDraggable]=\"true\"\r\n      (dragEnd)=\"markerDragEnd($event)\"></agm-marker>\r\n    </agm-map> -->\r\n    <google-map [latitude]=\"latitude\"  [longitude]=\"longitude\" [zoom]=\"zoom\" [center]=\"center\" (mapClick)=\"onMapClick($event)\">\r\n      <map-marker [position]=\"markerPosition\" [options]=\"markerOptions\"></map-marker>\r\n    </google-map>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n\r\n\r\n\r\n\r\n\r\n"]}
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
// VD 21DEC23 - dependent field change
|
|
3
|
+
import { ChangeWrapper } from '../../model/changeWrapper';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../../i18n.service";
|
|
6
|
+
import * as i2 from "@angular/common";
|
|
7
|
+
import * as i3 from "@angular/forms";
|
|
8
|
+
import * as i4 from "@angular/google-maps";
|
|
9
|
+
import * as i5 from "../../i18n.pipe";
|
|
10
|
+
export class PickLocationComponent {
|
|
11
|
+
i18nService;
|
|
12
|
+
ngZone;
|
|
13
|
+
latitude = null;
|
|
14
|
+
longitude = null;
|
|
15
|
+
zoom = 10;
|
|
16
|
+
geoCoder;
|
|
17
|
+
// public formGroup: FormGroup;
|
|
18
|
+
searchElementRef;
|
|
19
|
+
showModal = false;
|
|
20
|
+
address;
|
|
21
|
+
// VD 21DEC23 - dependent field change
|
|
22
|
+
question;
|
|
23
|
+
locationSelected = new EventEmitter();
|
|
24
|
+
navigatorGeolocation;
|
|
25
|
+
markerPosition;
|
|
26
|
+
center;
|
|
27
|
+
markerOptions;
|
|
28
|
+
apiKey; // HA10012024 declared Api key to src
|
|
29
|
+
constructor(
|
|
30
|
+
// private mapsAPILoader: MapsAPILoader,
|
|
31
|
+
i18nService, ngZone) {
|
|
32
|
+
this.i18nService = i18nService;
|
|
33
|
+
this.ngZone = ngZone;
|
|
34
|
+
// HA09012024 is to avoid google is undefined error and calling the below created function
|
|
35
|
+
}
|
|
36
|
+
ngOnInit() {
|
|
37
|
+
// HA-11-01-2024 Changed the map Call from constructor to ngOnInit as it was giving undefined values in the outsourced
|
|
38
|
+
if (this.apiKey) {
|
|
39
|
+
this.loadGoogleMapsScript().then(() => {
|
|
40
|
+
this.geoCoder = new google.maps.Geocoder();
|
|
41
|
+
this.markerOptions = new google.maps.Marker({
|
|
42
|
+
draggable: true,
|
|
43
|
+
animation: google.maps.Animation.DROP
|
|
44
|
+
});
|
|
45
|
+
this.initAutocomplete();
|
|
46
|
+
this.onMarkerDragEnd();
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
// HA09012024 is to avoid google is undefined error
|
|
51
|
+
loadGoogleMapsScript() {
|
|
52
|
+
const script = document.createElement('script');
|
|
53
|
+
script.type = 'text/javascript';
|
|
54
|
+
// HA10012024 Assigned Api key to src
|
|
55
|
+
script.src = `https://maps.googleapis.com/maps/api/js?key=${this.apiKey}&libraries=geometry,places`;
|
|
56
|
+
script.async = true;
|
|
57
|
+
script.defer = true;
|
|
58
|
+
document.body.appendChild(script);
|
|
59
|
+
return new Promise((resolve, reject) => {
|
|
60
|
+
script.onload = () => {
|
|
61
|
+
resolve();
|
|
62
|
+
};
|
|
63
|
+
script.onerror = (error) => {
|
|
64
|
+
reject(error);
|
|
65
|
+
};
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
initAutocomplete() {
|
|
69
|
+
if (this.geoCoder) {
|
|
70
|
+
const autocomplete = new google.maps.places.Autocomplete(this.searchElementRef?.nativeElement, {
|
|
71
|
+
types: []
|
|
72
|
+
});
|
|
73
|
+
autocomplete.addListener('place_changed', () => {
|
|
74
|
+
this.ngZone.run(() => {
|
|
75
|
+
const place = autocomplete.getPlace();
|
|
76
|
+
if (place.geometry === undefined || place.geometry === null) {
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
this.latitude = place.geometry.location.lat();
|
|
80
|
+
this.longitude = place.geometry.location.lng();
|
|
81
|
+
this.zoom = 18;
|
|
82
|
+
this.address = place.formatted_address;
|
|
83
|
+
// VD 21DEC23 - dependent field change
|
|
84
|
+
let change = new ChangeWrapper();
|
|
85
|
+
// RS 09DEC24 Changed keys
|
|
86
|
+
change.fromQuestionId = this.question.id;
|
|
87
|
+
let addObj = {};
|
|
88
|
+
addObj['address'] = this.address;
|
|
89
|
+
addObj['latitude'] = this.latitude;
|
|
90
|
+
addObj['longitude'] = this.longitude;
|
|
91
|
+
change.valueObj = addObj;
|
|
92
|
+
this.locationSelected.emit(change);
|
|
93
|
+
});
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
onMarkerDragEnd() {
|
|
98
|
+
google.maps.event.addListener(this.markerOptions, 'dragend', (event) => {
|
|
99
|
+
console.log('dragable working', event);
|
|
100
|
+
this.latitude = event.latLng.lat();
|
|
101
|
+
this.longitude = event.latLng.lng();
|
|
102
|
+
this.getAddress(this.latitude, this.longitude);
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
onMapClick(event) {
|
|
106
|
+
console.log('onMapClick', event);
|
|
107
|
+
this.latitude = event.latLng.lat();
|
|
108
|
+
this.longitude = event.latLng.lng();
|
|
109
|
+
this.getAddress(this.latitude, this.longitude);
|
|
110
|
+
}
|
|
111
|
+
setCurrentLocation() {
|
|
112
|
+
if ('geolocation' in navigator) {
|
|
113
|
+
navigator.geolocation.getCurrentPosition((position) => {
|
|
114
|
+
this.latitude = position.coords.latitude;
|
|
115
|
+
this.longitude = position.coords.longitude;
|
|
116
|
+
this.markerPosition = { lat: this.latitude, lng: this.longitude };
|
|
117
|
+
this.center = { lat: this.latitude, lng: this.longitude };
|
|
118
|
+
this.zoom = 8;
|
|
119
|
+
this.getAddress(this.latitude, this.longitude);
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
getAddress(latitude, longitude) {
|
|
124
|
+
if (this.geoCoder) {
|
|
125
|
+
this.geoCoder.geocode({ location: { lat: latitude, lng: longitude } }, (results, status) => {
|
|
126
|
+
console.log('results', results);
|
|
127
|
+
console.log('status', status);
|
|
128
|
+
if (status === 'OK') {
|
|
129
|
+
if (results[0]) {
|
|
130
|
+
// this.zoom = 18;
|
|
131
|
+
this.address = results[0].formatted_address;
|
|
132
|
+
// VD 21DEC23 - dependent field change
|
|
133
|
+
let change = new ChangeWrapper();
|
|
134
|
+
// RS 09DEC24 Changed keys
|
|
135
|
+
change.fromQuestionId = this.question.id;
|
|
136
|
+
let addObj1 = {};
|
|
137
|
+
addObj1['address'] = this.address;
|
|
138
|
+
addObj1['latitude'] = latitude;
|
|
139
|
+
addObj1['longitude'] = longitude;
|
|
140
|
+
change.valueObj = addObj1;
|
|
141
|
+
this.locationSelected.emit(change);
|
|
142
|
+
}
|
|
143
|
+
else {
|
|
144
|
+
console.log('No results found');
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
else {
|
|
148
|
+
console.log('Geocoder failed due to: ' + status);
|
|
149
|
+
}
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
openMap() {
|
|
154
|
+
this.showModal = true;
|
|
155
|
+
if (!this.address) {
|
|
156
|
+
this.latitude = this.longitude = null;
|
|
157
|
+
}
|
|
158
|
+
if (!(this.latitude && this.longitude)) {
|
|
159
|
+
this.setCurrentLocation();
|
|
160
|
+
}
|
|
161
|
+
else {
|
|
162
|
+
this.markerPosition = { lat: this.latitude, lng: this.longitude };
|
|
163
|
+
this.center = { lat: this.latitude, lng: this.longitude };
|
|
164
|
+
this.zoom = 8;
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
closeModal() {
|
|
168
|
+
this.showModal = false;
|
|
169
|
+
}
|
|
170
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PickLocationComponent, deps: [{ token: i1.I18nService }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
|
|
171
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: PickLocationComponent, selector: "app-pick-location", inputs: { address: "address", question: "question", apiKey: "apiKey" }, outputs: { locationSelected: "locationSelected" }, viewQueries: [{ propertyName: "searchElementRef", first: true, predicate: ["search"], descendants: true, static: true }], ngImport: i0, template: "<div>\n <!-- <label class=\"she-label\">Location</label> -->\n <!-- HA 19DEC23 For translation -->\n <input #search class=\"she-line-input form-control\" type=\"text\" placeholder=\"{{ 'enterLocation' | i18n:i18nService.currentLanguage }}\"\n (keydown.enter)=\"$event.preventDefault()\" placeholder=\"{{ 'searchNearestLocation' | i18n:i18nService.currentLanguage }}\" autocorrect=\"off\"\n autocapitalize=\"off\" spellcheck=\"off\" type=\"text\" [(ngModel)]=\"address\"\n >\n <a (click)=\"openMap()\"\n style=\"color:#48B7FF;position:relative;top:5px;cursor: pointer;\">\n <i class=\"fa fa-location-arrow\" aria-hidden=\"true\">\n <!-- HA 19DEC23 For translation -->\n </i> {{ 'pickLocation' | i18n:i18nService.currentLanguage }}</a>\n</div>\n\n<div class=\"map-overlay\" *ngIf=\"showModal\">\n <div class=\"map-modal\">\n <div class=\"map-modal-content\">\n <div class=\"map-modal-header\">\n <!-- HA 19DEC23 For translation -->\n <h4>{{ 'pickYourLocation' | i18n:i18nService.currentLanguage }}</h4>\n <button class=\"close-button\" (click)=\"closeModal()\">X</button>\n </div>\n <!-- Modal content goes here -->\n <!-- <agm-map [latitude]=\"latitude\" [longitude]=\"longitude\" [zoom]=\"zoom\" (mapClick)=\"markerDragEnd($event)\"\n [fullscreenControl]=\"true\">\n <agm-marker [latitude]=\"latitude\" [longitude]=\"longitude\" [markerDraggable]=\"true\"\n (dragEnd)=\"markerDragEnd($event)\"></agm-marker>\n </agm-map> -->\n <google-map [latitude]=\"latitude\" [longitude]=\"longitude\" [zoom]=\"zoom\" [center]=\"center\" (mapClick)=\"onMapClick($event)\">\n <map-marker [position]=\"markerPosition\" [options]=\"markerOptions\"></map-marker>\n </google-map>\n </div>\n </div>\n</div>\n\n\n\n\n\n\n", styles: [".she-label{font-weight:400;color:#9a9a9a;padding-bottom:5px;padding-top:5px;padding-right:15px;font-size:14px}.she-line-input{border:none;background:#fff;border-bottom:1px solid #eeeeee;border-radius:0}.fa-location-arrow:before{content:\"\\f124\"}google-map .map-container{width:auto!important}.map-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1}.map-modal{width:600px;background-color:#fff;border-radius:5px;box-shadow:0 2px 4px #0003}.map-modal-header{display:flex;align-items:center;justify-content:space-between;padding:0 0 10px;background-color:#fff;border-bottom:2px solid #e5e5e5}.map-modal-header h3{margin:0}.map-modal-content{padding:20px}.close-button{border:none;cursor:pointer;font-size:21px;font-weight:700;line-height:1;color:#000;text-shadow:0 1px 0 #fff;opacity:.2}\n"], dependencies: [{ 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.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.GoogleMap, selector: "google-map", inputs: ["height", "width", "mapId", "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"] }, { kind: "directive", type: i4.MapMarker, selector: "map-marker", inputs: ["title", "position", "label", "clickable", "options", "icon", "visible"], outputs: ["animationChanged", "mapClick", "clickableChanged", "cursorChanged", "mapDblclick", "mapDrag", "mapDragend", "draggableChanged", "mapDragstart", "flatChanged", "iconChanged", "mapMousedown", "mapMouseout", "mapMouseover", "mapMouseup", "positionChanged", "mapRightclick", "shapeChanged", "titleChanged", "visibleChanged", "zindexChanged", "markerInitialized"], exportAs: ["mapMarker"] }, { kind: "pipe", type: i5.I18nPipe, name: "i18n" }] });
|
|
172
|
+
}
|
|
173
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PickLocationComponent, decorators: [{
|
|
174
|
+
type: Component,
|
|
175
|
+
args: [{ selector: 'app-pick-location', template: "<div>\n <!-- <label class=\"she-label\">Location</label> -->\n <!-- HA 19DEC23 For translation -->\n <input #search class=\"she-line-input form-control\" type=\"text\" placeholder=\"{{ 'enterLocation' | i18n:i18nService.currentLanguage }}\"\n (keydown.enter)=\"$event.preventDefault()\" placeholder=\"{{ 'searchNearestLocation' | i18n:i18nService.currentLanguage }}\" autocorrect=\"off\"\n autocapitalize=\"off\" spellcheck=\"off\" type=\"text\" [(ngModel)]=\"address\"\n >\n <a (click)=\"openMap()\"\n style=\"color:#48B7FF;position:relative;top:5px;cursor: pointer;\">\n <i class=\"fa fa-location-arrow\" aria-hidden=\"true\">\n <!-- HA 19DEC23 For translation -->\n </i> {{ 'pickLocation' | i18n:i18nService.currentLanguage }}</a>\n</div>\n\n<div class=\"map-overlay\" *ngIf=\"showModal\">\n <div class=\"map-modal\">\n <div class=\"map-modal-content\">\n <div class=\"map-modal-header\">\n <!-- HA 19DEC23 For translation -->\n <h4>{{ 'pickYourLocation' | i18n:i18nService.currentLanguage }}</h4>\n <button class=\"close-button\" (click)=\"closeModal()\">X</button>\n </div>\n <!-- Modal content goes here -->\n <!-- <agm-map [latitude]=\"latitude\" [longitude]=\"longitude\" [zoom]=\"zoom\" (mapClick)=\"markerDragEnd($event)\"\n [fullscreenControl]=\"true\">\n <agm-marker [latitude]=\"latitude\" [longitude]=\"longitude\" [markerDraggable]=\"true\"\n (dragEnd)=\"markerDragEnd($event)\"></agm-marker>\n </agm-map> -->\n <google-map [latitude]=\"latitude\" [longitude]=\"longitude\" [zoom]=\"zoom\" [center]=\"center\" (mapClick)=\"onMapClick($event)\">\n <map-marker [position]=\"markerPosition\" [options]=\"markerOptions\"></map-marker>\n </google-map>\n </div>\n </div>\n</div>\n\n\n\n\n\n\n", styles: [".she-label{font-weight:400;color:#9a9a9a;padding-bottom:5px;padding-top:5px;padding-right:15px;font-size:14px}.she-line-input{border:none;background:#fff;border-bottom:1px solid #eeeeee;border-radius:0}.fa-location-arrow:before{content:\"\\f124\"}google-map .map-container{width:auto!important}.map-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1}.map-modal{width:600px;background-color:#fff;border-radius:5px;box-shadow:0 2px 4px #0003}.map-modal-header{display:flex;align-items:center;justify-content:space-between;padding:0 0 10px;background-color:#fff;border-bottom:2px solid #e5e5e5}.map-modal-header h3{margin:0}.map-modal-content{padding:20px}.close-button{border:none;cursor:pointer;font-size:21px;font-weight:700;line-height:1;color:#000;text-shadow:0 1px 0 #fff;opacity:.2}\n"] }]
|
|
176
|
+
}], ctorParameters: () => [{ type: i1.I18nService }, { type: i0.NgZone }], propDecorators: { searchElementRef: [{
|
|
177
|
+
type: ViewChild,
|
|
178
|
+
args: ['search', { static: true }]
|
|
179
|
+
}], address: [{
|
|
180
|
+
type: Input
|
|
181
|
+
}], question: [{
|
|
182
|
+
type: Input
|
|
183
|
+
}], locationSelected: [{
|
|
184
|
+
type: Output
|
|
185
|
+
}], apiKey: [{
|
|
186
|
+
type: Input
|
|
187
|
+
}] } });
|
|
188
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pick-location.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/pick-location/pick-location.component.ts","../../../../../../projects/nxt-app/src/lib/components/pick-location/pick-location.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, NgModule, NgZone, OnInit, Output, ViewChild } from '@angular/core';\n// HA 19DEC23 imported translation service\nimport { I18nService } from '../../i18n.service';\n // VD 21DEC23 - dependent field change\nimport { ChangeWrapper } from '../../model/changeWrapper';\nimport { Question } from '../../wrapper';\ndeclare var $: any;\n\n@Component({\n  selector: 'app-pick-location',\n  templateUrl: './pick-location.component.html',\n  styleUrls: ['./pick-location.component.css']\n})\nexport class PickLocationComponent implements OnInit {\n  latitude = null;\n  longitude = null;\n  zoom: number = 10;\n  private geoCoder;\n // public formGroup: FormGroup;\n  @ViewChild('search', { static: true })\n  public searchElementRef: ElementRef<HTMLInputElement>;\n  showModal: boolean = false;\n  @Input() address:string;\n   // VD 21DEC23 - dependent field change\n  @Input() question: Question\n  @Output() locationSelected: EventEmitter<ChangeWrapper> = new EventEmitter<ChangeWrapper>();\n  navigatorGeolocation: any;\n  markerPosition: { lat: any; lng: any; };\n  center: { lat: any; lng: any; };\n  markerOptions:any;\n  @Input() apiKey: any; // HA10012024 declared Api key to src\n\n  constructor(\n   // private mapsAPILoader: MapsAPILoader,\n   public i18nService: I18nService,\n    private ngZone: NgZone) { \n      // HA09012024 is to avoid google is undefined error and calling the below created function\n  }\n\n  ngOnInit(): void {\n    // HA-11-01-2024 Changed the map Call from constructor to ngOnInit as it was giving undefined values in the outsourced\n    if(this.apiKey){\n      this.loadGoogleMapsScript().then(() => {\n        this.geoCoder = new google.maps.Geocoder();\n        this.markerOptions = new google.maps.Marker ({\n          draggable: true,\n          animation: google.maps.Animation.DROP\n        });\n        this.initAutocomplete();\n        this.onMarkerDragEnd();\n      });\n    }\n  }\n  // HA09012024 is to avoid google is undefined error\n  private loadGoogleMapsScript(): Promise<void> {\n    const script = document.createElement('script');\n    script.type = 'text/javascript';\n    // HA10012024 Assigned Api key to src\n    script.src = `https://maps.googleapis.com/maps/api/js?key=${this.apiKey}&libraries=geometry,places`;\n    script.async = true;\n    script.defer = true;\n    document.body.appendChild(script);\n\n    return new Promise<void>((resolve, reject) => {\n      script.onload = () => {\n        resolve();\n      };\n      script.onerror = (error: any) => {\n        reject(error);\n      };\n    });\n  }\n  \n  initAutocomplete(): void {\n    if (this.geoCoder) {\n      const autocomplete = new google.maps.places.Autocomplete(this.searchElementRef?.nativeElement, {\n        types: []\n      });\n      autocomplete.addListener('place_changed', () => {\n        this.ngZone.run(() => {\n          const place: google.maps.places.PlaceResult = autocomplete.getPlace();\n\n          if (place.geometry === undefined || place.geometry === null) {\n            return;\n          }\n          this.latitude = place.geometry.location.lat();\n          this.longitude = place.geometry.location.lng();\n          this.zoom = 18;\n          this.address = place.formatted_address;\n          // VD 21DEC23 - dependent field change\n          let change = new ChangeWrapper();\n          // RS 09DEC24 Changed keys\n          change.fromQuestionId = this.question.id;\n          let addObj = {};\n          addObj['address'] = this.address;\n          addObj['latitude'] = this.latitude;\n          addObj['longitude'] = this.longitude;\n          change.valueObj = addObj;\n         this.locationSelected.emit(change);\n        });\n      });\n    }\n  }\n\n  onMarkerDragEnd(): void {\n    google.maps.event.addListener(this.markerOptions, 'dragend', (event) => {\n      console.log('dragable working',event);\n      this.latitude = event.latLng.lat();\n      this.longitude = event.latLng.lng();\n      this.getAddress(this.latitude, this.longitude);\n  });\n  }\n\n  onMapClick(event: google.maps.MapMouseEvent): void {\n    console.log('onMapClick',event);\n    this.latitude = event.latLng.lat();\n    this.longitude = event.latLng.lng();\n    this.getAddress(this.latitude, this.longitude);\n  }\n\n\n  private setCurrentLocation() {\n    if ('geolocation' in navigator) {\n      navigator.geolocation.getCurrentPosition((position) => {\n        this.latitude = position.coords.latitude;\n        this.longitude = position.coords.longitude;\n        this.markerPosition = { lat: this.latitude, lng: this.longitude };\n        this.center = { lat: this.latitude, lng: this.longitude };\n        this.zoom = 8;\n        this.getAddress(this.latitude, this.longitude);\n      });\n    }\n  }\n\n\n  getAddress(latitude: number, longitude: number) {\n    if (this.geoCoder) {\n      this.geoCoder.geocode({ location: { lat: latitude, lng: longitude } }, (results, status) => {\n        console.log('results',results);\n        console.log('status',status);\n        if (status === 'OK') {\n          if (results[0]) {\n           // this.zoom = 18;\n            this.address = results[0].formatted_address;\n             // VD 21DEC23 - dependent field change\n            let change = new ChangeWrapper();\n            // RS 09DEC24 Changed keys\n            change.fromQuestionId = this.question.id;\n            let addObj1 = {};\n            addObj1['address'] = this.address;\n            addObj1['latitude'] = latitude;\n            addObj1['longitude'] = longitude;\n            change.valueObj = addObj1;\n            this.locationSelected.emit(change);\n          } else {\n            console.log('No results found');\n          }\n        } else {\n          console.log('Geocoder failed due to: ' + status);\n        }\n      });\n    }\n  }\n\n  openMap() {\n    this.showModal = true;\n    if(!this.address){\n      this.latitude = this.longitude = null;\n    }\n    if (!(this.latitude && this.longitude)) {\n      this.setCurrentLocation();\n    }else{\n      this.markerPosition = { lat: this.latitude, lng: this.longitude };\n      this.center = { lat: this.latitude, lng: this.longitude };\n      this.zoom = 8;\n    }\n  }\n\n  closeModal() {\n    this.showModal = false;\n  }\n\n\n}\n","<div>\n     <!-- <label class=\"she-label\">Location</label> -->\n    <!-- HA 19DEC23 For translation -->\n     <input #search class=\"she-line-input form-control\" type=\"text\" placeholder=\"{{ 'enterLocation' | i18n:i18nService.currentLanguage }}\"\n        (keydown.enter)=\"$event.preventDefault()\" placeholder=\"{{ 'searchNearestLocation' | i18n:i18nService.currentLanguage }}\" autocorrect=\"off\"\n        autocapitalize=\"off\" spellcheck=\"off\" type=\"text\"  [(ngModel)]=\"address\"\n        >\n        <a (click)=\"openMap()\"\n        style=\"color:#48B7FF;position:relative;top:5px;cursor: pointer;\">\n        <i class=\"fa fa-location-arrow\" aria-hidden=\"true\">\n        <!-- HA 19DEC23 For translation -->\n        </i> {{ 'pickLocation' | i18n:i18nService.currentLanguage }}</a>\n</div>\n\n<div class=\"map-overlay\" *ngIf=\"showModal\">\n  <div class=\"map-modal\">\n    <div class=\"map-modal-content\">\n      <div class=\"map-modal-header\">\n        <!-- HA 19DEC23 For translation -->\n        <h4>{{ 'pickYourLocation' | i18n:i18nService.currentLanguage }}</h4>\n        <button class=\"close-button\" (click)=\"closeModal()\">X</button>\n      </div>\n      <!-- Modal content goes here -->\n    <!-- <agm-map [latitude]=\"latitude\" [longitude]=\"longitude\" [zoom]=\"zoom\" (mapClick)=\"markerDragEnd($event)\"\n    [fullscreenControl]=\"true\">\n    <agm-marker [latitude]=\"latitude\" [longitude]=\"longitude\" [markerDraggable]=\"true\"\n      (dragEnd)=\"markerDragEnd($event)\"></agm-marker>\n    </agm-map> -->\n    <google-map [latitude]=\"latitude\"  [longitude]=\"longitude\" [zoom]=\"zoom\" [center]=\"center\" (mapClick)=\"onMapClick($event)\">\n      <map-marker [position]=\"markerPosition\" [options]=\"markerOptions\"></map-marker>\n    </google-map>\n    </div>\n  </div>\n</div>\n\n\n\n\n\n\n"]}
|