@smarterplan/ngx-smarterplan-core 1.2.45 → 1.2.47
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +24 -24
- package/esm2020/lib/components/csv-export/csv-export.component.mjs +59 -59
- package/esm2020/lib/components/loader/loader.component.mjs +23 -23
- package/esm2020/lib/components/menu-bar/avatar/avatar.component.mjs +80 -80
- package/esm2020/lib/components/menu-bar/menu-bar.component.mjs +99 -99
- package/esm2020/lib/components/menu-bar/navigation-bar/navigation-bar.component.mjs +384 -384
- package/esm2020/lib/components/menu-bar/range-date-picker/range-date-picker.component.mjs +147 -147
- package/esm2020/lib/components/modal-switch-visit/modal-switch-visit.component.mjs +40 -40
- package/esm2020/lib/components/search-bar/search-bar.component.mjs +63 -63
- package/esm2020/lib/components/support-modal/support-modal.component.mjs +66 -66
- package/esm2020/lib/config.mjs +4 -4
- package/esm2020/lib/helpers.service.mjs +470 -470
- package/esm2020/lib/matterport-extensions/hsl-loader/HlsLoader.mjs +69 -69
- package/esm2020/lib/matterport-extensions/nest-thermostat/CanvasImage.mjs +51 -51
- package/esm2020/lib/matterport-extensions/nest-thermostat/CanvasRenderer.mjs +61 -61
- package/esm2020/lib/matterport-extensions/nest-thermostat/NestThermostat.mjs +158 -158
- package/esm2020/lib/matterport-extensions/nest-thermostat/PlaneRenderer.mjs +85 -85
- package/esm2020/lib/matterport-extensions/scene-component/SceneComponent.mjs +128 -128
- package/esm2020/lib/matterport-extensions/security-camera/SecurityCamera.mjs +249 -249
- package/esm2020/lib/matterport-extensions/tv-player/TvPlayer.mjs +98 -98
- package/esm2020/lib/matterport-extensions/video-renderer/VideoRenderer.mjs +64 -64
- package/esm2020/lib/matterport-extensions/view-frustum-mesh/ViewFrustumMesh.mjs +221 -221
- package/esm2020/lib/mattertagData.mjs +165 -165
- package/esm2020/lib/ngx-smarterplan-core.module.mjs +122 -122
- package/esm2020/lib/ngx-smarterplan-core.service.mjs +14 -14
- package/esm2020/lib/pipes/duration-to-string.pipe.mjs +66 -66
- package/esm2020/lib/pipes/format-date-number-to-digits.pipe.mjs +30 -30
- package/esm2020/lib/pipes/hashtag-from-id.pipe.mjs +26 -26
- package/esm2020/lib/pipes/safe-url.pipe.mjs +20 -20
- package/esm2020/lib/pipes/time-date-to-local-string.pipe.mjs +104 -104
- package/esm2020/lib/pipes/username-from-id.pipe.mjs +29 -29
- package/esm2020/lib/services/amplify-cache.service.mjs +72 -72
- package/esm2020/lib/services/base-tab.service.mjs +24 -24
- package/esm2020/lib/services/baseVisibility.service.mjs +18 -18
- package/esm2020/lib/services/content.service.mjs +135 -135
- package/esm2020/lib/services/filter.service.mjs +599 -599
- package/esm2020/lib/services/intervention.service.mjs +236 -236
- package/esm2020/lib/services/locale.service.mjs +45 -45
- package/esm2020/lib/services/matterport-import.service.mjs +340 -340
- package/esm2020/lib/services/matterport.service.mjs +1587 -1587
- package/esm2020/lib/services/models/affectation.service.mjs +60 -60
- package/esm2020/lib/services/models/base-object.service.mjs +70 -70
- package/esm2020/lib/services/models/capture.service.mjs +34 -34
- package/esm2020/lib/services/models/comment.service.mjs +98 -98
- package/esm2020/lib/services/models/domain.service.mjs +78 -78
- package/esm2020/lib/services/models/equipment.service.mjs +683 -683
- package/esm2020/lib/services/models/event.service.mjs +128 -128
- package/esm2020/lib/services/models/feature.service.mjs +380 -380
- package/esm2020/lib/services/models/hashtag.service.mjs +38 -38
- package/esm2020/lib/services/models/layer.service.mjs +33 -33
- package/esm2020/lib/services/models/measurement.service.mjs +199 -199
- package/esm2020/lib/services/models/mission.service.mjs +206 -206
- package/esm2020/lib/services/models/navigation.service.mjs +92 -92
- package/esm2020/lib/services/models/node.service.mjs +31 -31
- package/esm2020/lib/services/models/object3D.service.mjs +364 -364
- package/esm2020/lib/services/models/operation.service.mjs +59 -59
- package/esm2020/lib/services/models/organisation.service.mjs +73 -73
- package/esm2020/lib/services/models/plan.service.mjs +799 -799
- package/esm2020/lib/services/models/poi.service.mjs +103 -103
- package/esm2020/lib/services/models/profile.service.mjs +58 -58
- package/esm2020/lib/services/models/property.service.mjs +44 -44
- package/esm2020/lib/services/models/space.service.mjs +204 -204
- package/esm2020/lib/services/models/template.service.mjs +41 -41
- package/esm2020/lib/services/models/ticket.service.mjs +526 -526
- package/esm2020/lib/services/models/visit.service.mjs +130 -130
- package/esm2020/lib/services/models/zone.service.mjs +225 -225
- package/esm2020/lib/services/navigator.service.mjs +212 -212
- package/esm2020/lib/services/s3.service.mjs +137 -137
- package/esm2020/lib/services/search.service.mjs +124 -124
- package/esm2020/lib/services/support.service.mjs +42 -42
- package/esm2020/lib/services/tag.service.mjs +111 -111
- package/esm2020/lib/services/user.service.mjs +501 -501
- package/esm2020/lib/services/validators.service.mjs +50 -50
- package/esm2020/lib/services/viewer.service.mjs +389 -389
- package/esm2020/lib/services/zone-drawer.service.mjs +76 -76
- package/esm2020/lib/services/zoneChange.service.mjs +30 -30
- package/esm2020/lib/types.service.mjs +311 -311
- package/esm2020/lib/validators/email.directive.mjs +7 -7
- package/esm2020/lib/validators/no-empty.directive.mjs +12 -12
- package/esm2020/lib/validators/number.directive.mjs +12 -12
- package/esm2020/lib/validators/text.directive.mjs +12 -12
- package/esm2020/public-api.mjs +72 -72
- package/esm2020/smarterplan-ngx-smarterplan-core.mjs +4 -4
- package/fesm2015/smarterplan-ngx-smarterplan-core.mjs +13014 -13014
- package/fesm2015/smarterplan-ngx-smarterplan-core.mjs.map +1 -1
- package/fesm2020/smarterplan-ngx-smarterplan-core.mjs +12263 -12263
- package/fesm2020/smarterplan-ngx-smarterplan-core.mjs.map +1 -1
- package/lib/components/csv-export/csv-export.component.d.ts +18 -18
- package/lib/components/loader/loader.component.d.ts +10 -10
- package/lib/components/menu-bar/avatar/avatar.component.d.ts +21 -21
- package/lib/components/menu-bar/menu-bar.component.d.ts +38 -38
- package/lib/components/menu-bar/navigation-bar/navigation-bar.component.d.ts +73 -73
- package/lib/components/menu-bar/range-date-picker/range-date-picker.component.d.ts +35 -35
- package/lib/components/modal-switch-visit/modal-switch-visit.component.d.ts +22 -22
- package/lib/components/search-bar/search-bar.component.d.ts +16 -16
- package/lib/components/support-modal/support-modal.component.d.ts +26 -26
- package/lib/config.d.ts +22 -22
- package/lib/helpers.service.d.ts +79 -79
- package/lib/matterport-extensions/hsl-loader/HlsLoader.d.ts +26 -26
- package/lib/matterport-extensions/nest-thermostat/CanvasImage.d.ts +31 -31
- package/lib/matterport-extensions/nest-thermostat/CanvasRenderer.d.ts +37 -37
- package/lib/matterport-extensions/nest-thermostat/NestThermostat.d.ts +42 -42
- package/lib/matterport-extensions/nest-thermostat/PlaneRenderer.d.ts +46 -46
- package/lib/matterport-extensions/scene-component/SceneComponent.d.ts +388 -388
- package/lib/matterport-extensions/security-camera/SecurityCamera.d.ts +47 -47
- package/lib/matterport-extensions/tv-player/TvPlayer.d.ts +26 -26
- package/lib/matterport-extensions/video-renderer/VideoRenderer.d.ts +26 -26
- package/lib/matterport-extensions/view-frustum-mesh/ViewFrustumMesh.d.ts +43 -43
- package/lib/mattertagData.d.ts +70 -70
- package/lib/ngx-smarterplan-core.module.d.ts +29 -29
- package/lib/ngx-smarterplan-core.service.d.ts +6 -6
- package/lib/pipes/duration-to-string.pipe.d.ts +12 -12
- package/lib/pipes/format-date-number-to-digits.pipe.d.ts +10 -10
- package/lib/pipes/hashtag-from-id.pipe.d.ts +10 -10
- package/lib/pipes/safe-url.pipe.d.ts +10 -10
- package/lib/pipes/time-date-to-local-string.pipe.d.ts +16 -16
- package/lib/pipes/username-from-id.pipe.d.ts +11 -11
- package/lib/services/amplify-cache.service.d.ts +37 -37
- package/lib/services/base-tab.service.d.ts +10 -10
- package/lib/services/baseVisibility.service.d.ts +9 -9
- package/lib/services/content.service.d.ts +28 -28
- package/lib/services/filter.service.d.ts +60 -60
- package/lib/services/intervention.service.d.ts +25 -25
- package/lib/services/locale.service.d.ts +23 -23
- package/lib/services/matterport-import.service.d.ts +53 -53
- package/lib/services/matterport.service.d.ts +336 -336
- package/lib/services/models/affectation.service.d.ts +14 -14
- package/lib/services/models/base-object.service.d.ts +20 -20
- package/lib/services/models/capture.service.d.ts +13 -13
- package/lib/services/models/comment.service.d.ts +26 -26
- package/lib/services/models/domain.service.d.ts +19 -19
- package/lib/services/models/equipment.service.d.ts +93 -93
- package/lib/services/models/event.service.d.ts +43 -43
- package/lib/services/models/feature.service.d.ts +75 -75
- package/lib/services/models/hashtag.service.d.ts +13 -13
- package/lib/services/models/layer.service.d.ts +11 -11
- package/lib/services/models/measurement.service.d.ts +51 -51
- package/lib/services/models/mission.service.d.ts +39 -39
- package/lib/services/models/navigation.service.d.ts +29 -29
- package/lib/services/models/node.service.d.ts +12 -12
- package/lib/services/models/object3D.service.d.ts +57 -57
- package/lib/services/models/operation.service.d.ts +15 -15
- package/lib/services/models/organisation.service.d.ts +19 -19
- package/lib/services/models/plan.service.d.ts +133 -133
- package/lib/services/models/poi.service.d.ts +25 -25
- package/lib/services/models/profile.service.d.ts +16 -16
- package/lib/services/models/property.service.d.ts +13 -13
- package/lib/services/models/space.service.d.ts +46 -46
- package/lib/services/models/template.service.d.ts +15 -15
- package/lib/services/models/ticket.service.d.ts +93 -93
- package/lib/services/models/visit.service.d.ts +24 -24
- package/lib/services/models/zone.service.d.ts +50 -50
- package/lib/services/navigator.service.d.ts +61 -61
- package/lib/services/s3.service.d.ts +14 -14
- package/lib/services/search.service.d.ts +20 -20
- package/lib/services/support.service.d.ts +17 -17
- package/lib/services/tag.service.d.ts +29 -29
- package/lib/services/user.service.d.ts +118 -118
- package/lib/services/validators.service.d.ts +18 -18
- package/lib/services/viewer.service.d.ts +110 -110
- package/lib/services/zone-drawer.service.d.ts +7 -7
- package/lib/services/zoneChange.service.d.ts +17 -17
- package/lib/types.service.d.ts +842 -842
- package/lib/validators/email.directive.d.ts +2 -2
- package/lib/validators/no-empty.directive.d.ts +2 -2
- package/lib/validators/number.directive.d.ts +2 -2
- package/lib/validators/text.directive.d.ts +2 -2
- package/package.json +2 -2
- package/public-api.d.ts +64 -64
- package/smarterplan-ngx-smarterplan-core.d.ts +5 -5
|
@@ -1,147 +1,147 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
-
import { NgbDate, } from '@ng-bootstrap/ng-bootstrap';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@ng-bootstrap/ng-bootstrap";
|
|
5
|
-
import * as i2 from "../../../services/filter.service";
|
|
6
|
-
import * as i3 from "../../../services/amplify-cache.service";
|
|
7
|
-
import * as i4 from "@angular/forms";
|
|
8
|
-
import * as i5 from "@angular/common";
|
|
9
|
-
import * as i6 from "../../../pipes/format-date-number-to-digits.pipe";
|
|
10
|
-
import * as i7 from "@ngx-translate/core";
|
|
11
|
-
export class RangeDatePickerComponent {
|
|
12
|
-
constructor(calendar, formatter, filterService, cacheService) {
|
|
13
|
-
this.calendar = calendar;
|
|
14
|
-
this.formatter = formatter;
|
|
15
|
-
this.filterService = filterService;
|
|
16
|
-
this.cacheService = cacheService;
|
|
17
|
-
this.hoveredDate = null;
|
|
18
|
-
this.isDateFilterApplied = false;
|
|
19
|
-
this.dateChanged = false;
|
|
20
|
-
// this.fromDate = calendar.getPrev(calendar.getToday(), "d", 30);
|
|
21
|
-
// this.toDate = calendar.getToday();
|
|
22
|
-
}
|
|
23
|
-
ngOnInit() {
|
|
24
|
-
if (this.cacheName) {
|
|
25
|
-
this.cache = this.cacheService.getFromCache(this.cacheName);
|
|
26
|
-
}
|
|
27
|
-
if (this.cache) {
|
|
28
|
-
this.isDateFilterApplied = true;
|
|
29
|
-
let { from, to } = this.cache;
|
|
30
|
-
this.toDate = this.getNgbDate(to);
|
|
31
|
-
this.fromDate = this.getNgbDate(from);
|
|
32
|
-
localStorage.setItem('startDate', from.toString());
|
|
33
|
-
localStorage.setItem('endDate', to.toString());
|
|
34
|
-
this.filterService.dateFilterUpdated([new Date(from), new Date(to)]);
|
|
35
|
-
}
|
|
36
|
-
else {
|
|
37
|
-
const currentDate = new Date().getTime(); //get current timestamp
|
|
38
|
-
const thirtyDaysAgoDate = currentDate - 30 * 24 * 60 * 60 * 1000; //substract 30 days in miliseconds from the current timestamp
|
|
39
|
-
// add dates to localstorage for retool urlsParams
|
|
40
|
-
localStorage.setItem('startDate', thirtyDaysAgoDate.toString());
|
|
41
|
-
localStorage.setItem('endDate', currentDate.toString());
|
|
42
|
-
// updates date range dates to last 30 days ranges from today
|
|
43
|
-
this.fromDate = this.getNgbDate(thirtyDaysAgoDate);
|
|
44
|
-
this.toDate = this.getNgbDate(currentDate);
|
|
45
|
-
this.filterService.dateFilterUpdated([
|
|
46
|
-
new Date(thirtyDaysAgoDate.toString()),
|
|
47
|
-
new Date(currentDate.toString()),
|
|
48
|
-
]);
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
getNgbDate(date) {
|
|
52
|
-
let dt = new Date(date);
|
|
53
|
-
dt.setMinutes(dt.getMinutes() - dt.getTimezoneOffset()); // convert to UTC
|
|
54
|
-
return new NgbDate(dt.getUTCFullYear(), dt.getUTCMonth() + 1, dt.getUTCDate());
|
|
55
|
-
}
|
|
56
|
-
onDateSelection(date) {
|
|
57
|
-
if (!this.fromDate && !this.toDate) {
|
|
58
|
-
this.fromDate = date;
|
|
59
|
-
}
|
|
60
|
-
else if (this.fromDate &&
|
|
61
|
-
!this.toDate &&
|
|
62
|
-
date &&
|
|
63
|
-
date.after(this.fromDate)) {
|
|
64
|
-
this.toDate = date;
|
|
65
|
-
}
|
|
66
|
-
else {
|
|
67
|
-
this.toDate = null;
|
|
68
|
-
this.fromDate = date;
|
|
69
|
-
}
|
|
70
|
-
this.isDateChanged();
|
|
71
|
-
}
|
|
72
|
-
isDateChanged() {
|
|
73
|
-
if (this.fromDate && this.toDate) {
|
|
74
|
-
if (this.cache) {
|
|
75
|
-
this.dateChanged =
|
|
76
|
-
!this.fromDate.equals(this.getNgbDate(this.cache.from)) ||
|
|
77
|
-
!this.toDate.equals(this.getNgbDate(this.cache.to));
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
isHovered(date) {
|
|
82
|
-
return (this.fromDate &&
|
|
83
|
-
!this.toDate &&
|
|
84
|
-
this.hoveredDate &&
|
|
85
|
-
date.after(this.fromDate) &&
|
|
86
|
-
date.before(this.hoveredDate));
|
|
87
|
-
}
|
|
88
|
-
isInside(date) {
|
|
89
|
-
return this.toDate && date.after(this.fromDate) && date.before(this.toDate);
|
|
90
|
-
}
|
|
91
|
-
isRange(date) {
|
|
92
|
-
return (date.equals(this.fromDate) ||
|
|
93
|
-
(this.toDate && date.equals(this.toDate)) ||
|
|
94
|
-
this.isInside(date) ||
|
|
95
|
-
this.isHovered(date));
|
|
96
|
-
}
|
|
97
|
-
validateInput(currentValue, input) {
|
|
98
|
-
const parsed = this.formatter.parse(input);
|
|
99
|
-
return parsed && this.calendar.isValid(NgbDate.from(parsed))
|
|
100
|
-
? NgbDate.from(parsed)
|
|
101
|
-
: currentValue;
|
|
102
|
-
}
|
|
103
|
-
emitRange() {
|
|
104
|
-
if (this.fromDate && this.toDate) {
|
|
105
|
-
const from = new Date(this.fromDate.year, this.fromDate.month - 1, this.fromDate.day);
|
|
106
|
-
const to = new Date(this.toDate.year, this.toDate.month - 1, this.toDate.day, 23, 59);
|
|
107
|
-
this.cacheService.putInCache(this.cacheName, {
|
|
108
|
-
from: from.getTime(),
|
|
109
|
-
to: to.getTime(),
|
|
110
|
-
});
|
|
111
|
-
this.filterService.dateFilterUpdated([from, to]);
|
|
112
|
-
this.isDateFilterApplied = true;
|
|
113
|
-
this.dateChanged = false;
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
onClearDates() {
|
|
117
|
-
this.fromDate = null;
|
|
118
|
-
this.toDate = null;
|
|
119
|
-
this.isDateFilterApplied = false;
|
|
120
|
-
this.cacheService.removeFromCache(this.cacheName);
|
|
121
|
-
this.filterService.dateFilterUpdated(null);
|
|
122
|
-
}
|
|
123
|
-
onApply() {
|
|
124
|
-
if (this.fromDate && this.toDate) {
|
|
125
|
-
this.emitRange();
|
|
126
|
-
}
|
|
127
|
-
//transform ngbDate to date objet then put dates in timestamp in localStorage to share it with Retool
|
|
128
|
-
if (this.fromDate) {
|
|
129
|
-
const startDate = new Date(this.fromDate.year, this.fromDate.month - 1, this.fromDate.day);
|
|
130
|
-
localStorage.setItem('startDate', startDate.getTime().toString());
|
|
131
|
-
console.log('test setItem from : ' + startDate.getTime().toString());
|
|
132
|
-
}
|
|
133
|
-
if (this.toDate) {
|
|
134
|
-
const endDate = new Date(this.toDate.year, this.toDate.month - 1, this.toDate.day);
|
|
135
|
-
localStorage.setItem('endDate', endDate.getTime().toString());
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
RangeDatePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: RangeDatePickerComponent, deps: [{ token: i1.NgbCalendar }, { token: i1.NgbDateParserFormatter }, { token: i2.FilterService }, { token: i3.AmplifyCacheService }], target: i0.ɵɵFactoryTarget.Component });
|
|
140
|
-
RangeDatePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: RangeDatePickerComponent, selector: "lib-range-date-picker", inputs: { cacheName: "cacheName" }, ngImport: i0, template: "<form class=\"form-inline\">\n <div class=\"mb-3 hidden\">\n <div class=\"input-group\">\n <input name=\"datepicker\" class=\"form-control\" ngbDatepicker #datepicker=\"ngbDatepicker\"\n [autoClose]=\"'outside'\" (dateSelect)=\"onDateSelection($event)\" [displayMonths]=\"2\" [dayTemplate]=\"t\"\n outsideDays=\"hidden\" [startDate]=\"fromDate!\" tabindex=\"-1\">\n <ng-template #t let-date let-focused=\"focused\">\n <span class=\"custom-day\" [class.focused]=\"focused\" [class.range]=\"isRange(date)\"\n [class.faded]=\"isHovered(date) || isInside(date)\" (mouseenter)=\"hoveredDate = date\"\n (mouseleave)=\"hoveredDate = null\">\n {{ date.day }}\n </span>\n </ng-template>\n </div>\n </div>\n <div>\n <div class=\"input-group\">\n <input #dpFromDate class=\"form-control\" placeholder=\"dd/MM/yyyy\" name=\"dpFromDate\"\n [value]=\"fromDate | formatDateNumberToDigits\"\n (input)=\"fromDate = validateInput(fromDate, dpFromDate.value)\">\n <div class=\"input-group-append\">\n <button class=\"btn btn-outline-secondary calendar\" (click)=\"datepicker.toggle()\" type=\"button\"></button>\n </div>\n </div>\n </div>\n <div class=\"mb-3 ms-2\">\n <div class=\"input-group\">\n <input #dpToDate class=\"form-control\" placeholder=\"dd/MM/yyyy\" name=\"dpToDate\"\n [value]=\"toDate | formatDateNumberToDigits\" (input)=\"toDate = validateInput(toDate, dpToDate.value)\">\n <div class=\"input-group-append\">\n <button class=\"btn btn-outline-secondary calendar\" (click)=\"datepicker.toggle()\" type=\"button\"></button>\n </div>\n </div>\n </div>\n <div class=\"confirmation-button\">\n <button class=\"btn btn-outline-primary rounded-pill ms-3\" (click)=\"onApply()\"\n *ngIf=\"!isDateFilterApplied || dateChanged\">\n {{'Apply' | translate}}\n </button>\n <span class=\"appliedText ms-3\" *ngIf=\"isDateFilterApplied && !dateChanged\">\n <span class=\"iconify\" data-icon=\"ion:checkmark\" data-width=\"15\" data-height=\"15\"></span>\n {{\"Applied\" | translate}}\n </span>\n <button class=\"btn btn-outline-primary rounded-pill ms-3\" (click)=\"onClearDates()\">{{'Clear' |\n translate}}</button>\n </div>\n</form
|
|
141
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: RangeDatePickerComponent, decorators: [{
|
|
142
|
-
type: Component,
|
|
143
|
-
args: [{ selector: 'lib-range-date-picker', template: "<form class=\"form-inline\">\n <div class=\"mb-3 hidden\">\n <div class=\"input-group\">\n <input name=\"datepicker\" class=\"form-control\" ngbDatepicker #datepicker=\"ngbDatepicker\"\n [autoClose]=\"'outside'\" (dateSelect)=\"onDateSelection($event)\" [displayMonths]=\"2\" [dayTemplate]=\"t\"\n outsideDays=\"hidden\" [startDate]=\"fromDate!\" tabindex=\"-1\">\n <ng-template #t let-date let-focused=\"focused\">\n <span class=\"custom-day\" [class.focused]=\"focused\" [class.range]=\"isRange(date)\"\n [class.faded]=\"isHovered(date) || isInside(date)\" (mouseenter)=\"hoveredDate = date\"\n (mouseleave)=\"hoveredDate = null\">\n {{ date.day }}\n </span>\n </ng-template>\n </div>\n </div>\n <div>\n <div class=\"input-group\">\n <input #dpFromDate class=\"form-control\" placeholder=\"dd/MM/yyyy\" name=\"dpFromDate\"\n [value]=\"fromDate | formatDateNumberToDigits\"\n (input)=\"fromDate = validateInput(fromDate, dpFromDate.value)\">\n <div class=\"input-group-append\">\n <button class=\"btn btn-outline-secondary calendar\" (click)=\"datepicker.toggle()\" type=\"button\"></button>\n </div>\n </div>\n </div>\n <div class=\"mb-3 ms-2\">\n <div class=\"input-group\">\n <input #dpToDate class=\"form-control\" placeholder=\"dd/MM/yyyy\" name=\"dpToDate\"\n [value]=\"toDate | formatDateNumberToDigits\" (input)=\"toDate = validateInput(toDate, dpToDate.value)\">\n <div class=\"input-group-append\">\n <button class=\"btn btn-outline-secondary calendar\" (click)=\"datepicker.toggle()\" type=\"button\"></button>\n </div>\n </div>\n </div>\n <div class=\"confirmation-button\">\n <button class=\"btn btn-outline-primary rounded-pill ms-3\" (click)=\"onApply()\"\n *ngIf=\"!isDateFilterApplied || dateChanged\">\n {{'Apply' | translate}}\n </button>\n <span class=\"appliedText ms-3\" *ngIf=\"isDateFilterApplied && !dateChanged\">\n <span class=\"iconify\" data-icon=\"ion:checkmark\" data-width=\"15\" data-height=\"15\"></span>\n {{\"Applied\" | translate}}\n </span>\n <button class=\"btn btn-outline-primary rounded-pill ms-3\" (click)=\"onClearDates()\">{{'Clear' |\n translate}}</button>\n </div>\n</form
|
|
144
|
-
}], ctorParameters: function () { return [{ type: i1.NgbCalendar }, { type: i1.NgbDateParserFormatter }, { type: i2.FilterService }, { type: i3.AmplifyCacheService }]; }, propDecorators: { cacheName: [{
|
|
145
|
-
type: Input
|
|
146
|
-
}] } });
|
|
147
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range-date-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-smarterplan-core/src/lib/components/menu-bar/range-date-picker/range-date-picker.component.ts","../../../../../../../projects/ngx-smarterplan-core/src/lib/components/menu-bar/range-date-picker/range-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input } from '@angular/core';\nimport {\n  NgbDate,\n  NgbCalendar,\n  NgbDateParserFormatter,\n} from '@ng-bootstrap/ng-bootstrap';\nimport { AmplifyCacheService } from '../../../services/amplify-cache.service';\nimport { FilterService } from '../../../services/filter.service';\n\n@Component({\n  selector: 'lib-range-date-picker',\n  templateUrl: './range-date-picker.component.html',\n  styleUrls: ['./range-date-picker.component.scss'],\n})\nexport class RangeDatePickerComponent implements OnInit {\n  hoveredDate: NgbDate | null = null;\n\n  fromDate: NgbDate | null;\n\n  toDate: NgbDate | null;\n\n  @Input() cacheName: string | null;\n\n  cache: { from: number; to: number } | null;\n\n  isDateFilterApplied: boolean = false;\n\n  dateChanged: boolean = false;\n\n  constructor(\n    private calendar: NgbCalendar,\n    public formatter: NgbDateParserFormatter,\n    private filterService: FilterService,\n    private cacheService: AmplifyCacheService\n  ) {\n    // this.fromDate = calendar.getPrev(calendar.getToday(), \"d\", 30);\n    // this.toDate = calendar.getToday();\n  }\n\n  ngOnInit(): void {\n    if (this.cacheName) {\n      this.cache = this.cacheService.getFromCache(this.cacheName);\n    }\n    if (this.cache) {\n      this.isDateFilterApplied = true;\n      let { from, to } = this.cache;\n      this.toDate = this.getNgbDate(to);\n      this.fromDate = this.getNgbDate(from);\n\n      localStorage.setItem('startDate', from.toString());\n      localStorage.setItem('endDate', to.toString());\n      this.filterService.dateFilterUpdated([new Date(from), new Date(to)]);\n    } else {\n      const currentDate = new Date().getTime(); //get current timestamp\n      const thirtyDaysAgoDate = currentDate - 30 * 24 * 60 * 60 * 1000; //substract 30 days in miliseconds from the current timestamp\n\n      // add dates to localstorage for retool urlsParams\n      localStorage.setItem('startDate', thirtyDaysAgoDate.toString());\n      localStorage.setItem('endDate', currentDate.toString());\n\n      // updates date range dates to last 30 days ranges from today\n      this.fromDate = this.getNgbDate(thirtyDaysAgoDate);\n      this.toDate = this.getNgbDate(currentDate);\n\n      this.filterService.dateFilterUpdated([\n        new Date(thirtyDaysAgoDate.toString()),\n        new Date(currentDate.toString()),\n      ]);\n    }\n  }\n\n  getNgbDate(date: number): NgbDate {\n    let dt = new Date(date);\n    dt.setMinutes(dt.getMinutes() - dt.getTimezoneOffset()); // convert to UTC\n    return new NgbDate(\n      dt.getUTCFullYear(),\n      dt.getUTCMonth() + 1,\n      dt.getUTCDate()\n    );\n  }\n\n  onDateSelection(date: NgbDate) {\n    if (!this.fromDate && !this.toDate) {\n      this.fromDate = date;\n    } else if (\n      this.fromDate &&\n      !this.toDate &&\n      date &&\n      date.after(this.fromDate)\n    ) {\n      this.toDate = date;\n    } else {\n      this.toDate = null;\n      this.fromDate = date;\n    }\n    this.isDateChanged();\n  }\n\n  isDateChanged() {\n    if (this.fromDate && this.toDate) {\n      if (this.cache) {\n        this.dateChanged =\n          !this.fromDate.equals(this.getNgbDate(this.cache.from)) ||\n          !this.toDate.equals(this.getNgbDate(this.cache.to));\n      }\n    }\n  }\n\n  isHovered(date: NgbDate) {\n    return (\n      this.fromDate &&\n      !this.toDate &&\n      this.hoveredDate &&\n      date.after(this.fromDate) &&\n      date.before(this.hoveredDate)\n    );\n  }\n\n  isInside(date: NgbDate) {\n    return this.toDate && date.after(this.fromDate) && date.before(this.toDate);\n  }\n\n  isRange(date: NgbDate) {\n    return (\n      date.equals(this.fromDate) ||\n      (this.toDate && date.equals(this.toDate)) ||\n      this.isInside(date) ||\n      this.isHovered(date)\n    );\n  }\n\n  validateInput(currentValue: NgbDate | null, input: string): NgbDate | null {\n    const parsed = this.formatter.parse(input);\n    return parsed && this.calendar.isValid(NgbDate.from(parsed))\n      ? NgbDate.from(parsed)\n      : currentValue;\n  }\n\n  emitRange() {\n    if (this.fromDate && this.toDate) {\n      const from = new Date(\n        this.fromDate.year,\n        this.fromDate.month - 1,\n        this.fromDate.day\n      );\n      const to = new Date(\n        this.toDate.year,\n        this.toDate.month - 1,\n        this.toDate.day,\n        23,\n        59\n      );\n      this.cacheService.putInCache(this.cacheName, {\n        from: from.getTime(),\n        to: to.getTime(),\n      });\n      this.filterService.dateFilterUpdated([from, to]);\n      this.isDateFilterApplied = true;\n      this.dateChanged = false;\n    }\n  }\n\n  onClearDates() {\n    this.fromDate = null;\n    this.toDate = null;\n    this.isDateFilterApplied = false;\n    this.cacheService.removeFromCache(this.cacheName);\n    this.filterService.dateFilterUpdated(null);\n  }\n\n  onApply() {\n    if (this.fromDate && this.toDate) {\n      this.emitRange();\n    }\n\n    //transform ngbDate to date objet then put dates in timestamp in localStorage to share it with Retool\n    if (this.fromDate) {\n      const startDate = new Date(\n        this.fromDate.year,\n        this.fromDate.month - 1,\n        this.fromDate.day\n      );\n      localStorage.setItem('startDate', startDate.getTime().toString());\n      console.log('test setItem from : ' + startDate.getTime().toString());\n    }\n    if (this.toDate) {\n      const endDate = new Date(\n        this.toDate.year,\n        this.toDate.month - 1,\n        this.toDate.day\n      );\n      localStorage.setItem('endDate', endDate.getTime().toString());\n    }\n  }\n}\n","<form class=\"form-inline\">\n    <div class=\"mb-3 hidden\">\n        <div class=\"input-group\">\n            <input name=\"datepicker\" class=\"form-control\" ngbDatepicker #datepicker=\"ngbDatepicker\"\n                [autoClose]=\"'outside'\" (dateSelect)=\"onDateSelection($event)\" [displayMonths]=\"2\" [dayTemplate]=\"t\"\n                outsideDays=\"hidden\" [startDate]=\"fromDate!\" tabindex=\"-1\">\n            <ng-template #t let-date let-focused=\"focused\">\n                <span class=\"custom-day\" [class.focused]=\"focused\" [class.range]=\"isRange(date)\"\n                    [class.faded]=\"isHovered(date) || isInside(date)\" (mouseenter)=\"hoveredDate = date\"\n                    (mouseleave)=\"hoveredDate = null\">\n                    {{ date.day }}\n                </span>\n            </ng-template>\n        </div>\n    </div>\n    <div>\n        <div class=\"input-group\">\n            <input #dpFromDate class=\"form-control\" placeholder=\"dd/MM/yyyy\" name=\"dpFromDate\"\n                [value]=\"fromDate | formatDateNumberToDigits\"\n                (input)=\"fromDate = validateInput(fromDate, dpFromDate.value)\">\n            <div class=\"input-group-append\">\n                <button class=\"btn btn-outline-secondary calendar\" (click)=\"datepicker.toggle()\" type=\"button\"></button>\n            </div>\n        </div>\n    </div>\n    <div class=\"mb-3 ms-2\">\n        <div class=\"input-group\">\n            <input #dpToDate class=\"form-control\" placeholder=\"dd/MM/yyyy\" name=\"dpToDate\"\n                [value]=\"toDate | formatDateNumberToDigits\" (input)=\"toDate = validateInput(toDate, dpToDate.value)\">\n            <div class=\"input-group-append\">\n                <button class=\"btn btn-outline-secondary calendar\" (click)=\"datepicker.toggle()\" type=\"button\"></button>\n            </div>\n        </div>\n    </div>\n    <div class=\"confirmation-button\">\n        <button class=\"btn btn-outline-primary rounded-pill ms-3\" (click)=\"onApply()\"\n            *ngIf=\"!isDateFilterApplied || dateChanged\">\n            {{'Apply' | translate}}\n        </button>\n        <span class=\"appliedText ms-3\" *ngIf=\"isDateFilterApplied && !dateChanged\">\n            <span class=\"iconify\" data-icon=\"ion:checkmark\" data-width=\"15\" data-height=\"15\"></span>\n            {{\"Applied\" | translate}}\n        </span>\n        <button class=\"btn btn-outline-primary rounded-pill ms-3\" (click)=\"onClearDates()\">{{'Clear' |\n            translate}}</button>\n    </div>\n</form>"]}
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { NgbDate, } from '@ng-bootstrap/ng-bootstrap';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@ng-bootstrap/ng-bootstrap";
|
|
5
|
+
import * as i2 from "../../../services/filter.service";
|
|
6
|
+
import * as i3 from "../../../services/amplify-cache.service";
|
|
7
|
+
import * as i4 from "@angular/forms";
|
|
8
|
+
import * as i5 from "@angular/common";
|
|
9
|
+
import * as i6 from "../../../pipes/format-date-number-to-digits.pipe";
|
|
10
|
+
import * as i7 from "@ngx-translate/core";
|
|
11
|
+
export class RangeDatePickerComponent {
|
|
12
|
+
constructor(calendar, formatter, filterService, cacheService) {
|
|
13
|
+
this.calendar = calendar;
|
|
14
|
+
this.formatter = formatter;
|
|
15
|
+
this.filterService = filterService;
|
|
16
|
+
this.cacheService = cacheService;
|
|
17
|
+
this.hoveredDate = null;
|
|
18
|
+
this.isDateFilterApplied = false;
|
|
19
|
+
this.dateChanged = false;
|
|
20
|
+
// this.fromDate = calendar.getPrev(calendar.getToday(), "d", 30);
|
|
21
|
+
// this.toDate = calendar.getToday();
|
|
22
|
+
}
|
|
23
|
+
ngOnInit() {
|
|
24
|
+
if (this.cacheName) {
|
|
25
|
+
this.cache = this.cacheService.getFromCache(this.cacheName);
|
|
26
|
+
}
|
|
27
|
+
if (this.cache) {
|
|
28
|
+
this.isDateFilterApplied = true;
|
|
29
|
+
let { from, to } = this.cache;
|
|
30
|
+
this.toDate = this.getNgbDate(to);
|
|
31
|
+
this.fromDate = this.getNgbDate(from);
|
|
32
|
+
localStorage.setItem('startDate', from.toString());
|
|
33
|
+
localStorage.setItem('endDate', to.toString());
|
|
34
|
+
this.filterService.dateFilterUpdated([new Date(from), new Date(to)]);
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
const currentDate = new Date().getTime(); //get current timestamp
|
|
38
|
+
const thirtyDaysAgoDate = currentDate - 30 * 24 * 60 * 60 * 1000; //substract 30 days in miliseconds from the current timestamp
|
|
39
|
+
// add dates to localstorage for retool urlsParams
|
|
40
|
+
localStorage.setItem('startDate', thirtyDaysAgoDate.toString());
|
|
41
|
+
localStorage.setItem('endDate', currentDate.toString());
|
|
42
|
+
// updates date range dates to last 30 days ranges from today
|
|
43
|
+
this.fromDate = this.getNgbDate(thirtyDaysAgoDate);
|
|
44
|
+
this.toDate = this.getNgbDate(currentDate);
|
|
45
|
+
this.filterService.dateFilterUpdated([
|
|
46
|
+
new Date(thirtyDaysAgoDate.toString()),
|
|
47
|
+
new Date(currentDate.toString()),
|
|
48
|
+
]);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
getNgbDate(date) {
|
|
52
|
+
let dt = new Date(date);
|
|
53
|
+
dt.setMinutes(dt.getMinutes() - dt.getTimezoneOffset()); // convert to UTC
|
|
54
|
+
return new NgbDate(dt.getUTCFullYear(), dt.getUTCMonth() + 1, dt.getUTCDate());
|
|
55
|
+
}
|
|
56
|
+
onDateSelection(date) {
|
|
57
|
+
if (!this.fromDate && !this.toDate) {
|
|
58
|
+
this.fromDate = date;
|
|
59
|
+
}
|
|
60
|
+
else if (this.fromDate &&
|
|
61
|
+
!this.toDate &&
|
|
62
|
+
date &&
|
|
63
|
+
date.after(this.fromDate)) {
|
|
64
|
+
this.toDate = date;
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
this.toDate = null;
|
|
68
|
+
this.fromDate = date;
|
|
69
|
+
}
|
|
70
|
+
this.isDateChanged();
|
|
71
|
+
}
|
|
72
|
+
isDateChanged() {
|
|
73
|
+
if (this.fromDate && this.toDate) {
|
|
74
|
+
if (this.cache) {
|
|
75
|
+
this.dateChanged =
|
|
76
|
+
!this.fromDate.equals(this.getNgbDate(this.cache.from)) ||
|
|
77
|
+
!this.toDate.equals(this.getNgbDate(this.cache.to));
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
isHovered(date) {
|
|
82
|
+
return (this.fromDate &&
|
|
83
|
+
!this.toDate &&
|
|
84
|
+
this.hoveredDate &&
|
|
85
|
+
date.after(this.fromDate) &&
|
|
86
|
+
date.before(this.hoveredDate));
|
|
87
|
+
}
|
|
88
|
+
isInside(date) {
|
|
89
|
+
return this.toDate && date.after(this.fromDate) && date.before(this.toDate);
|
|
90
|
+
}
|
|
91
|
+
isRange(date) {
|
|
92
|
+
return (date.equals(this.fromDate) ||
|
|
93
|
+
(this.toDate && date.equals(this.toDate)) ||
|
|
94
|
+
this.isInside(date) ||
|
|
95
|
+
this.isHovered(date));
|
|
96
|
+
}
|
|
97
|
+
validateInput(currentValue, input) {
|
|
98
|
+
const parsed = this.formatter.parse(input);
|
|
99
|
+
return parsed && this.calendar.isValid(NgbDate.from(parsed))
|
|
100
|
+
? NgbDate.from(parsed)
|
|
101
|
+
: currentValue;
|
|
102
|
+
}
|
|
103
|
+
emitRange() {
|
|
104
|
+
if (this.fromDate && this.toDate) {
|
|
105
|
+
const from = new Date(this.fromDate.year, this.fromDate.month - 1, this.fromDate.day);
|
|
106
|
+
const to = new Date(this.toDate.year, this.toDate.month - 1, this.toDate.day, 23, 59);
|
|
107
|
+
this.cacheService.putInCache(this.cacheName, {
|
|
108
|
+
from: from.getTime(),
|
|
109
|
+
to: to.getTime(),
|
|
110
|
+
});
|
|
111
|
+
this.filterService.dateFilterUpdated([from, to]);
|
|
112
|
+
this.isDateFilterApplied = true;
|
|
113
|
+
this.dateChanged = false;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
onClearDates() {
|
|
117
|
+
this.fromDate = null;
|
|
118
|
+
this.toDate = null;
|
|
119
|
+
this.isDateFilterApplied = false;
|
|
120
|
+
this.cacheService.removeFromCache(this.cacheName);
|
|
121
|
+
this.filterService.dateFilterUpdated(null);
|
|
122
|
+
}
|
|
123
|
+
onApply() {
|
|
124
|
+
if (this.fromDate && this.toDate) {
|
|
125
|
+
this.emitRange();
|
|
126
|
+
}
|
|
127
|
+
//transform ngbDate to date objet then put dates in timestamp in localStorage to share it with Retool
|
|
128
|
+
if (this.fromDate) {
|
|
129
|
+
const startDate = new Date(this.fromDate.year, this.fromDate.month - 1, this.fromDate.day);
|
|
130
|
+
localStorage.setItem('startDate', startDate.getTime().toString());
|
|
131
|
+
console.log('test setItem from : ' + startDate.getTime().toString());
|
|
132
|
+
}
|
|
133
|
+
if (this.toDate) {
|
|
134
|
+
const endDate = new Date(this.toDate.year, this.toDate.month - 1, this.toDate.day);
|
|
135
|
+
localStorage.setItem('endDate', endDate.getTime().toString());
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
RangeDatePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: RangeDatePickerComponent, deps: [{ token: i1.NgbCalendar }, { token: i1.NgbDateParserFormatter }, { token: i2.FilterService }, { token: i3.AmplifyCacheService }], target: i0.ɵɵFactoryTarget.Component });
|
|
140
|
+
RangeDatePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: RangeDatePickerComponent, selector: "lib-range-date-picker", inputs: { cacheName: "cacheName" }, ngImport: i0, template: "<form class=\"form-inline\">\r\n <div class=\"mb-3 hidden\">\r\n <div class=\"input-group\">\r\n <input name=\"datepicker\" class=\"form-control\" ngbDatepicker #datepicker=\"ngbDatepicker\"\r\n [autoClose]=\"'outside'\" (dateSelect)=\"onDateSelection($event)\" [displayMonths]=\"2\" [dayTemplate]=\"t\"\r\n outsideDays=\"hidden\" [startDate]=\"fromDate!\" tabindex=\"-1\">\r\n <ng-template #t let-date let-focused=\"focused\">\r\n <span class=\"custom-day\" [class.focused]=\"focused\" [class.range]=\"isRange(date)\"\r\n [class.faded]=\"isHovered(date) || isInside(date)\" (mouseenter)=\"hoveredDate = date\"\r\n (mouseleave)=\"hoveredDate = null\">\r\n {{ date.day }}\r\n </span>\r\n </ng-template>\r\n </div>\r\n </div>\r\n <div>\r\n <div class=\"input-group\">\r\n <input #dpFromDate class=\"form-control\" placeholder=\"dd/MM/yyyy\" name=\"dpFromDate\"\r\n [value]=\"fromDate | formatDateNumberToDigits\"\r\n (input)=\"fromDate = validateInput(fromDate, dpFromDate.value)\">\r\n <div class=\"input-group-append\">\r\n <button class=\"btn btn-outline-secondary calendar\" (click)=\"datepicker.toggle()\" type=\"button\"></button>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"mb-3 ms-0 ms-md-2\">\r\n <div class=\"input-group\">\r\n <input #dpToDate class=\"form-control\" placeholder=\"dd/MM/yyyy\" name=\"dpToDate\"\r\n [value]=\"toDate | formatDateNumberToDigits\" (input)=\"toDate = validateInput(toDate, dpToDate.value)\">\r\n <div class=\"input-group-append\">\r\n <button class=\"btn btn-outline-secondary calendar\" (click)=\"datepicker.toggle()\" type=\"button\"></button>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"confirmation-button\">\r\n <button class=\"btn btn-outline-primary rounded-pill ms-3\" (click)=\"onApply()\"\r\n *ngIf=\"!isDateFilterApplied || dateChanged\">\r\n {{'Apply' | translate}}\r\n </button>\r\n <span class=\"appliedText ms-3\" *ngIf=\"isDateFilterApplied && !dateChanged\">\r\n <span class=\"iconify\" data-icon=\"ion:checkmark\" data-width=\"15\" data-height=\"15\"></span>\r\n {{\"Applied\" | translate}}\r\n </span>\r\n <button class=\"btn btn-outline-primary rounded-pill ms-3\" (click)=\"onClearDates()\">{{'Clear' |\r\n translate}}</button>\r\n </div>\r\n</form>\r\n", styles: [".mb-3.hidden{width:0;margin:0;border:none;padding:0}.custom-day{text-align:center;padding:.185rem .25rem;display:inline-block;height:2rem;width:2rem}.custom-day.focused{background-color:#e6e6e6}.custom-day.range,.custom-day:hover{background-color:var(--smarterplan-primary-lighter);color:#fff}.custom-day.faded{background-color:var(--smarterplan-primary-transparent)}.calendar{height:100%}.appliedText,.appliedText span{color:var(--smarterplan-primary)}@media (max-width: 767px){.form-inline{flex-direction:column}.mb-3{margin-bottom:15px}}.mb-3.hidden{opacity:0}.confirmation-button{display:flex;padding:.5rem}\n"], directives: [{ type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i4.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i1.NgbInputDatepicker, selector: "input[ngbDatepicker]", inputs: ["autoClose", "datepickerClass", "dayTemplate", "dayTemplateData", "displayMonths", "firstDayOfWeek", "footerTemplate", "markDisabled", "minDate", "maxDate", "navigation", "outsideDays", "placement", "restoreFocus", "showWeekNumbers", "startDate", "container", "positionTarget", "weekdays", "disabled"], outputs: ["dateSelect", "navigate", "closed"], exportAs: ["ngbDatepicker"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "formatDateNumberToDigits": i6.FormatDateNumberToDigitsPipe, "translate": i7.TranslatePipe } });
|
|
141
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: RangeDatePickerComponent, decorators: [{
|
|
142
|
+
type: Component,
|
|
143
|
+
args: [{ selector: 'lib-range-date-picker', template: "<form class=\"form-inline\">\r\n <div class=\"mb-3 hidden\">\r\n <div class=\"input-group\">\r\n <input name=\"datepicker\" class=\"form-control\" ngbDatepicker #datepicker=\"ngbDatepicker\"\r\n [autoClose]=\"'outside'\" (dateSelect)=\"onDateSelection($event)\" [displayMonths]=\"2\" [dayTemplate]=\"t\"\r\n outsideDays=\"hidden\" [startDate]=\"fromDate!\" tabindex=\"-1\">\r\n <ng-template #t let-date let-focused=\"focused\">\r\n <span class=\"custom-day\" [class.focused]=\"focused\" [class.range]=\"isRange(date)\"\r\n [class.faded]=\"isHovered(date) || isInside(date)\" (mouseenter)=\"hoveredDate = date\"\r\n (mouseleave)=\"hoveredDate = null\">\r\n {{ date.day }}\r\n </span>\r\n </ng-template>\r\n </div>\r\n </div>\r\n <div>\r\n <div class=\"input-group\">\r\n <input #dpFromDate class=\"form-control\" placeholder=\"dd/MM/yyyy\" name=\"dpFromDate\"\r\n [value]=\"fromDate | formatDateNumberToDigits\"\r\n (input)=\"fromDate = validateInput(fromDate, dpFromDate.value)\">\r\n <div class=\"input-group-append\">\r\n <button class=\"btn btn-outline-secondary calendar\" (click)=\"datepicker.toggle()\" type=\"button\"></button>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"mb-3 ms-0 ms-md-2\">\r\n <div class=\"input-group\">\r\n <input #dpToDate class=\"form-control\" placeholder=\"dd/MM/yyyy\" name=\"dpToDate\"\r\n [value]=\"toDate | formatDateNumberToDigits\" (input)=\"toDate = validateInput(toDate, dpToDate.value)\">\r\n <div class=\"input-group-append\">\r\n <button class=\"btn btn-outline-secondary calendar\" (click)=\"datepicker.toggle()\" type=\"button\"></button>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"confirmation-button\">\r\n <button class=\"btn btn-outline-primary rounded-pill ms-3\" (click)=\"onApply()\"\r\n *ngIf=\"!isDateFilterApplied || dateChanged\">\r\n {{'Apply' | translate}}\r\n </button>\r\n <span class=\"appliedText ms-3\" *ngIf=\"isDateFilterApplied && !dateChanged\">\r\n <span class=\"iconify\" data-icon=\"ion:checkmark\" data-width=\"15\" data-height=\"15\"></span>\r\n {{\"Applied\" | translate}}\r\n </span>\r\n <button class=\"btn btn-outline-primary rounded-pill ms-3\" (click)=\"onClearDates()\">{{'Clear' |\r\n translate}}</button>\r\n </div>\r\n</form>\r\n", styles: [".mb-3.hidden{width:0;margin:0;border:none;padding:0}.custom-day{text-align:center;padding:.185rem .25rem;display:inline-block;height:2rem;width:2rem}.custom-day.focused{background-color:#e6e6e6}.custom-day.range,.custom-day:hover{background-color:var(--smarterplan-primary-lighter);color:#fff}.custom-day.faded{background-color:var(--smarterplan-primary-transparent)}.calendar{height:100%}.appliedText,.appliedText span{color:var(--smarterplan-primary)}@media (max-width: 767px){.form-inline{flex-direction:column}.mb-3{margin-bottom:15px}}.mb-3.hidden{opacity:0}.confirmation-button{display:flex;padding:.5rem}\n"] }]
|
|
144
|
+
}], ctorParameters: function () { return [{ type: i1.NgbCalendar }, { type: i1.NgbDateParserFormatter }, { type: i2.FilterService }, { type: i3.AmplifyCacheService }]; }, propDecorators: { cacheName: [{
|
|
145
|
+
type: Input
|
|
146
|
+
}] } });
|
|
147
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range-date-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-smarterplan-core/src/lib/components/menu-bar/range-date-picker/range-date-picker.component.ts","../../../../../../../projects/ngx-smarterplan-core/src/lib/components/menu-bar/range-date-picker/range-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input } from '@angular/core';\r\nimport {\r\n  NgbDate,\r\n  NgbCalendar,\r\n  NgbDateParserFormatter,\r\n} from '@ng-bootstrap/ng-bootstrap';\r\nimport { AmplifyCacheService } from '../../../services/amplify-cache.service';\r\nimport { FilterService } from '../../../services/filter.service';\r\n\r\n@Component({\r\n  selector: 'lib-range-date-picker',\r\n  templateUrl: './range-date-picker.component.html',\r\n  styleUrls: ['./range-date-picker.component.scss'],\r\n})\r\nexport class RangeDatePickerComponent implements OnInit {\r\n  hoveredDate: NgbDate | null = null;\r\n\r\n  fromDate: NgbDate | null;\r\n\r\n  toDate: NgbDate | null;\r\n\r\n  @Input() cacheName: string | null;\r\n\r\n  cache: { from: number; to: number } | null;\r\n\r\n  isDateFilterApplied: boolean = false;\r\n\r\n  dateChanged: boolean = false;\r\n\r\n  constructor(\r\n    private calendar: NgbCalendar,\r\n    public formatter: NgbDateParserFormatter,\r\n    private filterService: FilterService,\r\n    private cacheService: AmplifyCacheService\r\n  ) {\r\n    // this.fromDate = calendar.getPrev(calendar.getToday(), \"d\", 30);\r\n    // this.toDate = calendar.getToday();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (this.cacheName) {\r\n      this.cache = this.cacheService.getFromCache(this.cacheName);\r\n    }\r\n    if (this.cache) {\r\n      this.isDateFilterApplied = true;\r\n      let { from, to } = this.cache;\r\n      this.toDate = this.getNgbDate(to);\r\n      this.fromDate = this.getNgbDate(from);\r\n\r\n      localStorage.setItem('startDate', from.toString());\r\n      localStorage.setItem('endDate', to.toString());\r\n      this.filterService.dateFilterUpdated([new Date(from), new Date(to)]);\r\n    } else {\r\n      const currentDate = new Date().getTime(); //get current timestamp\r\n      const thirtyDaysAgoDate = currentDate - 30 * 24 * 60 * 60 * 1000; //substract 30 days in miliseconds from the current timestamp\r\n\r\n      // add dates to localstorage for retool urlsParams\r\n      localStorage.setItem('startDate', thirtyDaysAgoDate.toString());\r\n      localStorage.setItem('endDate', currentDate.toString());\r\n\r\n      // updates date range dates to last 30 days ranges from today\r\n      this.fromDate = this.getNgbDate(thirtyDaysAgoDate);\r\n      this.toDate = this.getNgbDate(currentDate);\r\n\r\n      this.filterService.dateFilterUpdated([\r\n        new Date(thirtyDaysAgoDate.toString()),\r\n        new Date(currentDate.toString()),\r\n      ]);\r\n    }\r\n  }\r\n\r\n  getNgbDate(date: number): NgbDate {\r\n    let dt = new Date(date);\r\n    dt.setMinutes(dt.getMinutes() - dt.getTimezoneOffset()); // convert to UTC\r\n    return new NgbDate(\r\n      dt.getUTCFullYear(),\r\n      dt.getUTCMonth() + 1,\r\n      dt.getUTCDate()\r\n    );\r\n  }\r\n\r\n  onDateSelection(date: NgbDate) {\r\n    if (!this.fromDate && !this.toDate) {\r\n      this.fromDate = date;\r\n    } else if (\r\n      this.fromDate &&\r\n      !this.toDate &&\r\n      date &&\r\n      date.after(this.fromDate)\r\n    ) {\r\n      this.toDate = date;\r\n    } else {\r\n      this.toDate = null;\r\n      this.fromDate = date;\r\n    }\r\n    this.isDateChanged();\r\n  }\r\n\r\n  isDateChanged() {\r\n    if (this.fromDate && this.toDate) {\r\n      if (this.cache) {\r\n        this.dateChanged =\r\n          !this.fromDate.equals(this.getNgbDate(this.cache.from)) ||\r\n          !this.toDate.equals(this.getNgbDate(this.cache.to));\r\n      }\r\n    }\r\n  }\r\n\r\n  isHovered(date: NgbDate) {\r\n    return (\r\n      this.fromDate &&\r\n      !this.toDate &&\r\n      this.hoveredDate &&\r\n      date.after(this.fromDate) &&\r\n      date.before(this.hoveredDate)\r\n    );\r\n  }\r\n\r\n  isInside(date: NgbDate) {\r\n    return this.toDate && date.after(this.fromDate) && date.before(this.toDate);\r\n  }\r\n\r\n  isRange(date: NgbDate) {\r\n    return (\r\n      date.equals(this.fromDate) ||\r\n      (this.toDate && date.equals(this.toDate)) ||\r\n      this.isInside(date) ||\r\n      this.isHovered(date)\r\n    );\r\n  }\r\n\r\n  validateInput(currentValue: NgbDate | null, input: string): NgbDate | null {\r\n    const parsed = this.formatter.parse(input);\r\n    return parsed && this.calendar.isValid(NgbDate.from(parsed))\r\n      ? NgbDate.from(parsed)\r\n      : currentValue;\r\n  }\r\n\r\n  emitRange() {\r\n    if (this.fromDate && this.toDate) {\r\n      const from = new Date(\r\n        this.fromDate.year,\r\n        this.fromDate.month - 1,\r\n        this.fromDate.day\r\n      );\r\n      const to = new Date(\r\n        this.toDate.year,\r\n        this.toDate.month - 1,\r\n        this.toDate.day,\r\n        23,\r\n        59\r\n      );\r\n      this.cacheService.putInCache(this.cacheName, {\r\n        from: from.getTime(),\r\n        to: to.getTime(),\r\n      });\r\n      this.filterService.dateFilterUpdated([from, to]);\r\n      this.isDateFilterApplied = true;\r\n      this.dateChanged = false;\r\n    }\r\n  }\r\n\r\n  onClearDates() {\r\n    this.fromDate = null;\r\n    this.toDate = null;\r\n    this.isDateFilterApplied = false;\r\n    this.cacheService.removeFromCache(this.cacheName);\r\n    this.filterService.dateFilterUpdated(null);\r\n  }\r\n\r\n  onApply() {\r\n    if (this.fromDate && this.toDate) {\r\n      this.emitRange();\r\n    }\r\n\r\n    //transform ngbDate to date objet then put dates in timestamp in localStorage to share it with Retool\r\n    if (this.fromDate) {\r\n      const startDate = new Date(\r\n        this.fromDate.year,\r\n        this.fromDate.month - 1,\r\n        this.fromDate.day\r\n      );\r\n      localStorage.setItem('startDate', startDate.getTime().toString());\r\n      console.log('test setItem from : ' + startDate.getTime().toString());\r\n    }\r\n    if (this.toDate) {\r\n      const endDate = new Date(\r\n        this.toDate.year,\r\n        this.toDate.month - 1,\r\n        this.toDate.day\r\n      );\r\n      localStorage.setItem('endDate', endDate.getTime().toString());\r\n    }\r\n  }\r\n}\r\n","<form class=\"form-inline\">\r\n    <div class=\"mb-3 hidden\">\r\n        <div class=\"input-group\">\r\n            <input name=\"datepicker\" class=\"form-control\" ngbDatepicker #datepicker=\"ngbDatepicker\"\r\n                [autoClose]=\"'outside'\" (dateSelect)=\"onDateSelection($event)\" [displayMonths]=\"2\" [dayTemplate]=\"t\"\r\n                outsideDays=\"hidden\" [startDate]=\"fromDate!\" tabindex=\"-1\">\r\n            <ng-template #t let-date let-focused=\"focused\">\r\n                <span class=\"custom-day\" [class.focused]=\"focused\" [class.range]=\"isRange(date)\"\r\n                    [class.faded]=\"isHovered(date) || isInside(date)\" (mouseenter)=\"hoveredDate = date\"\r\n                    (mouseleave)=\"hoveredDate = null\">\r\n                    {{ date.day }}\r\n                </span>\r\n            </ng-template>\r\n        </div>\r\n    </div>\r\n    <div>\r\n        <div class=\"input-group\">\r\n            <input #dpFromDate class=\"form-control\" placeholder=\"dd/MM/yyyy\" name=\"dpFromDate\"\r\n                [value]=\"fromDate | formatDateNumberToDigits\"\r\n                (input)=\"fromDate = validateInput(fromDate, dpFromDate.value)\">\r\n            <div class=\"input-group-append\">\r\n                <button class=\"btn btn-outline-secondary calendar\" (click)=\"datepicker.toggle()\" type=\"button\"></button>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div class=\"mb-3 ms-0 ms-md-2\">\r\n        <div class=\"input-group\">\r\n            <input #dpToDate class=\"form-control\" placeholder=\"dd/MM/yyyy\" name=\"dpToDate\"\r\n                [value]=\"toDate | formatDateNumberToDigits\" (input)=\"toDate = validateInput(toDate, dpToDate.value)\">\r\n            <div class=\"input-group-append\">\r\n                <button class=\"btn btn-outline-secondary calendar\" (click)=\"datepicker.toggle()\" type=\"button\"></button>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div class=\"confirmation-button\">\r\n        <button class=\"btn btn-outline-primary rounded-pill ms-3\" (click)=\"onApply()\"\r\n            *ngIf=\"!isDateFilterApplied || dateChanged\">\r\n            {{'Apply' | translate}}\r\n        </button>\r\n        <span class=\"appliedText ms-3\" *ngIf=\"isDateFilterApplied && !dateChanged\">\r\n            <span class=\"iconify\" data-icon=\"ion:checkmark\" data-width=\"15\" data-height=\"15\"></span>\r\n            {{\"Applied\" | translate}}\r\n        </span>\r\n        <button class=\"btn btn-outline-primary rounded-pill ms-3\" (click)=\"onClearDates()\">{{'Clear' |\r\n            translate}}</button>\r\n    </div>\r\n</form>\r\n"]}
|
|
@@ -1,40 +1,40 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "@ng-bootstrap/ng-bootstrap";
|
|
4
|
-
import * as i2 from "@angular/router";
|
|
5
|
-
import * as i3 from "../../services/viewer.service";
|
|
6
|
-
import * as i4 from "@ngx-translate/core";
|
|
7
|
-
export class ModalSwitchVisitComponent {
|
|
8
|
-
constructor(activeModal, router, viewerService) {
|
|
9
|
-
this.activeModal = activeModal;
|
|
10
|
-
this.router = router;
|
|
11
|
-
this.viewerService = viewerService;
|
|
12
|
-
}
|
|
13
|
-
ngOnInit() { }
|
|
14
|
-
switchVisit() {
|
|
15
|
-
this.activeModal.close();
|
|
16
|
-
if (this.dataToMove) {
|
|
17
|
-
this.viewerService.setSweepToMove(this.dataToMove.sweepToMove);
|
|
18
|
-
this.viewerService.setRotationToMove(this.dataToMove.rotation);
|
|
19
|
-
}
|
|
20
|
-
// this.objectSubService.forceRemove = true; // we reset the tags when changing visit
|
|
21
|
-
this.router.navigate(["visit", this.spaceID], {
|
|
22
|
-
queryParams: { model3D: this.model3D },
|
|
23
|
-
});
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
ModalSwitchVisitComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: ModalSwitchVisitComponent, deps: [{ token: i1.NgbActiveModal }, { token: i2.Router }, { token: i3.ViewerService }], target: i0.ɵɵFactoryTarget.Component });
|
|
27
|
-
ModalSwitchVisitComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: ModalSwitchVisitComponent, selector: "lib-modal-switch-visit", inputs: { content: "content", model3D: "model3D", spaceID: "spaceID", dataToMove: "dataToMove" }, ngImport: i0, template: "<div class=\"modal-container\">\n <p>{{content}}</p>\n <button class=\"btn btn-outline-primary rounded-pill\" (click)=\"switchVisit()\">{{'Yes, switch visit' | translate }}</button>\n <button class=\"btn btn-outline-primary rounded-pill\"(click)=\"activeModal.close()\">{{'No, stay here' | translate }}</button>\n</div>\n", styles: [".modal-container{margin:10px}button{margin-right:8px}\n"], pipes: { "translate": i4.TranslatePipe } });
|
|
28
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: ModalSwitchVisitComponent, decorators: [{
|
|
29
|
-
type: Component,
|
|
30
|
-
args: [{ selector: 'lib-modal-switch-visit', template: "<div class=\"modal-container\">\n <p>{{content}}</p>\n <button class=\"btn btn-outline-primary rounded-pill\" (click)=\"switchVisit()\">{{'Yes, switch visit' | translate }}</button>\n <button class=\"btn btn-outline-primary rounded-pill\"(click)=\"activeModal.close()\">{{'No, stay here' | translate }}</button>\n</div>\n", styles: [".modal-container{margin:10px}button{margin-right:8px}\n"] }]
|
|
31
|
-
}], ctorParameters: function () { return [{ type: i1.NgbActiveModal }, { type: i2.Router }, { type: i3.ViewerService }]; }, propDecorators: { content: [{
|
|
32
|
-
type: Input
|
|
33
|
-
}], model3D: [{
|
|
34
|
-
type: Input
|
|
35
|
-
}], spaceID: [{
|
|
36
|
-
type: Input
|
|
37
|
-
}], dataToMove: [{
|
|
38
|
-
type: Input
|
|
39
|
-
}] } });
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@ng-bootstrap/ng-bootstrap";
|
|
4
|
+
import * as i2 from "@angular/router";
|
|
5
|
+
import * as i3 from "../../services/viewer.service";
|
|
6
|
+
import * as i4 from "@ngx-translate/core";
|
|
7
|
+
export class ModalSwitchVisitComponent {
|
|
8
|
+
constructor(activeModal, router, viewerService) {
|
|
9
|
+
this.activeModal = activeModal;
|
|
10
|
+
this.router = router;
|
|
11
|
+
this.viewerService = viewerService;
|
|
12
|
+
}
|
|
13
|
+
ngOnInit() { }
|
|
14
|
+
switchVisit() {
|
|
15
|
+
this.activeModal.close();
|
|
16
|
+
if (this.dataToMove) {
|
|
17
|
+
this.viewerService.setSweepToMove(this.dataToMove.sweepToMove);
|
|
18
|
+
this.viewerService.setRotationToMove(this.dataToMove.rotation);
|
|
19
|
+
}
|
|
20
|
+
// this.objectSubService.forceRemove = true; // we reset the tags when changing visit
|
|
21
|
+
this.router.navigate(["visit", this.spaceID], {
|
|
22
|
+
queryParams: { model3D: this.model3D },
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
ModalSwitchVisitComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: ModalSwitchVisitComponent, deps: [{ token: i1.NgbActiveModal }, { token: i2.Router }, { token: i3.ViewerService }], target: i0.ɵɵFactoryTarget.Component });
|
|
27
|
+
ModalSwitchVisitComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: ModalSwitchVisitComponent, selector: "lib-modal-switch-visit", inputs: { content: "content", model3D: "model3D", spaceID: "spaceID", dataToMove: "dataToMove" }, ngImport: i0, template: "<div class=\"modal-container\">\r\n <p>{{content}}</p>\r\n <button class=\"btn btn-outline-primary rounded-pill\" (click)=\"switchVisit()\">{{'Yes, switch visit' | translate }}</button>\r\n <button class=\"btn btn-outline-primary rounded-pill\"(click)=\"activeModal.close()\">{{'No, stay here' | translate }}</button>\r\n</div>\r\n", styles: [".modal-container{margin:10px}button{margin-right:8px}\n"], pipes: { "translate": i4.TranslatePipe } });
|
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: ModalSwitchVisitComponent, decorators: [{
|
|
29
|
+
type: Component,
|
|
30
|
+
args: [{ selector: 'lib-modal-switch-visit', template: "<div class=\"modal-container\">\r\n <p>{{content}}</p>\r\n <button class=\"btn btn-outline-primary rounded-pill\" (click)=\"switchVisit()\">{{'Yes, switch visit' | translate }}</button>\r\n <button class=\"btn btn-outline-primary rounded-pill\"(click)=\"activeModal.close()\">{{'No, stay here' | translate }}</button>\r\n</div>\r\n", styles: [".modal-container{margin:10px}button{margin-right:8px}\n"] }]
|
|
31
|
+
}], ctorParameters: function () { return [{ type: i1.NgbActiveModal }, { type: i2.Router }, { type: i3.ViewerService }]; }, propDecorators: { content: [{
|
|
32
|
+
type: Input
|
|
33
|
+
}], model3D: [{
|
|
34
|
+
type: Input
|
|
35
|
+
}], spaceID: [{
|
|
36
|
+
type: Input
|
|
37
|
+
}], dataToMove: [{
|
|
38
|
+
type: Input
|
|
39
|
+
}] } });
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtc3dpdGNoLXZpc2l0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1zbWFydGVycGxhbi1jb3JlL3NyYy9saWIvY29tcG9uZW50cy9tb2RhbC1zd2l0Y2gtdmlzaXQvbW9kYWwtc3dpdGNoLXZpc2l0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1zbWFydGVycGxhbi1jb3JlL3NyYy9saWIvY29tcG9uZW50cy9tb2RhbC1zd2l0Y2gtdmlzaXQvbW9kYWwtc3dpdGNoLXZpc2l0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDOzs7Ozs7QUFVekQsTUFBTSxPQUFPLHlCQUF5QjtJQUtsQyxZQUFtQixXQUEyQixFQUFVLE1BQWMsRUFBVSxhQUE0QjtRQUF6RixnQkFBVyxHQUFYLFdBQVcsQ0FBZ0I7UUFBVSxXQUFNLEdBQU4sTUFBTSxDQUFRO1FBQVUsa0JBQWEsR0FBYixhQUFhLENBQWU7SUFFeEcsQ0FBQztJQUVMLFFBQVEsS0FBVyxDQUFDO0lBRXBCLFdBQVc7UUFDUCxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ3pCLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRTtZQUNqQixJQUFJLENBQUMsYUFBYSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQy9ELElBQUksQ0FBQyxhQUFhLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQztTQUNsRTtRQUNELHFGQUFxRjtRQUNyRixJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLEVBQUU7WUFDMUMsV0FBVyxFQUFFLEVBQUUsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUU7U0FDekMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQzs7c0hBckJRLHlCQUF5QjswR0FBekIseUJBQXlCLGdLQ1Z0QyxzVkFLQTsyRkRLYSx5QkFBeUI7a0JBTHJDLFNBQVM7K0JBQ0ksd0JBQXdCO3NKQUt6QixPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XHJcbmltcG9ydCB7IE5nYkFjdGl2ZU1vZGFsIH0gZnJvbSAnQG5nLWJvb3RzdHJhcC9uZy1ib290c3RyYXAnO1xyXG5pbXBvcnQgeyBWaWV3ZXJTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvdmlld2VyLnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2xpYi1tb2RhbC1zd2l0Y2gtdmlzaXQnLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL21vZGFsLXN3aXRjaC12aXNpdC5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBzdHlsZVVybHM6IFsnLi9tb2RhbC1zd2l0Y2gtdmlzaXQuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTW9kYWxTd2l0Y2hWaXNpdENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgICBASW5wdXQoKSBjb250ZW50OiBzdHJpbmc7XHJcbiAgICBASW5wdXQoKSBtb2RlbDNEOiBzdHJpbmc7XHJcbiAgICBASW5wdXQoKSBzcGFjZUlEOiBzdHJpbmc7XHJcbiAgICBASW5wdXQoKSBkYXRhVG9Nb3ZlOiB7IHN3ZWVwVG9Nb3ZlOiBzdHJpbmcsIHJvdGF0aW9uOiBhbnk7IH07XHJcbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgYWN0aXZlTW9kYWw6IE5nYkFjdGl2ZU1vZGFsLCBwcml2YXRlIHJvdXRlcjogUm91dGVyLCBwcml2YXRlIHZpZXdlclNlcnZpY2U6IFZpZXdlclNlcnZpY2UsXHJcbiAgICAgICAgLy8gcHJpdmF0ZSBvYmplY3RTdWJTZXJ2aWNlOiBPYmplY3RTdWJzY3JpcHRpb25TZXJ2aWNlXHJcbiAgICApIHsgfVxyXG5cclxuICAgIG5nT25Jbml0KCk6IHZvaWQgeyB9XHJcblxyXG4gICAgc3dpdGNoVmlzaXQoKSB7XHJcbiAgICAgICAgdGhpcy5hY3RpdmVNb2RhbC5jbG9zZSgpO1xyXG4gICAgICAgIGlmICh0aGlzLmRhdGFUb01vdmUpIHtcclxuICAgICAgICAgICAgdGhpcy52aWV3ZXJTZXJ2aWNlLnNldFN3ZWVwVG9Nb3ZlKHRoaXMuZGF0YVRvTW92ZS5zd2VlcFRvTW92ZSk7XHJcbiAgICAgICAgICAgIHRoaXMudmlld2VyU2VydmljZS5zZXRSb3RhdGlvblRvTW92ZSh0aGlzLmRhdGFUb01vdmUucm90YXRpb24pO1xyXG4gICAgICAgIH1cclxuICAgICAgICAvLyB0aGlzLm9iamVjdFN1YlNlcnZpY2UuZm9yY2VSZW1vdmUgPSB0cnVlOyAvLyB3ZSByZXNldCB0aGUgdGFncyB3aGVuIGNoYW5naW5nIHZpc2l0XHJcbiAgICAgICAgdGhpcy5yb3V0ZXIubmF2aWdhdGUoW1widmlzaXRcIiwgdGhpcy5zcGFjZUlEXSwge1xyXG4gICAgICAgICAgICBxdWVyeVBhcmFtczogeyBtb2RlbDNEOiB0aGlzLm1vZGVsM0QgfSxcclxuICAgICAgICB9KTtcclxuICAgIH1cclxuXHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cIm1vZGFsLWNvbnRhaW5lclwiPlxyXG4gICAgPHA+e3tjb250ZW50fX08L3A+XHJcbiAgICA8YnV0dG9uIGNsYXNzPVwiYnRuIGJ0bi1vdXRsaW5lLXByaW1hcnkgcm91bmRlZC1waWxsXCIgKGNsaWNrKT1cInN3aXRjaFZpc2l0KClcIj57eydZZXMsIHN3aXRjaCB2aXNpdCcgfCB0cmFuc2xhdGUgfX08L2J1dHRvbj5cclxuICAgIDxidXR0b24gY2xhc3M9XCJidG4gYnRuLW91dGxpbmUtcHJpbWFyeSByb3VuZGVkLXBpbGxcIihjbGljayk9XCJhY3RpdmVNb2RhbC5jbG9zZSgpXCI+e3snTm8sIHN0YXkgaGVyZScgfCB0cmFuc2xhdGUgfX08L2J1dHRvbj5cclxuPC9kaXY+XHJcbiJdfQ==
|