@rangertechnologies/ngnxt 2.0.37 → 2.0.38
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 +84 -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 +96 -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 +4079 -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 +34 -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.38.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"]}
|
|
@@ -1,84 +1,84 @@
|
|
|
1
|
-
import { Component, Input, ViewChild, } from "@angular/core";
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "../../services/salesforce.service";
|
|
4
|
-
import * as i2 from "../../services/data.service";
|
|
5
|
-
import * as i3 from "@angular/router";
|
|
6
|
-
import * as i4 from "@angular/common/http";
|
|
7
|
-
import * as i5 from "@angular/common";
|
|
8
|
-
import * as i6 from "@angular/forms";
|
|
9
|
-
export class SearchBoxComponent {
|
|
10
|
-
sfService;
|
|
11
|
-
dataService;
|
|
12
|
-
route;
|
|
13
|
-
http;
|
|
14
|
-
placeHolderText;
|
|
15
|
-
auto;
|
|
16
|
-
filterName;
|
|
17
|
-
finalResults = [];
|
|
18
|
-
searchKeyWord = '';
|
|
19
|
-
newResult;
|
|
20
|
-
showResult = false;
|
|
21
|
-
noResult = false;
|
|
22
|
-
showSuggestion = true;
|
|
23
|
-
el;
|
|
24
|
-
serv = 'api';
|
|
25
|
-
tkn = '';
|
|
26
|
-
constructor(sfService, dataService, route, http, el) {
|
|
27
|
-
this.sfService = sfService;
|
|
28
|
-
this.dataService = dataService;
|
|
29
|
-
this.route = route;
|
|
30
|
-
this.http = http;
|
|
31
|
-
}
|
|
32
|
-
ngOnInit() {
|
|
33
|
-
}
|
|
34
|
-
clearList() {
|
|
35
|
-
setTimeout(() => {
|
|
36
|
-
this.finalResults = [];
|
|
37
|
-
}, 1000);
|
|
38
|
-
}
|
|
39
|
-
getSourceDataLocal(event) {
|
|
40
|
-
if (event.target.value.length > 2) {
|
|
41
|
-
this.showSuggestion = true;
|
|
42
|
-
this.finalResults = [];
|
|
43
|
-
this.searchKeyWord = event.target.value;
|
|
44
|
-
this.showResult = false;
|
|
45
|
-
this.getSourceData(event.target.value);
|
|
46
|
-
}
|
|
47
|
-
else {
|
|
48
|
-
this.showSuggestion = false;
|
|
49
|
-
this.finalResults = [];
|
|
50
|
-
this.noResult = false;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
apiResponse(keyword) {
|
|
54
|
-
return this.http.get('https://dummyjson.com/products');
|
|
55
|
-
}
|
|
56
|
-
getSourceData = (keyword) => {
|
|
57
|
-
this.apiResponse('ok').subscribe((apiResponse) => {
|
|
58
|
-
let results = [];
|
|
59
|
-
for (let i = 0; i < apiResponse.products.length; i++) {
|
|
60
|
-
if (apiResponse.products[i].title.indexOf(keyword) >= 0) {
|
|
61
|
-
console.log('pushing ' + apiResponse.products[i].title);
|
|
62
|
-
results.push(apiResponse.products[i]);
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
this.noResult = !(results.length > 1);
|
|
66
|
-
this.finalResults = results;
|
|
67
|
-
});
|
|
68
|
-
};
|
|
69
|
-
clickItem(event) {
|
|
70
|
-
console.log('inside clickItem of ' + event.target.value);
|
|
71
|
-
}
|
|
72
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SearchBoxComponent, deps: [{ token: i1.SalesforceService }, { token: i2.DataService }, { token: i3.ActivatedRoute }, { token: i4.HttpClient }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
73
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: SearchBoxComponent, selector: "lib-search-box", inputs: { placeHolderText: "placeHolderText" }, viewQueries: [{ propertyName: "auto", first: true, predicate: ["auto"], descendants: true }], ngImport: i0, template: "<div id=\"autocomplete-input\">\
|
|
74
|
-
}
|
|
75
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SearchBoxComponent, decorators: [{
|
|
76
|
-
type: Component,
|
|
77
|
-
args: [{ selector: 'lib-search-box', template: "<div id=\"autocomplete-input\">\
|
|
78
|
-
}], ctorParameters: function () { return [{ type: i1.SalesforceService }, { type: i2.DataService }, { type: i3.ActivatedRoute }, { type: i4.HttpClient }, { type: i0.ElementRef }]; }, propDecorators: { placeHolderText: [{
|
|
79
|
-
type: Input
|
|
80
|
-
}], auto: [{
|
|
81
|
-
type: ViewChild,
|
|
82
|
-
args: ['auto']
|
|
83
|
-
}] } });
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-box.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/search-box/search-box.component.ts","../../../../../../projects/nxt-app/src/lib/components/search-box/search-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  OnChanges,\r\n  Inject,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ViewEncapsulation,\r\n  ElementRef,\r\n  ViewChild,\r\n} from \"@angular/core\";\r\nimport { DataService } from '../../services/data.service';\r\nimport { SalesforceService } from \"../../services/salesforce.service\";\r\nimport { ActivatedRoute, Params } from \"@angular/router\";\r\nimport { HttpClient, HttpHeaders } from '@angular/common/http';\r\nimport { Observable } from 'rxjs';\r\nimport { ItemsList } from \"@ng-select/ng-select/lib/items-list\";\r\nimport { ConsoleService } from \"@ng-select/ng-select/lib/console.service\";\r\n\r\n@Component({\r\n  selector: 'lib-search-box',\r\n  templateUrl: './search-box.component.html',\r\n  styleUrls: ['./search-box.component.css']\r\n})\r\nexport class SearchBoxComponent implements OnInit {\r\n  @Input() placeHolderText: string;\r\n  @ViewChild('auto') auto;\r\n\r\n  public filterName: string;\r\n  public finalResults: any[] = [];\r\n  public searchKeyWord: string = '';\r\n  public newResult: any;\r\n  public showResult = false;\r\n  public noResult = false;\r\n  public showSuggestion = true;\r\n  private el: HTMLElement;\r\n  private serv: string = 'api';\r\n  private tkn: string = '';\r\n  \r\n  constructor(\r\n    private sfService: SalesforceService,\r\n    private dataService: DataService,\r\n    private route: ActivatedRoute,\r\n    private http: HttpClient,\r\n    el: ElementRef\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n  }\r\n\r\n  clearList(){\r\n    setTimeout(()=> {\r\n      this.finalResults = [];\r\n    }, 1000);\r\n  }\r\n\r\n  getSourceDataLocal(event) { //to get results list from backend API whenever key is up after the entering atleast one key\r\n    if(event.target.value.length > 2){\r\n      this.showSuggestion=true;\r\n      this.finalResults=[];\r\n      this.searchKeyWord = event.target.value;\r\n      this.showResult = false;\r\n      this.getSourceData(event.target.value);\r\n    } else {\r\n      this.showSuggestion=false;\r\n      this.finalResults = [];\r\n      this.noResult = false;\r\n    }\r\n  }\r\n\r\n  public apiResponse(keyword: string): Observable<any> {\r\n    return this.http.get('https://dummyjson.com/products');\r\n  }\r\n\r\n  public getSourceData = (keyword: string) => {\r\n    this.apiResponse('ok').subscribe((apiResponse) => {\r\n      let results=[];\r\n      for (let i = 0; i < apiResponse.products.length; i++) {\r\n        if(apiResponse.products[i].title.indexOf(keyword) >= 0) {\r\n          console.log('pushing ' + apiResponse.products[i].title);\r\n          results.push(apiResponse.products[i]);\r\n        }\r\n      }\r\n      this.noResult = !(results.length > 1);\r\n      this.finalResults = results;\r\n    })\r\n  }\r\n\r\n  public clickItem(event) {\r\n    console.log('inside clickItem of ' + event.target.value);\r\n  }\r\n  /*\r\n  public getSourceData = (keyword: string) => {\r\n    if(this.serv == \"api\") {\r\n      this.dataService.getAPIData(\r\n        this.tkn,\r\n        [\"QuestionBook\", \"read\", uuid],\r\n        this.successSourceData,\r\n        this.failureSourceData\r\n      );\r\n    } else {\r\n      this.sfService.remoteAction(\r\n        \"NxtController.process\",\r\n        [\"QuestionBook\", \"read\", uuid],\r\n        this.successSourceData,\r\n        this.failureSourceData\r\n      );\r\n    }\r\n  }\r\n\r\n  public successSourceData = (response) => {\r\n    let results=[];\r\n    results=response.results;\r\n    results.push({uuid: null, name: \"\"});\r\n    this.noResult = !(results.length > 1);\r\n    this.finalResults = results;\r\n  }\r\n\r\n  public failureSourceData = (response) => {\r\n    console.log(\"Error reading the data from API\");\r\n  }\r\n  */\r\n}\r\n","<div id=\"autocomplete-input\">\r\n    <input #auto id=\"searchbox-style\" \r\n            (blur)=\"clearList()\" \r\n            [(ngModel)]=\"filterName\" \r\n            type=\"text\" \r\n            name=\"name\" \r\n            (placeholder)=\"placeHolderText\" \r\n            style=\"margin: 0 !important;\" \r\n            class=\"searchInput\" \r\n            (focusin)=\"getSourceDataLocal($event)\" \r\n            (input)=\"getSourceDataLocal($event)\">\r\n    <div id=\"selectList\" style=\"position: absolute;position: absolute;background: white;z-index: 2;\">\r\n    <div *ngIf=\"finalResults.length > 1 && showSuggestion\" \r\n        style=\"max-height: 100vh;border: 1px solid #d2d4d6;overflow: scroll;\" \r\n        class=\"suggestions-container\">\r\n        <div *ngFor=\"let item of finalResults\" (click)='clickItem(item)' class=\"hoover\">\r\n            <div class=\"grid-x align-middle\" style=\"padding: 1rem\" *ngIf=\"item.id != null\">\r\n                <div class=\"cell shrink\" style=\"width: 60px; margin-right: 1.6rem;\">\r\n                    <img [src]=\"item.thumbnail\" style=\"width: 60px;\" alt=\"\">\r\n                </div>\r\n                <div class=\"cell auto\" style=\"text-align: left; padding-left: 20px;\">\r\n                    <h4 >{{item.title}}</h4>\r\n                    <div class=\"show-for-medium\" style=\" white-space: nowrap;\r\n                    overflow: hidden;text-overflow: ellipsis;\" > {{item.description}}\r\n                    </div>\r\n                    <div *ngIf=\"item.price\"  class=\"drop-list\">\r\n                        {{item.price.toFixed(2)}}\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
1
|
+
import { Component, Input, ViewChild, } from "@angular/core";
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../../services/salesforce.service";
|
|
4
|
+
import * as i2 from "../../services/data.service";
|
|
5
|
+
import * as i3 from "@angular/router";
|
|
6
|
+
import * as i4 from "@angular/common/http";
|
|
7
|
+
import * as i5 from "@angular/common";
|
|
8
|
+
import * as i6 from "@angular/forms";
|
|
9
|
+
export class SearchBoxComponent {
|
|
10
|
+
sfService;
|
|
11
|
+
dataService;
|
|
12
|
+
route;
|
|
13
|
+
http;
|
|
14
|
+
placeHolderText;
|
|
15
|
+
auto;
|
|
16
|
+
filterName;
|
|
17
|
+
finalResults = [];
|
|
18
|
+
searchKeyWord = '';
|
|
19
|
+
newResult;
|
|
20
|
+
showResult = false;
|
|
21
|
+
noResult = false;
|
|
22
|
+
showSuggestion = true;
|
|
23
|
+
el;
|
|
24
|
+
serv = 'api';
|
|
25
|
+
tkn = '';
|
|
26
|
+
constructor(sfService, dataService, route, http, el) {
|
|
27
|
+
this.sfService = sfService;
|
|
28
|
+
this.dataService = dataService;
|
|
29
|
+
this.route = route;
|
|
30
|
+
this.http = http;
|
|
31
|
+
}
|
|
32
|
+
ngOnInit() {
|
|
33
|
+
}
|
|
34
|
+
clearList() {
|
|
35
|
+
setTimeout(() => {
|
|
36
|
+
this.finalResults = [];
|
|
37
|
+
}, 1000);
|
|
38
|
+
}
|
|
39
|
+
getSourceDataLocal(event) {
|
|
40
|
+
if (event.target.value.length > 2) {
|
|
41
|
+
this.showSuggestion = true;
|
|
42
|
+
this.finalResults = [];
|
|
43
|
+
this.searchKeyWord = event.target.value;
|
|
44
|
+
this.showResult = false;
|
|
45
|
+
this.getSourceData(event.target.value);
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
this.showSuggestion = false;
|
|
49
|
+
this.finalResults = [];
|
|
50
|
+
this.noResult = false;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
apiResponse(keyword) {
|
|
54
|
+
return this.http.get('https://dummyjson.com/products');
|
|
55
|
+
}
|
|
56
|
+
getSourceData = (keyword) => {
|
|
57
|
+
this.apiResponse('ok').subscribe((apiResponse) => {
|
|
58
|
+
let results = [];
|
|
59
|
+
for (let i = 0; i < apiResponse.products.length; i++) {
|
|
60
|
+
if (apiResponse.products[i].title.indexOf(keyword) >= 0) {
|
|
61
|
+
console.log('pushing ' + apiResponse.products[i].title);
|
|
62
|
+
results.push(apiResponse.products[i]);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
this.noResult = !(results.length > 1);
|
|
66
|
+
this.finalResults = results;
|
|
67
|
+
});
|
|
68
|
+
};
|
|
69
|
+
clickItem(event) {
|
|
70
|
+
console.log('inside clickItem of ' + event.target.value);
|
|
71
|
+
}
|
|
72
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SearchBoxComponent, deps: [{ token: i1.SalesforceService }, { token: i2.DataService }, { token: i3.ActivatedRoute }, { token: i4.HttpClient }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
73
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: SearchBoxComponent, selector: "lib-search-box", inputs: { placeHolderText: "placeHolderText" }, viewQueries: [{ propertyName: "auto", first: true, predicate: ["auto"], descendants: true }], ngImport: i0, template: "<div id=\"autocomplete-input\">\n <input #auto id=\"searchbox-style\" \n (blur)=\"clearList()\" \n [(ngModel)]=\"filterName\" \n type=\"text\" \n name=\"name\" \n (placeholder)=\"placeHolderText\" \n style=\"margin: 0 !important;\" \n class=\"searchInput\" \n (focusin)=\"getSourceDataLocal($event)\" \n (input)=\"getSourceDataLocal($event)\">\n <div id=\"selectList\" style=\"position: absolute;position: absolute;background: white;z-index: 2;\">\n <div *ngIf=\"finalResults.length > 1 && showSuggestion\" \n style=\"max-height: 100vh;border: 1px solid #d2d4d6;overflow: scroll;\" \n class=\"suggestions-container\">\n <div *ngFor=\"let item of finalResults\" (click)='clickItem(item)' class=\"hoover\">\n <div class=\"grid-x align-middle\" style=\"padding: 1rem\" *ngIf=\"item.id != null\">\n <div class=\"cell shrink\" style=\"width: 60px; margin-right: 1.6rem;\">\n <img [src]=\"item.thumbnail\" style=\"width: 60px;\" alt=\"\">\n </div>\n <div class=\"cell auto\" style=\"text-align: left; padding-left: 20px;\">\n <h4 >{{item.title}}</h4>\n <div class=\"show-for-medium\" style=\" white-space: nowrap;\n overflow: hidden;text-overflow: ellipsis;\" > {{item.description}}\n </div>\n <div *ngIf=\"item.price\" class=\"drop-list\">\n {{item.price.toFixed(2)}}\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.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: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
|
|
74
|
+
}
|
|
75
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SearchBoxComponent, decorators: [{
|
|
76
|
+
type: Component,
|
|
77
|
+
args: [{ selector: 'lib-search-box', template: "<div id=\"autocomplete-input\">\n <input #auto id=\"searchbox-style\" \n (blur)=\"clearList()\" \n [(ngModel)]=\"filterName\" \n type=\"text\" \n name=\"name\" \n (placeholder)=\"placeHolderText\" \n style=\"margin: 0 !important;\" \n class=\"searchInput\" \n (focusin)=\"getSourceDataLocal($event)\" \n (input)=\"getSourceDataLocal($event)\">\n <div id=\"selectList\" style=\"position: absolute;position: absolute;background: white;z-index: 2;\">\n <div *ngIf=\"finalResults.length > 1 && showSuggestion\" \n style=\"max-height: 100vh;border: 1px solid #d2d4d6;overflow: scroll;\" \n class=\"suggestions-container\">\n <div *ngFor=\"let item of finalResults\" (click)='clickItem(item)' class=\"hoover\">\n <div class=\"grid-x align-middle\" style=\"padding: 1rem\" *ngIf=\"item.id != null\">\n <div class=\"cell shrink\" style=\"width: 60px; margin-right: 1.6rem;\">\n <img [src]=\"item.thumbnail\" style=\"width: 60px;\" alt=\"\">\n </div>\n <div class=\"cell auto\" style=\"text-align: left; padding-left: 20px;\">\n <h4 >{{item.title}}</h4>\n <div class=\"show-for-medium\" style=\" white-space: nowrap;\n overflow: hidden;text-overflow: ellipsis;\" > {{item.description}}\n </div>\n <div *ngIf=\"item.price\" class=\"drop-list\">\n {{item.price.toFixed(2)}}\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>" }]
|
|
78
|
+
}], ctorParameters: function () { return [{ type: i1.SalesforceService }, { type: i2.DataService }, { type: i3.ActivatedRoute }, { type: i4.HttpClient }, { type: i0.ElementRef }]; }, propDecorators: { placeHolderText: [{
|
|
79
|
+
type: Input
|
|
80
|
+
}], auto: [{
|
|
81
|
+
type: ViewChild,
|
|
82
|
+
args: ['auto']
|
|
83
|
+
}] } });
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-box.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/search-box/search-box.component.ts","../../../../../../projects/nxt-app/src/lib/components/search-box/search-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  OnChanges,\n  Inject,\n  Input,\n  Output,\n  EventEmitter,\n  ViewEncapsulation,\n  ElementRef,\n  ViewChild,\n} from \"@angular/core\";\nimport { DataService } from '../../services/data.service';\nimport { SalesforceService } from \"../../services/salesforce.service\";\nimport { ActivatedRoute, Params } from \"@angular/router\";\nimport { HttpClient, HttpHeaders } from '@angular/common/http';\nimport { Observable } from 'rxjs';\nimport { ItemsList } from \"@ng-select/ng-select/lib/items-list\";\nimport { ConsoleService } from \"@ng-select/ng-select/lib/console.service\";\n\n@Component({\n  selector: 'lib-search-box',\n  templateUrl: './search-box.component.html',\n  styleUrls: ['./search-box.component.css']\n})\nexport class SearchBoxComponent implements OnInit {\n  @Input() placeHolderText: string;\n  @ViewChild('auto') auto;\n\n  public filterName: string;\n  public finalResults: any[] = [];\n  public searchKeyWord: string = '';\n  public newResult: any;\n  public showResult = false;\n  public noResult = false;\n  public showSuggestion = true;\n  private el: HTMLElement;\n  private serv: string = 'api';\n  private tkn: string = '';\n  \n  constructor(\n    private sfService: SalesforceService,\n    private dataService: DataService,\n    private route: ActivatedRoute,\n    private http: HttpClient,\n    el: ElementRef\n  ) { }\n\n  ngOnInit(): void {\n  }\n\n  clearList(){\n    setTimeout(()=> {\n      this.finalResults = [];\n    }, 1000);\n  }\n\n  getSourceDataLocal(event) { //to get results list from backend API whenever key is up after the entering atleast one key\n    if(event.target.value.length > 2){\n      this.showSuggestion=true;\n      this.finalResults=[];\n      this.searchKeyWord = event.target.value;\n      this.showResult = false;\n      this.getSourceData(event.target.value);\n    } else {\n      this.showSuggestion=false;\n      this.finalResults = [];\n      this.noResult = false;\n    }\n  }\n\n  public apiResponse(keyword: string): Observable<any> {\n    return this.http.get('https://dummyjson.com/products');\n  }\n\n  public getSourceData = (keyword: string) => {\n    this.apiResponse('ok').subscribe((apiResponse) => {\n      let results=[];\n      for (let i = 0; i < apiResponse.products.length; i++) {\n        if(apiResponse.products[i].title.indexOf(keyword) >= 0) {\n          console.log('pushing ' + apiResponse.products[i].title);\n          results.push(apiResponse.products[i]);\n        }\n      }\n      this.noResult = !(results.length > 1);\n      this.finalResults = results;\n    })\n  }\n\n  public clickItem(event) {\n    console.log('inside clickItem of ' + event.target.value);\n  }\n  /*\n  public getSourceData = (keyword: string) => {\n    if(this.serv == \"api\") {\n      this.dataService.getAPIData(\n        this.tkn,\n        [\"QuestionBook\", \"read\", uuid],\n        this.successSourceData,\n        this.failureSourceData\n      );\n    } else {\n      this.sfService.remoteAction(\n        \"NxtController.process\",\n        [\"QuestionBook\", \"read\", uuid],\n        this.successSourceData,\n        this.failureSourceData\n      );\n    }\n  }\n\n  public successSourceData = (response) => {\n    let results=[];\n    results=response.results;\n    results.push({uuid: null, name: \"\"});\n    this.noResult = !(results.length > 1);\n    this.finalResults = results;\n  }\n\n  public failureSourceData = (response) => {\n    console.log(\"Error reading the data from API\");\n  }\n  */\n}\n","<div id=\"autocomplete-input\">\n    <input #auto id=\"searchbox-style\" \n            (blur)=\"clearList()\" \n            [(ngModel)]=\"filterName\" \n            type=\"text\" \n            name=\"name\" \n            (placeholder)=\"placeHolderText\" \n            style=\"margin: 0 !important;\" \n            class=\"searchInput\" \n            (focusin)=\"getSourceDataLocal($event)\" \n            (input)=\"getSourceDataLocal($event)\">\n    <div id=\"selectList\" style=\"position: absolute;position: absolute;background: white;z-index: 2;\">\n    <div *ngIf=\"finalResults.length > 1 && showSuggestion\" \n        style=\"max-height: 100vh;border: 1px solid #d2d4d6;overflow: scroll;\" \n        class=\"suggestions-container\">\n        <div *ngFor=\"let item of finalResults\" (click)='clickItem(item)' class=\"hoover\">\n            <div class=\"grid-x align-middle\" style=\"padding: 1rem\" *ngIf=\"item.id != null\">\n                <div class=\"cell shrink\" style=\"width: 60px; margin-right: 1.6rem;\">\n                    <img [src]=\"item.thumbnail\" style=\"width: 60px;\" alt=\"\">\n                </div>\n                <div class=\"cell auto\" style=\"text-align: left; padding-left: 20px;\">\n                    <h4 >{{item.title}}</h4>\n                    <div class=\"show-for-medium\" style=\" white-space: nowrap;\n                    overflow: hidden;text-overflow: ellipsis;\" > {{item.description}}\n                    </div>\n                    <div *ngIf=\"item.price\"  class=\"drop-list\">\n                        {{item.price.toFixed(2)}}\n                    </div>\n                </div>\n            </div>\n        </div>\n    </div>\n</div>"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uTWV0YS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL254dC1hcHAvc3JjL2xpYi9pbnRlcmZhY2VzL2FjdGlvbk1ldGEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQWN0aW9uTWV0YSB7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIGV2ZW50dG9lbWl0OiBzdHJpbmc7XG4gICAgYWx0OiBzdHJpbmc7XG59XG4iXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpbWV0YS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL254dC1hcHAvc3JjL2xpYi9pbnRlcmZhY2VzL2FwaW1ldGEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQVBJTWV0YSB7XG4gICAgZW5kcG9pbnQ6IHN0cmluZztcbiAgICB2YXJpYWJsZTogc3RyaW5nO1xuICAgIGZpZWxkOiBzdHJpbmc7XG59XG4iXX0=
|