@rangertechnologies/ngnxt 2.0.37 → 2.0.39
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 +2 -2
- package/esm2022/lib/components/custom-date-picker/custom-date-picker.component.mjs +33 -33
- package/esm2022/lib/components/custom-dropdown/custom-dropdown.component.mjs +94 -82
- package/esm2022/lib/components/custom-input/custom-input.component.mjs +76 -76
- package/esm2022/lib/components/custom-table/custom-table.component.mjs +53 -53
- package/esm2022/lib/components/custom-text-area/custom-text-area.component.mjs +34 -34
- package/esm2022/lib/components/dropdown-with-flag/dropdown-with-flag.component.mjs +34 -34
- package/esm2022/lib/components/file-upload/file-upload.component.mjs +110 -159
- package/esm2022/lib/components/file-view/file-view.component.mjs +42 -0
- package/esm2022/lib/components/pick-location/pick-location.component.mjs +136 -136
- package/esm2022/lib/components/search-box/search-box.component.mjs +106 -84
- 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 +8 -8
- package/esm2022/lib/model/errorWrapper.mjs +6 -6
- package/esm2022/lib/model/tableWrapper.mjs +16 -16
- package/esm2022/lib/nxt-app.component.mjs +22 -22
- package/esm2022/lib/nxt-app.module.mjs +276 -268
- package/esm2022/lib/nxt-app.service.mjs +14 -14
- package/esm2022/lib/pages/booklet/booklet.component.mjs +171 -159
- package/esm2022/lib/pages/questionbook/questionbook.component.mjs +102 -85
- package/esm2022/lib/pages/questionnaire/questionnaire.component.mjs +2066 -2066
- package/esm2022/lib/pages/summary-page/summary-page.component.mjs +70 -0
- package/esm2022/lib/sample.mjs +432 -432
- package/esm2022/lib/services/change.service.mjs +38 -33
- package/esm2022/lib/services/data.service.mjs +40 -40
- package/esm2022/lib/services/salesforce.service.mjs +46 -46
- package/esm2022/lib/services/shared.service.mjs +86 -0
- package/esm2022/lib/services/storage.service.mjs +41 -41
- package/esm2022/lib/wrapper.mjs +161 -161
- package/esm2022/public-api.mjs +11 -10
- package/esm2022/rangertechnologies-ngnxt.mjs +4 -4
- package/fesm2022/rangertechnologies-ngnxt.mjs +4105 -3899
- package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
- package/index.d.ts +5 -5
- package/lib/components/custom-date-picker/custom-date-picker.component.d.ts +14 -14
- package/lib/components/custom-dropdown/custom-dropdown.component.d.ts +29 -26
- package/lib/components/custom-input/custom-input.component.d.ts +26 -26
- package/lib/components/custom-table/custom-table.component.d.ts +20 -20
- package/lib/components/custom-text-area/custom-text-area.component.d.ts +14 -14
- package/lib/components/dropdown-with-flag/dropdown-with-flag.component.d.ts +14 -14
- package/lib/components/file-upload/file-upload.component.d.ts +24 -23
- package/lib/components/file-view/file-view.component.d.ts +14 -0
- package/lib/components/pick-location/pick-location.component.d.ts +35 -35
- package/lib/components/search-box/search-box.component.d.ts +40 -34
- package/lib/interfaces/actionMeta.d.ts +5 -5
- package/lib/interfaces/apimeta.d.ts +5 -5
- package/lib/interfaces/dependencyMeta.d.ts +5 -5
- package/lib/model/bookletWrapper.d.ts +5 -5
- package/lib/model/changeWrapper.d.ts +7 -7
- package/lib/model/errorWrapper.d.ts +5 -5
- package/lib/model/tableWrapper.d.ts +15 -15
- package/lib/nxt-app.component.d.ts +8 -8
- package/lib/nxt-app.module.d.ts +30 -28
- package/lib/nxt-app.service.d.ts +6 -6
- package/lib/pages/booklet/booklet.component.d.ts +45 -43
- package/lib/pages/questionbook/questionbook.component.d.ts +27 -26
- package/lib/pages/questionnaire/questionnaire.component.d.ts +206 -206
- package/lib/pages/summary-page/summary-page.component.d.ts +18 -0
- package/lib/sample.d.ts +10 -10
- package/lib/services/change.service.d.ts +16 -13
- package/lib/services/data.service.d.ts +9 -9
- package/lib/services/salesforce.service.d.ts +11 -11
- package/lib/services/shared.service.d.ts +11 -0
- package/lib/services/storage.service.d.ts +12 -12
- package/lib/wrapper.d.ts +161 -161
- package/package.json +1 -1
- package/public-api.d.ts +7 -6
- package/rangertechnologies-ngnxt-2.0.39.tgz +0 -0
- package/rangertechnologies-ngnxt-2.0.37.tgz +0 -0
|
@@ -1,136 +1,136 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output, ViewChild } 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
|
-
import * as i3 from "@angular/google-maps";
|
|
6
|
-
export class PickLocationComponent {
|
|
7
|
-
ngZone;
|
|
8
|
-
latitude = null;
|
|
9
|
-
longitude = null;
|
|
10
|
-
zoom = 10;
|
|
11
|
-
geoCoder;
|
|
12
|
-
// public formGroup: FormGroup;
|
|
13
|
-
searchElementRef;
|
|
14
|
-
showModal = false;
|
|
15
|
-
address;
|
|
16
|
-
locationSelected = new EventEmitter();
|
|
17
|
-
navigatorGeolocation;
|
|
18
|
-
markerPosition;
|
|
19
|
-
center;
|
|
20
|
-
markerOptions;
|
|
21
|
-
constructor(
|
|
22
|
-
// private mapsAPILoader: MapsAPILoader,
|
|
23
|
-
ngZone) {
|
|
24
|
-
this.ngZone = ngZone;
|
|
25
|
-
this.geoCoder = new google.maps.Geocoder();
|
|
26
|
-
this.markerOptions = new google.maps.Marker({
|
|
27
|
-
draggable: true,
|
|
28
|
-
animation: google.maps.Animation.DROP
|
|
29
|
-
});
|
|
30
|
-
// this.formGroup = this.formBuilder.group({
|
|
31
|
-
// location: [''] // Add any initial value or leave it empty
|
|
32
|
-
// });
|
|
33
|
-
}
|
|
34
|
-
ngOnInit() {
|
|
35
|
-
this.initAutocomplete();
|
|
36
|
-
this.onMarkerDragEnd();
|
|
37
|
-
}
|
|
38
|
-
initAutocomplete() {
|
|
39
|
-
if (this.geoCoder) {
|
|
40
|
-
const autocomplete = new google.maps.places.Autocomplete(this.searchElementRef?.nativeElement, {
|
|
41
|
-
types: []
|
|
42
|
-
});
|
|
43
|
-
autocomplete.addListener('place_changed', () => {
|
|
44
|
-
this.ngZone.run(() => {
|
|
45
|
-
const place = autocomplete.getPlace();
|
|
46
|
-
if (place.geometry === undefined || place.geometry === null) {
|
|
47
|
-
return;
|
|
48
|
-
}
|
|
49
|
-
this.latitude = place.geometry.location.lat();
|
|
50
|
-
this.longitude = place.geometry.location.lng();
|
|
51
|
-
this.zoom = 18;
|
|
52
|
-
this.address = place.formatted_address;
|
|
53
|
-
this.locationSelected.emit(this.address);
|
|
54
|
-
});
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
onMarkerDragEnd() {
|
|
59
|
-
google.maps.event.addListener(this.markerOptions, 'dragend', (event) => {
|
|
60
|
-
console.log('dragable working', event);
|
|
61
|
-
this.latitude = event.latLng.lat();
|
|
62
|
-
this.longitude = event.latLng.lng();
|
|
63
|
-
this.getAddress(this.latitude, this.longitude);
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
onMapClick(event) {
|
|
67
|
-
console.log('onMapClick', event);
|
|
68
|
-
this.latitude = event.latLng.lat();
|
|
69
|
-
this.longitude = event.latLng.lng();
|
|
70
|
-
this.getAddress(this.latitude, this.longitude);
|
|
71
|
-
}
|
|
72
|
-
setCurrentLocation() {
|
|
73
|
-
if ('geolocation' in navigator) {
|
|
74
|
-
navigator.geolocation.getCurrentPosition((position) => {
|
|
75
|
-
this.latitude = position.coords.latitude;
|
|
76
|
-
this.longitude = position.coords.longitude;
|
|
77
|
-
this.markerPosition = { lat: this.latitude, lng: this.longitude };
|
|
78
|
-
this.center = { lat: this.latitude, lng: this.longitude };
|
|
79
|
-
this.zoom = 8;
|
|
80
|
-
this.getAddress(this.latitude, this.longitude);
|
|
81
|
-
});
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
getAddress(latitude, longitude) {
|
|
85
|
-
if (this.geoCoder) {
|
|
86
|
-
this.geoCoder.geocode({ location: { lat: latitude, lng: longitude } }, (results, status) => {
|
|
87
|
-
console.log('results', results);
|
|
88
|
-
console.log('status', status);
|
|
89
|
-
if (status === 'OK') {
|
|
90
|
-
if (results[0]) {
|
|
91
|
-
// this.zoom = 18;
|
|
92
|
-
this.address = results[0].formatted_address;
|
|
93
|
-
this.locationSelected.emit(this.address);
|
|
94
|
-
}
|
|
95
|
-
else {
|
|
96
|
-
console.log('No results found');
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
else {
|
|
100
|
-
console.log('Geocoder failed due to: ' + status);
|
|
101
|
-
}
|
|
102
|
-
});
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
openMap() {
|
|
106
|
-
this.showModal = true;
|
|
107
|
-
if (!this.address) {
|
|
108
|
-
this.latitude = this.longitude = null;
|
|
109
|
-
}
|
|
110
|
-
if (!(this.latitude && this.longitude)) {
|
|
111
|
-
this.setCurrentLocation();
|
|
112
|
-
}
|
|
113
|
-
else {
|
|
114
|
-
this.markerPosition = { lat: this.latitude, lng: this.longitude };
|
|
115
|
-
this.center = { lat: this.latitude, lng: this.longitude };
|
|
116
|
-
this.zoom = 8;
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
closeModal() {
|
|
120
|
-
this.showModal = false;
|
|
121
|
-
}
|
|
122
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: PickLocationComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
|
|
123
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: PickLocationComponent, selector: "app-pick-location", inputs: { address: "address" }, outputs: { locationSelected: "locationSelected" }, viewQueries: [{ propertyName: "searchElementRef", first: true, predicate: ["search"], descendants: true, static: true }], ngImport: i0, template: "<div>\
|
|
124
|
-
}
|
|
125
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: PickLocationComponent, decorators: [{
|
|
126
|
-
type: Component,
|
|
127
|
-
args: [{ selector: 'app-pick-location', template: "<div>\
|
|
128
|
-
}], ctorParameters: function () { return [{ type: i0.NgZone }]; }, propDecorators: { searchElementRef: [{
|
|
129
|
-
type: ViewChild,
|
|
130
|
-
args: ['search', { static: true }]
|
|
131
|
-
}], address: [{
|
|
132
|
-
type: Input
|
|
133
|
-
}], locationSelected: [{
|
|
134
|
-
type: Output
|
|
135
|
-
}] } });
|
|
136
|
-
//# 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\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  @Output() locationSelected: EventEmitter<any> = new EventEmitter<any>();\r\n  navigatorGeolocation: any;\r\n  markerPosition: { lat: any; lng: any; };\r\n  center: { lat: any; lng: any; };\r\n  markerOptions:any;\r\n\r\n  constructor(\r\n   // private mapsAPILoader: MapsAPILoader,\r\n    private ngZone: NgZone) { \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.formGroup = this.formBuilder.group({\r\n    //   location: [''] // Add any initial value or leave it empty\r\n    // });\r\n\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.initAutocomplete();\r\n    this.onMarkerDragEnd();\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          this.locationSelected.emit(this.address);\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            this.locationSelected.emit(this.address);\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    <input #search class=\"she-line-input form-control\" type=\"text\" placeholder=\"Enter Location\"\r\n        (keydown.enter)=\"$event.preventDefault()\" placeholder=\"Search Nearest Location\" 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        </i> Pick Location</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        <h4>Pick Your Location</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
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "@angular/forms";
|
|
5
|
+
import * as i3 from "@angular/google-maps";
|
|
6
|
+
export class PickLocationComponent {
|
|
7
|
+
ngZone;
|
|
8
|
+
latitude = null;
|
|
9
|
+
longitude = null;
|
|
10
|
+
zoom = 10;
|
|
11
|
+
geoCoder;
|
|
12
|
+
// public formGroup: FormGroup;
|
|
13
|
+
searchElementRef;
|
|
14
|
+
showModal = false;
|
|
15
|
+
address;
|
|
16
|
+
locationSelected = new EventEmitter();
|
|
17
|
+
navigatorGeolocation;
|
|
18
|
+
markerPosition;
|
|
19
|
+
center;
|
|
20
|
+
markerOptions;
|
|
21
|
+
constructor(
|
|
22
|
+
// private mapsAPILoader: MapsAPILoader,
|
|
23
|
+
ngZone) {
|
|
24
|
+
this.ngZone = ngZone;
|
|
25
|
+
this.geoCoder = new google.maps.Geocoder();
|
|
26
|
+
this.markerOptions = new google.maps.Marker({
|
|
27
|
+
draggable: true,
|
|
28
|
+
animation: google.maps.Animation.DROP
|
|
29
|
+
});
|
|
30
|
+
// this.formGroup = this.formBuilder.group({
|
|
31
|
+
// location: [''] // Add any initial value or leave it empty
|
|
32
|
+
// });
|
|
33
|
+
}
|
|
34
|
+
ngOnInit() {
|
|
35
|
+
this.initAutocomplete();
|
|
36
|
+
this.onMarkerDragEnd();
|
|
37
|
+
}
|
|
38
|
+
initAutocomplete() {
|
|
39
|
+
if (this.geoCoder) {
|
|
40
|
+
const autocomplete = new google.maps.places.Autocomplete(this.searchElementRef?.nativeElement, {
|
|
41
|
+
types: []
|
|
42
|
+
});
|
|
43
|
+
autocomplete.addListener('place_changed', () => {
|
|
44
|
+
this.ngZone.run(() => {
|
|
45
|
+
const place = autocomplete.getPlace();
|
|
46
|
+
if (place.geometry === undefined || place.geometry === null) {
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
this.latitude = place.geometry.location.lat();
|
|
50
|
+
this.longitude = place.geometry.location.lng();
|
|
51
|
+
this.zoom = 18;
|
|
52
|
+
this.address = place.formatted_address;
|
|
53
|
+
this.locationSelected.emit(this.address);
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
onMarkerDragEnd() {
|
|
59
|
+
google.maps.event.addListener(this.markerOptions, 'dragend', (event) => {
|
|
60
|
+
console.log('dragable working', event);
|
|
61
|
+
this.latitude = event.latLng.lat();
|
|
62
|
+
this.longitude = event.latLng.lng();
|
|
63
|
+
this.getAddress(this.latitude, this.longitude);
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
onMapClick(event) {
|
|
67
|
+
console.log('onMapClick', event);
|
|
68
|
+
this.latitude = event.latLng.lat();
|
|
69
|
+
this.longitude = event.latLng.lng();
|
|
70
|
+
this.getAddress(this.latitude, this.longitude);
|
|
71
|
+
}
|
|
72
|
+
setCurrentLocation() {
|
|
73
|
+
if ('geolocation' in navigator) {
|
|
74
|
+
navigator.geolocation.getCurrentPosition((position) => {
|
|
75
|
+
this.latitude = position.coords.latitude;
|
|
76
|
+
this.longitude = position.coords.longitude;
|
|
77
|
+
this.markerPosition = { lat: this.latitude, lng: this.longitude };
|
|
78
|
+
this.center = { lat: this.latitude, lng: this.longitude };
|
|
79
|
+
this.zoom = 8;
|
|
80
|
+
this.getAddress(this.latitude, this.longitude);
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
getAddress(latitude, longitude) {
|
|
85
|
+
if (this.geoCoder) {
|
|
86
|
+
this.geoCoder.geocode({ location: { lat: latitude, lng: longitude } }, (results, status) => {
|
|
87
|
+
console.log('results', results);
|
|
88
|
+
console.log('status', status);
|
|
89
|
+
if (status === 'OK') {
|
|
90
|
+
if (results[0]) {
|
|
91
|
+
// this.zoom = 18;
|
|
92
|
+
this.address = results[0].formatted_address;
|
|
93
|
+
this.locationSelected.emit(this.address);
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
console.log('No results found');
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
else {
|
|
100
|
+
console.log('Geocoder failed due to: ' + status);
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
openMap() {
|
|
106
|
+
this.showModal = true;
|
|
107
|
+
if (!this.address) {
|
|
108
|
+
this.latitude = this.longitude = null;
|
|
109
|
+
}
|
|
110
|
+
if (!(this.latitude && this.longitude)) {
|
|
111
|
+
this.setCurrentLocation();
|
|
112
|
+
}
|
|
113
|
+
else {
|
|
114
|
+
this.markerPosition = { lat: this.latitude, lng: this.longitude };
|
|
115
|
+
this.center = { lat: this.latitude, lng: this.longitude };
|
|
116
|
+
this.zoom = 8;
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
closeModal() {
|
|
120
|
+
this.showModal = false;
|
|
121
|
+
}
|
|
122
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: PickLocationComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
|
|
123
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: PickLocationComponent, selector: "app-pick-location", inputs: { address: "address" }, 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 <input #search class=\"she-line-input form-control\" type=\"text\" placeholder=\"Enter Location\"\n (keydown.enter)=\"$event.preventDefault()\" placeholder=\"Search Nearest Location\" 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 </i> Pick Location</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 <h4>Pick Your Location</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: 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"] }, { kind: "component", type: i3.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"] }, { kind: "directive", type: i3.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"], exportAs: ["mapMarker"] }] });
|
|
124
|
+
}
|
|
125
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: PickLocationComponent, decorators: [{
|
|
126
|
+
type: Component,
|
|
127
|
+
args: [{ selector: 'app-pick-location', template: "<div>\n <!-- <label class=\"she-label\">Location</label> -->\n <input #search class=\"she-line-input form-control\" type=\"text\" placeholder=\"Enter Location\"\n (keydown.enter)=\"$event.preventDefault()\" placeholder=\"Search Nearest Location\" 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 </i> Pick Location</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 <h4>Pick Your Location</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"] }]
|
|
128
|
+
}], ctorParameters: function () { return [{ type: i0.NgZone }]; }, propDecorators: { searchElementRef: [{
|
|
129
|
+
type: ViewChild,
|
|
130
|
+
args: ['search', { static: true }]
|
|
131
|
+
}], address: [{
|
|
132
|
+
type: Input
|
|
133
|
+
}], locationSelected: [{
|
|
134
|
+
type: Output
|
|
135
|
+
}] } });
|
|
136
|
+
//# 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';\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  @Output() locationSelected: EventEmitter<any> = new EventEmitter<any>();\n  navigatorGeolocation: any;\n  markerPosition: { lat: any; lng: any; };\n  center: { lat: any; lng: any; };\n  markerOptions:any;\n\n  constructor(\n   // private mapsAPILoader: MapsAPILoader,\n    private ngZone: NgZone) { \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.formGroup = this.formBuilder.group({\n    //   location: [''] // Add any initial value or leave it empty\n    // });\n\n  }\n\n  ngOnInit(): void {\n    this.initAutocomplete();\n    this.onMarkerDragEnd();\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          this.locationSelected.emit(this.address);\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            this.locationSelected.emit(this.address);\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    <input #search class=\"she-line-input form-control\" type=\"text\" placeholder=\"Enter Location\"\n        (keydown.enter)=\"$event.preventDefault()\" placeholder=\"Search Nearest Location\" 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        </i> Pick Location</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        <h4>Pick Your Location</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"]}
|