@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,384 +1,384 @@
|
|
|
1
|
-
import { Component, Inject, ViewChild } from '@angular/core';
|
|
2
|
-
import { Subject, takeUntil } from 'rxjs';
|
|
3
|
-
import { waitUntil } from '../../../helpers.service';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "@angular/router";
|
|
6
|
-
import * as i2 from "../../../services/models/space.service";
|
|
7
|
-
import * as i3 from "../../../services/user.service";
|
|
8
|
-
import * as i4 from "../../../services/models/zone.service";
|
|
9
|
-
import * as i5 from "../../../services/models/visit.service";
|
|
10
|
-
import * as i6 from "../../../services/viewer.service";
|
|
11
|
-
import * as i7 from "../../../services/navigator.service";
|
|
12
|
-
import * as i8 from "../../../services/zoneChange.service";
|
|
13
|
-
import * as i9 from "@ng-bootstrap/ng-bootstrap";
|
|
14
|
-
import * as i10 from "@angular/forms";
|
|
15
|
-
import * as i11 from "@angular/common";
|
|
16
|
-
import * as i12 from "@ngx-translate/core";
|
|
17
|
-
export class NavigationBarComponent {
|
|
18
|
-
constructor(awsKinesisAnalyticsInjected, router, spaceService, userService, zoneService, visitService, viewerService, navigatorService, zoneChangeService) {
|
|
19
|
-
this.router = router;
|
|
20
|
-
this.spaceService = spaceService;
|
|
21
|
-
this.userService = userService;
|
|
22
|
-
this.zoneService = zoneService;
|
|
23
|
-
this.visitService = visitService;
|
|
24
|
-
this.viewerService = viewerService;
|
|
25
|
-
this.navigatorService = navigatorService;
|
|
26
|
-
this.zoneChangeService = zoneChangeService;
|
|
27
|
-
this.selectedLocation = null;
|
|
28
|
-
this.selectedFloor = null;
|
|
29
|
-
this.selectedZone = null;
|
|
30
|
-
this.selectedChildZone = null;
|
|
31
|
-
this.visitsPerSpace = null;
|
|
32
|
-
this.floorsPerSpace = null;
|
|
33
|
-
this.zonesPerSpace = null;
|
|
34
|
-
this.zonesPerFloor = null;
|
|
35
|
-
this.childrenZones = null;
|
|
36
|
-
this.destroy$ = new Subject();
|
|
37
|
-
this.awsKinesisAnalytics = awsKinesisAnalyticsInjected;
|
|
38
|
-
this.spaceService.locationUpdated
|
|
39
|
-
.pipe(takeUntil(this.destroy$))
|
|
40
|
-
.subscribe((locs) => {
|
|
41
|
-
this.locations = locs;
|
|
42
|
-
if (this.selectedLocation) {
|
|
43
|
-
this.selectedLocation = this.findLocationByID(this.selectedLocation.id); // Update Object (object address will change);
|
|
44
|
-
}
|
|
45
|
-
});
|
|
46
|
-
this.viewerService.viewerIsOn
|
|
47
|
-
.pipe(takeUntil(this.destroy$))
|
|
48
|
-
.subscribe((data) => {
|
|
49
|
-
// console.log('menu navigation received update', data);
|
|
50
|
-
this.currentLocationID = data.spaceID;
|
|
51
|
-
this.currentModel3d = data.model3D;
|
|
52
|
-
if (!data.spaceID) {
|
|
53
|
-
this.selectedLocation = null;
|
|
54
|
-
localStorage.removeItem('locationId');
|
|
55
|
-
this.sendUpdateLocationEvent();
|
|
56
|
-
return;
|
|
57
|
-
}
|
|
58
|
-
if ((!this.selectedLocation ||
|
|
59
|
-
this.selectedLocation.id !== data.spaceID) &&
|
|
60
|
-
this.locations) {
|
|
61
|
-
this.selectedLocation = this.findLocationByID(data.spaceID);
|
|
62
|
-
this.sendUpdateLocationEvent();
|
|
63
|
-
}
|
|
64
|
-
});
|
|
65
|
-
/**
|
|
66
|
-
* We listen for Location change event
|
|
67
|
-
*/
|
|
68
|
-
this.navigatorService.locationIDChange
|
|
69
|
-
.pipe(takeUntil(this.destroy$))
|
|
70
|
-
.subscribe((id) => {
|
|
71
|
-
this.clearData();
|
|
72
|
-
this.currentLocationID = id;
|
|
73
|
-
this.selectedLocation = this.findLocationByID(id);
|
|
74
|
-
this.navigatorService.currentNavBarLocationID = id;
|
|
75
|
-
this.onSelectedLocationChanged().catch((e) => console.log(e.message));
|
|
76
|
-
});
|
|
77
|
-
this.zoneChangeService.zonesForUserChange
|
|
78
|
-
.pipe(takeUntil(this.destroy$))
|
|
79
|
-
.subscribe(async (zones) => {
|
|
80
|
-
if (zones) {
|
|
81
|
-
await waitUntil(() => this.floorsPerSpace !== null);
|
|
82
|
-
const floorZone = zones.find((zone) => zone.layer && zone.layer.name === 'FLOOR');
|
|
83
|
-
if (floorZone) {
|
|
84
|
-
this.selectedFloor = this.floorsPerSpace.find((f) => f.id === floorZone.id);
|
|
85
|
-
// Emit event to dispatch value of this.selectedFloor in all poi/ticket/equipment/measure services
|
|
86
|
-
this.zoneChangeService.floorHasChanged.emit(this.selectedFloor);
|
|
87
|
-
this.onFloorClick(false).catch((e) => console.log(e.message));
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
});
|
|
91
|
-
}
|
|
92
|
-
async ngOnInit() {
|
|
93
|
-
await this.initLocations();
|
|
94
|
-
this.handleStartUrl();
|
|
95
|
-
}
|
|
96
|
-
ngOnDestroy() {
|
|
97
|
-
this.destroy$.next(true);
|
|
98
|
-
this.destroy$.complete();
|
|
99
|
-
}
|
|
100
|
-
// Capture the "id" in localisation/:id routes
|
|
101
|
-
handleStartUrl() {
|
|
102
|
-
if (this.router.url.includes('localisation/')) {
|
|
103
|
-
const paths = this.router.url.split('/'); // /dashboard/localisation/fc0aadb7-3c89-4349-ad1f-bfe9b44916c0
|
|
104
|
-
// eslint-disable-next-line prefer-destructuring
|
|
105
|
-
const locID = paths[3];
|
|
106
|
-
if (this.currentLocationID !== locID) {
|
|
107
|
-
this.clearData();
|
|
108
|
-
this.currentLocationID = locID;
|
|
109
|
-
this.selectedLocation = this.findLocationByID(locID);
|
|
110
|
-
this.navigatorService.currentNavBarLocationID = locID;
|
|
111
|
-
this.onSelectedLocationChanged().catch((e) => console.log(e.message));
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
async initLocations() {
|
|
116
|
-
this.locations = this.spaceService.locationsForUser;
|
|
117
|
-
if (this.locations.length === 0) {
|
|
118
|
-
this.locations = await this.spaceService.getLocationsForCurrentUser();
|
|
119
|
-
}
|
|
120
|
-
if (this.currentLocationID && this.locations.length > 0) {
|
|
121
|
-
this.selectedLocation = this.findLocationByID(this.currentLocationID);
|
|
122
|
-
if (this.selectedLocation) {
|
|
123
|
-
this.sendUpdateLocationEvent();
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
/**
|
|
128
|
-
* Find a location with a given ID
|
|
129
|
-
* @param id ID for the location
|
|
130
|
-
* @returns The location or null if no location were found
|
|
131
|
-
*/
|
|
132
|
-
findLocationByID(id) {
|
|
133
|
-
const space = this.locations.find((loc) => loc.id === id);
|
|
134
|
-
return space || null; /** Convert to null if undefined */
|
|
135
|
-
}
|
|
136
|
-
clearData(clearVisits = true) {
|
|
137
|
-
this.floorsPerSpace = null;
|
|
138
|
-
this.selectedFloor = null;
|
|
139
|
-
this.zonesPerFloor = null;
|
|
140
|
-
this.childrenZones = null;
|
|
141
|
-
this.selectedModel3d = null;
|
|
142
|
-
this.sweepToGo = null;
|
|
143
|
-
this.floorToGo = null;
|
|
144
|
-
this.selectedZone = null;
|
|
145
|
-
this.selectedChildZone = null;
|
|
146
|
-
if (clearVisits) {
|
|
147
|
-
this.visitsPerSpace = null;
|
|
148
|
-
this.zonesPerSpace = null;
|
|
149
|
-
}
|
|
150
|
-
localStorage.removeItem('locationId');
|
|
151
|
-
localStorage.removeItem('floorId');
|
|
152
|
-
localStorage.removeItem('zoneId');
|
|
153
|
-
localStorage.removeItem('childZoneId');
|
|
154
|
-
}
|
|
155
|
-
/**
|
|
156
|
-
* When the selectedLocation changes
|
|
157
|
-
* Send a event to locationIDChange from NavigatorService
|
|
158
|
-
* The event will be catch by this component and the filter bar will be update
|
|
159
|
-
*/
|
|
160
|
-
sendUpdateLocationEvent() {
|
|
161
|
-
const locationID = this.selectedLocation ? this.selectedLocation.id : null;
|
|
162
|
-
this.navigatorService.locationIDChange.next(locationID);
|
|
163
|
-
if (this.selectedLocation) {
|
|
164
|
-
localStorage.setItem('locationId', this.selectedLocation.id);
|
|
165
|
-
}
|
|
166
|
-
else {
|
|
167
|
-
localStorage.removeItem('locationId');
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
async onSelectedLocationChanged() {
|
|
171
|
-
if (!this.selectedLocation) {
|
|
172
|
-
return;
|
|
173
|
-
}
|
|
174
|
-
try {
|
|
175
|
-
this.visitsPerSpace = await this.visitService.getVisitsForSpaceForUser(this.selectedLocation.id);
|
|
176
|
-
this.zonesPerSpace = await this.zoneService.getZonesBySpaceForUser(this.selectedLocation.id);
|
|
177
|
-
if (this.visitsPerSpace.length === 1) {
|
|
178
|
-
this.selectedModel3d = this.visitsPerSpace[0].model3d;
|
|
179
|
-
this.floorsPerSpace = this.zonesPerSpace.filter((zone) => zone.layer && zone.layer.name.includes('FLOOR'));
|
|
180
|
-
// sort from highest floor to lowest
|
|
181
|
-
this.floorsPerSpace.sort((a, b) => {
|
|
182
|
-
if (a.metadata && b.metadata) {
|
|
183
|
-
const metadataA = JSON.parse(a.metadata);
|
|
184
|
-
const metadataB = JSON.parse(b.metadata);
|
|
185
|
-
return (metadataB.matterportFloorSequence -
|
|
186
|
-
metadataA.matterportFloorSequence);
|
|
187
|
-
}
|
|
188
|
-
return a.name.localeCompare(b.name);
|
|
189
|
-
});
|
|
190
|
-
const multiFloorZones = this.zonesPerSpace.filter((zone) => zone.isMultipleFloorZone);
|
|
191
|
-
// sort alphabetically
|
|
192
|
-
multiFloorZones.sort((a, b) => a.name.localeCompare(b.name));
|
|
193
|
-
// merge multiFloor and Floors
|
|
194
|
-
this.floorsPerSpace = [...this.floorsPerSpace, ...multiFloorZones];
|
|
195
|
-
if (this.floorsPerSpace.length === 1) {
|
|
196
|
-
[this.selectedFloor] = this.floorsPerSpace;
|
|
197
|
-
this.onFloorClick(false).catch((e) => console.log(e.message));
|
|
198
|
-
}
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
catch (error) {
|
|
202
|
-
console.log('error onChosenLocation', error);
|
|
203
|
-
}
|
|
204
|
-
}
|
|
205
|
-
onLocationClick() {
|
|
206
|
-
this.clearData();
|
|
207
|
-
this.sendUpdateLocationEvent();
|
|
208
|
-
}
|
|
209
|
-
async onFloorClick(emitEvent = true) {
|
|
210
|
-
if (this.selectedFloor) {
|
|
211
|
-
localStorage.setItem('floorId', this.selectedFloor.id);
|
|
212
|
-
}
|
|
213
|
-
else {
|
|
214
|
-
localStorage.removeItem('floorId');
|
|
215
|
-
}
|
|
216
|
-
if (this.selectedFloor && this.selectedFloor.isMultipleFloorZone) {
|
|
217
|
-
this.selectedZone = this.selectedFloor;
|
|
218
|
-
this.onZoneClick().catch((e) => console.log(e.message));
|
|
219
|
-
return;
|
|
220
|
-
}
|
|
221
|
-
else {
|
|
222
|
-
this.onZoneClick().catch((e) => console.log(e.message));
|
|
223
|
-
}
|
|
224
|
-
this.sweepToGo = null;
|
|
225
|
-
this.selectedZone = null;
|
|
226
|
-
this.selectedChildZone = null;
|
|
227
|
-
localStorage.removeItem('zoneId');
|
|
228
|
-
localStorage.removeItem('childZoneId');
|
|
229
|
-
if (this.selectedFloor === null) {
|
|
230
|
-
this.navigatorService.navBarZoneIDChange.next(null);
|
|
231
|
-
this.navigatorService.currentNavBarZoneID = null;
|
|
232
|
-
return;
|
|
233
|
-
}
|
|
234
|
-
if (emitEvent) {
|
|
235
|
-
this.navigatorService.navBarZoneIDChange.next(this.selectedFloor.id);
|
|
236
|
-
}
|
|
237
|
-
this.navigatorService.currentNavBarZoneID = this.selectedFloor.id;
|
|
238
|
-
await waitUntil(() => this.zonesPerSpace !== null && this.zonesPerSpace !== undefined);
|
|
239
|
-
this.zonesPerFloor = this.zonesPerSpace.filter((zone) =>
|
|
240
|
-
// zone.id === this.selectedFloor.id ||
|
|
241
|
-
zone.parentID === this.selectedFloor.id);
|
|
242
|
-
this.zonesPerFloor.sort((a, b) => {
|
|
243
|
-
const Collator = new Intl.Collator(undefined, {
|
|
244
|
-
numeric: true,
|
|
245
|
-
sensitivity: 'accent',
|
|
246
|
-
});
|
|
247
|
-
return (Collator.compare(a.code_ref, b.code_ref) ||
|
|
248
|
-
Collator.compare(a.name, b.name));
|
|
249
|
-
});
|
|
250
|
-
}
|
|
251
|
-
async onZoneClick() {
|
|
252
|
-
this.selectedChildZone = null;
|
|
253
|
-
localStorage.removeItem('childZoneId');
|
|
254
|
-
if (this.selectedZone) {
|
|
255
|
-
localStorage.setItem('zoneId', this.selectedZone.id);
|
|
256
|
-
}
|
|
257
|
-
else {
|
|
258
|
-
localStorage.removeItem('zoneId');
|
|
259
|
-
}
|
|
260
|
-
if (this.selectedZone === null) {
|
|
261
|
-
if (this.selectedFloor === null) {
|
|
262
|
-
this.navigatorService.navBarZoneIDChange.next(null);
|
|
263
|
-
this.navigatorService.currentNavBarZoneID = null;
|
|
264
|
-
}
|
|
265
|
-
else {
|
|
266
|
-
this.navigatorService.navBarZoneIDChange.next(this.selectedFloor.id);
|
|
267
|
-
this.navigatorService.currentNavBarZoneID = this.selectedFloor.id;
|
|
268
|
-
}
|
|
269
|
-
this.sendKinesisAnalyticsEventForZone(this.selectedZone?.id, this.selectedZone?.name).catch((e) => console.log(e.message));
|
|
270
|
-
return;
|
|
271
|
-
}
|
|
272
|
-
this.childrenZones = this.zonesPerSpace.filter((zone) => zone.parentID === this.selectedZone.id);
|
|
273
|
-
this.navigatorService.navBarZoneIDChange.next(this.selectedZone.id);
|
|
274
|
-
this.navigatorService.currentNavBarZoneID = this.selectedZone.id;
|
|
275
|
-
this.sendKinesisAnalyticsEventForZone(this.selectedZone?.id, this.selectedZone?.name).catch((e) => console.log(e.message));
|
|
276
|
-
}
|
|
277
|
-
onChildZoneClick() {
|
|
278
|
-
if (this.selectedChildZone) {
|
|
279
|
-
localStorage.setItem('childZoneId', this.selectedChildZone?.id);
|
|
280
|
-
}
|
|
281
|
-
else {
|
|
282
|
-
localStorage.removeItem('childZoneId');
|
|
283
|
-
}
|
|
284
|
-
}
|
|
285
|
-
async sendKinesisAnalyticsEventForZone(zoneId, zoneName) {
|
|
286
|
-
if (!!this.awsKinesisAnalytics && !!this.awsKinesisAnalytics.record && this.awsKinesisAnalytics.record()) {
|
|
287
|
-
this.awsKinesisAnalytics.getInstance().record(
|
|
288
|
-
// @ts-ignore
|
|
289
|
-
{
|
|
290
|
-
data: {
|
|
291
|
-
eventType: 'Zone Change',
|
|
292
|
-
zoneId: zoneId,
|
|
293
|
-
zoneName: zoneName,
|
|
294
|
-
locationId: this.selectedLocation?.id,
|
|
295
|
-
locationName: this.selectedLocation?.name,
|
|
296
|
-
user: this.userService?.cu,
|
|
297
|
-
timestamp: new Date(),
|
|
298
|
-
floorId: this.selectedFloor?.id,
|
|
299
|
-
childZoneId: this.selectedChildZone?.id,
|
|
300
|
-
},
|
|
301
|
-
streamName: 'smarterplanKinesis-analytics',
|
|
302
|
-
// partitionKey: "",
|
|
303
|
-
}, 'AWSKinesis');
|
|
304
|
-
}
|
|
305
|
-
}
|
|
306
|
-
async onVisitClick(event) {
|
|
307
|
-
this.clearData(false);
|
|
308
|
-
const index = event.target.value;
|
|
309
|
-
const visit = this.visitsPerSpace[index];
|
|
310
|
-
this.selectedModel3d = visit.model3d;
|
|
311
|
-
const parentZoneForVisit = await this.visitService.getDefaultZoneForVisit(visit);
|
|
312
|
-
this.floorsPerSpace = this.zonesPerSpace.filter((zone) => zone.layer &&
|
|
313
|
-
zone.layer.name.includes('FLOOR') &&
|
|
314
|
-
zone.parentID === parentZoneForVisit.id);
|
|
315
|
-
}
|
|
316
|
-
async goTo() {
|
|
317
|
-
if (this.selectedZone && !this.selectedZone.virtual) {
|
|
318
|
-
this.sweepToGo = this.selectedZone.startSweepID
|
|
319
|
-
? this.selectedZone.startSweepID
|
|
320
|
-
: this.selectedZone.sweepIDs[0];
|
|
321
|
-
}
|
|
322
|
-
if (this.selectedFloor && !this.selectedZone) {
|
|
323
|
-
this.floorToGo = this.selectedFloor;
|
|
324
|
-
}
|
|
325
|
-
if (this.isWithinSameVisit()) {
|
|
326
|
-
this.goToSweepOrFloor();
|
|
327
|
-
}
|
|
328
|
-
else {
|
|
329
|
-
if (this.sweepToGo) {
|
|
330
|
-
this.viewerService.setSweepToMove(this.sweepToGo);
|
|
331
|
-
}
|
|
332
|
-
if (this.floorToGo && this.floorsPerSpace.length !== 1) {
|
|
333
|
-
this.navigatorService.floorToGo = this.floorToGo;
|
|
334
|
-
}
|
|
335
|
-
this.router
|
|
336
|
-
.navigate(['visit', this.selectedLocation.id], {
|
|
337
|
-
queryParams: { model3D: this.selectedModel3d },
|
|
338
|
-
})
|
|
339
|
-
.catch((e) => console.log(e.message));
|
|
340
|
-
}
|
|
341
|
-
}
|
|
342
|
-
isWithinSameVisit() {
|
|
343
|
-
return (this.currentLocationID === this.selectedLocation.id &&
|
|
344
|
-
this.selectedModel3d === this.currentModel3d);
|
|
345
|
-
}
|
|
346
|
-
goToSweepOrFloor() {
|
|
347
|
-
if (this.sweepToGo) {
|
|
348
|
-
this.navigatorService.goToSweepWithRotation(this.sweepToGo);
|
|
349
|
-
}
|
|
350
|
-
if (this.floorToGo) {
|
|
351
|
-
this.navigatorService.goToFloor(this.floorToGo);
|
|
352
|
-
}
|
|
353
|
-
}
|
|
354
|
-
// hasHistory(): boolean {
|
|
355
|
-
// return this.navigatorService.modelHasHistory(this.selectedModel3d);
|
|
356
|
-
// }
|
|
357
|
-
canGo() {
|
|
358
|
-
const viewerIsReady = this.viewerService.isLoaded && this.viewerService.showingViewer;
|
|
359
|
-
const noViewer = !this.viewerService.showingViewer;
|
|
360
|
-
return viewerIsReady || noViewer;
|
|
361
|
-
}
|
|
362
|
-
showLocation() {
|
|
363
|
-
if (window.innerWidth < 750 &&
|
|
364
|
-
this.navbarSelectMenu &&
|
|
365
|
-
this.navbarSelectMenu.nativeElement.className.search('show') === -1 &&
|
|
366
|
-
this.selectedLocation) {
|
|
367
|
-
return this.selectedLocation.name;
|
|
368
|
-
}
|
|
369
|
-
return '';
|
|
370
|
-
}
|
|
371
|
-
}
|
|
372
|
-
NavigationBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: NavigationBarComponent, deps: [{ token: 'currentAwsKinesisAnalyticsService' }, { token: i1.Router }, { token: i2.SpaceService }, { token: i3.BaseUserService }, { token: i4.ZoneService }, { token: i5.VisitService }, { token: i6.ViewerService }, { token: i7.NavigatorService }, { token: i8.ZoneChangeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
373
|
-
NavigationBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: NavigationBarComponent, selector: "lib-navigation-bar", viewQueries: [{ propertyName: "navbarSelectMenu", first: true, predicate: ["navbarSelectMenu"], descendants: true }], ngImport: i0, template: "<nav class=\"navbar navbar-expand-md navbar-dark navbar-inverse second-nav\">\n <div class=\"d-flex col-12\">\n <div #navbarSelectMenu class=\"collapse navbar-collapse\" id=\"nav-item-container-blue\">\n <div class=\"d-flex flex-column flex-md-row \">\n <select class=\"form-control flex-fill location select-menu\" [(ngModel)]=\"selectedLocation\"\n (ngModelChange)=\"onLocationClick()\">\n <option [ngValue]=\"null\" selected>{{ 'Location' | translate }}</option>\n <option *ngFor=\"let loc of locations; index as index\" [ngValue]=\"loc\"> {{ loc.name }}</option>\n </select>\n <select class=\"form-control flex-fill select-menu\" (change)=\"onVisitClick($event)\"\n *ngIf=\"visitsPerSpace && visitsPerSpace.length > 1\">\n <option value=\"default\" selected disabled hidden>{{'Visit' | translate}}</option>\n <option *ngFor=\"let visit of visitsPerSpace; index as index\" value=\"{{index}}\">{{ visit.name}}\n </option>\n </select>\n <select class=\"form-control flex-fill floor select-menu\" [(ngModel)]=\"selectedFloor\"\n (ngModelChange)=\"onFloorClick()\">\n <option [ngValue]=\"null\" selected>{{'Floor' | translate}}</option>\n <option *ngFor=\"let floor of floorsPerSpace\" [ngValue]=\"floor\">{{ floor.name}}</option>\n </select>\n <select class=\"form-control flex-fill select-menu zone\" [(ngModel)]=\"selectedZone\"\n (ngModelChange)=\"onZoneClick()\">\n <option [ngValue]=\"null\" selected>{{'Zone' | translate}}</option>\n <option *ngFor=\"let zone of zonesPerFloor\" [ngValue]=\"zone\"><span\n *ngIf=\"zone.code_ref\">{{zone.code_ref}}_</span>{{zone.name}}</option>\n </select>\n <select class=\"form-control flex-fill select-menu\" [(ngModel)]=\"selectedChildZone\"\n *ngIf=\"childrenZones && childrenZones.length>0\" (ngModelChange)=\"onChildZoneClick()\">\n <option [ngValue]=\"null\" selected disabled>{{'Zone' | translate}}</option>\n <option *ngFor=\"let zone of childrenZones\" [ngValue]=\"zone\">{{ zone.name}}</option>\n </select>\n <!-- <select class=\"form-control flex-fill\">\n <option i18n>{{'Favorites' | translate}}</option>\n </select> -->\n </div>\n <div class=\"row\" style=\"margin-left: 0;\">\n <div class=\"outer_circle\">\n <button id='btn-icon' [disabled]=\"!selectedLocation || !selectedModel3d || !canGo()\"\n (click)=\"goTo()\"></button>\n </div>\n <button (click)=\"goTo()\" class=\"btn rounded-pill btn-3d\"\n [disabled]=\"!selectedLocation || !selectedModel3d || !canGo()\">{{'3D visit' | translate}}</button>\n </div>\n </div>\n\n <h4 style=\"line-height: 29px;margin: 0;\" *ngIf=\"showLocation()\">\n {{ showLocation() }}\n </h4>\n </div>\n</nav>", styles: [":host{position:sticky;top:0;height:123px}.navbar{z-index:200;padding:.4rem 1rem}.navbar.second-nav{z-index:199;background-color:var(--smarterplan-primary)}input,select{margin-right:15px}.select{background:transparent;border:none;color:#fff;margin:6px 20px 0}.form-control{width:auto;min-width:80px;max-width:18%}.location{width:auto;max-width:35%}.floor,.zone{width:auto;max-width:30%}button{color:#fff;padding:5px 10px;font-size:1.1em}.btn-3d:active:hover:not([disabled]){color:var(--smarterplan-secondary)}.btn-3d[disabled]:hover{color:#fff}.navbar-toggler{margin-right:1em}.select-menu{max-width:inherit}#btn-icon{width:30px;height:30px;background:url(../../../../../assets/icons/goTo3d.svg);border:none;vertical-align:middle}#btn-icon:hover{background:url(../../../../../assets/icons/goTo3d-over.svg)}#btn-icon[disabled]:hover{background:url(../../../../../assets/icons/goTo3d.svg)}.outer_circle{background-color:#ebebeb;border-radius:50%;width:32px;height:32px;padding:1px}@media (max-width: 767px){.navbar{padding:.2rem .5rem}.form-control,.location,.floor,.zone{max-width:100%;margin-bottom:15px}input,select{margin-right:0;margin-bottom:15px}#btn-icon{width:20px;height:20px}}\n"], directives: [{ type: i9.NgbNavbar, selector: ".navbar" }, { type: i10.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { type: i10.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i10.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i10.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i10.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i11.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i11.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i12.TranslatePipe } });
|
|
374
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: NavigationBarComponent, decorators: [{
|
|
375
|
-
type: Component,
|
|
376
|
-
args: [{ selector: 'lib-navigation-bar', template: "<nav class=\"navbar navbar-expand-md navbar-dark navbar-inverse second-nav\">\n <div class=\"d-flex col-12\">\n <div #navbarSelectMenu class=\"collapse navbar-collapse\" id=\"nav-item-container-blue\">\n <div class=\"d-flex flex-column flex-md-row \">\n <select class=\"form-control flex-fill location select-menu\" [(ngModel)]=\"selectedLocation\"\n (ngModelChange)=\"onLocationClick()\">\n <option [ngValue]=\"null\" selected>{{ 'Location' | translate }}</option>\n <option *ngFor=\"let loc of locations; index as index\" [ngValue]=\"loc\"> {{ loc.name }}</option>\n </select>\n <select class=\"form-control flex-fill select-menu\" (change)=\"onVisitClick($event)\"\n *ngIf=\"visitsPerSpace && visitsPerSpace.length > 1\">\n <option value=\"default\" selected disabled hidden>{{'Visit' | translate}}</option>\n <option *ngFor=\"let visit of visitsPerSpace; index as index\" value=\"{{index}}\">{{ visit.name}}\n </option>\n </select>\n <select class=\"form-control flex-fill floor select-menu\" [(ngModel)]=\"selectedFloor\"\n (ngModelChange)=\"onFloorClick()\">\n <option [ngValue]=\"null\" selected>{{'Floor' | translate}}</option>\n <option *ngFor=\"let floor of floorsPerSpace\" [ngValue]=\"floor\">{{ floor.name}}</option>\n </select>\n <select class=\"form-control flex-fill select-menu zone\" [(ngModel)]=\"selectedZone\"\n (ngModelChange)=\"onZoneClick()\">\n <option [ngValue]=\"null\" selected>{{'Zone' | translate}}</option>\n <option *ngFor=\"let zone of zonesPerFloor\" [ngValue]=\"zone\"><span\n *ngIf=\"zone.code_ref\">{{zone.code_ref}}_</span>{{zone.name}}</option>\n </select>\n <select class=\"form-control flex-fill select-menu\" [(ngModel)]=\"selectedChildZone\"\n *ngIf=\"childrenZones && childrenZones.length>0\" (ngModelChange)=\"onChildZoneClick()\">\n <option [ngValue]=\"null\" selected disabled>{{'Zone' | translate}}</option>\n <option *ngFor=\"let zone of childrenZones\" [ngValue]=\"zone\">{{ zone.name}}</option>\n </select>\n <!-- <select class=\"form-control flex-fill\">\n <option i18n>{{'Favorites' | translate}}</option>\n </select> -->\n </div>\n <div class=\"row\" style=\"margin-left: 0;\">\n <div class=\"outer_circle\">\n <button id='btn-icon' [disabled]=\"!selectedLocation || !selectedModel3d || !canGo()\"\n (click)=\"goTo()\"></button>\n </div>\n <button (click)=\"goTo()\" class=\"btn rounded-pill btn-3d\"\n [disabled]=\"!selectedLocation || !selectedModel3d || !canGo()\">{{'3D visit' | translate}}</button>\n </div>\n </div>\n\n <h4 style=\"line-height: 29px;margin: 0;\" *ngIf=\"showLocation()\">\n {{ showLocation() }}\n </h4>\n </div>\n</nav>", styles: [":host{position:sticky;top:0;height:123px}.navbar{z-index:200;padding:.4rem 1rem}.navbar.second-nav{z-index:199;background-color:var(--smarterplan-primary)}input,select{margin-right:15px}.select{background:transparent;border:none;color:#fff;margin:6px 20px 0}.form-control{width:auto;min-width:80px;max-width:18%}.location{width:auto;max-width:35%}.floor,.zone{width:auto;max-width:30%}button{color:#fff;padding:5px 10px;font-size:1.1em}.btn-3d:active:hover:not([disabled]){color:var(--smarterplan-secondary)}.btn-3d[disabled]:hover{color:#fff}.navbar-toggler{margin-right:1em}.select-menu{max-width:inherit}#btn-icon{width:30px;height:30px;background:url(../../../../../assets/icons/goTo3d.svg);border:none;vertical-align:middle}#btn-icon:hover{background:url(../../../../../assets/icons/goTo3d-over.svg)}#btn-icon[disabled]:hover{background:url(../../../../../assets/icons/goTo3d.svg)}.outer_circle{background-color:#ebebeb;border-radius:50%;width:32px;height:32px;padding:1px}@media (max-width: 767px){.navbar{padding:.2rem .5rem}.form-control,.location,.floor,.zone{max-width:100%;margin-bottom:15px}input,select{margin-right:0;margin-bottom:15px}#btn-icon{width:20px;height:20px}}\n"] }]
|
|
377
|
-
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
378
|
-
type: Inject,
|
|
379
|
-
args: ['currentAwsKinesisAnalyticsService']
|
|
380
|
-
}] }, { type: i1.Router }, { type: i2.SpaceService }, { type: i3.BaseUserService }, { type: i4.ZoneService }, { type: i5.VisitService }, { type: i6.ViewerService }, { type: i7.NavigatorService }, { type: i8.ZoneChangeService }]; }, propDecorators: { navbarSelectMenu: [{
|
|
381
|
-
type: ViewChild,
|
|
382
|
-
args: ['navbarSelectMenu']
|
|
383
|
-
}] } });
|
|
384
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation-bar.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-smarterplan-core/src/lib/components/menu-bar/navigation-bar/navigation-bar.component.ts","../../../../../../../projects/ngx-smarterplan-core/src/lib/components/menu-bar/navigation-bar/navigation-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, OnInit, ViewChild } from '@angular/core';\nimport { NavigationEnd, Router } from '@angular/router';\nimport { Observable, Subject, takeUntil } from 'rxjs';\nimport { waitUntil } from '../../../helpers.service';\nimport { SpaceService } from '../../../services/models/space.service';\nimport { VisitService } from '../../../services/models/visit.service';\nimport { ZoneService } from '../../../services/models/zone.service';\nimport { NavigatorService } from '../../../services/navigator.service';\nimport { ViewerService } from '../../../services/viewer.service';\nimport { Space, Visit, Zone } from '../../../types.service';\nimport { BaseUserService } from '../../../services/user.service';\nimport {ZoneChangeService} from \"../../../services/zoneChange.service\";\n\n@Component({\n  selector: 'lib-navigation-bar',\n  templateUrl: './navigation-bar.component.html',\n  styleUrls: ['./navigation-bar.component.scss'],\n})\nexport class NavigationBarComponent implements OnInit {\n  awsKinesisAnalytics: any; //AWS\n\n  @ViewChild('navbarSelectMenu') navbarSelectMenu!: any;\n\n  locations: Space[];\n\n  currentLocationID: string;\n\n  currentModel3d: string;\n\n  selectedLocation: Space = null;\n\n  selectedModel3d: string;\n\n  selectedFloor: Zone = null;\n\n  selectedZone: Zone = null;\n\n  selectedChildZone: Zone = null;\n\n  visitsPerSpace: Visit[] = null;\n\n  floorsPerSpace: Zone[] = null;\n\n  zonesPerSpace: Zone[] = null;\n\n  zonesPerFloor: Zone[] = null;\n\n  childrenZones: Zone[] = null;\n\n  sweepToGo: string;\n\n  floorToGo: Zone;\n\n  destroy$ = new Subject();\n\n  navEvents: Observable<NavigationEnd>;\n\n  constructor(\n    @Inject('currentAwsKinesisAnalyticsService')\n    awsKinesisAnalyticsInjected: any,\n    private router: Router,\n    private spaceService: SpaceService,\n    private userService: BaseUserService,\n    private zoneService: ZoneService,\n    private visitService: VisitService,\n    private viewerService: ViewerService,\n    private navigatorService: NavigatorService,\n    private zoneChangeService: ZoneChangeService\n  ) {\n    this.awsKinesisAnalytics = awsKinesisAnalyticsInjected;\n    this.spaceService.locationUpdated\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((locs) => {\n        this.locations = locs;\n        if (this.selectedLocation) {\n          this.selectedLocation = this.findLocationByID(\n            this.selectedLocation.id\n          ); // Update Object (object address will change);\n        }\n      });\n    this.viewerService.viewerIsOn\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(\n        (data: { spaceID: string; model3D: string; sweep: string | null }) => {\n          // console.log('menu navigation received update', data);\n          this.currentLocationID = data.spaceID;\n          this.currentModel3d = data.model3D;\n          if (!data.spaceID) {\n            this.selectedLocation = null;\n            localStorage.removeItem('locationId');\n            this.sendUpdateLocationEvent();\n            return;\n          }\n          if (\n            (!this.selectedLocation ||\n              this.selectedLocation.id !== data.spaceID) &&\n            this.locations\n          ) {\n            this.selectedLocation = this.findLocationByID(data.spaceID);\n            this.sendUpdateLocationEvent();\n          }\n        }\n      );\n\n    /**\n     * We listen for Location change event\n     */\n    this.navigatorService.locationIDChange\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((id: string) => {\n        this.clearData();\n        this.currentLocationID = id;\n        this.selectedLocation = this.findLocationByID(id);\n        this.navigatorService.currentNavBarLocationID = id;\n        this.onSelectedLocationChanged().catch((e) => console.log(e.message));\n      });\n\n    this.zoneChangeService.zonesForUserChange\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(async (zones) => {\n        if (zones) {\n          await waitUntil(() => this.floorsPerSpace !== null);\n          const floorZone = zones.find(\n            (zone) => zone.layer && zone.layer.name === 'FLOOR'\n          );\n          if (floorZone) {\n            this.selectedFloor = this.floorsPerSpace.find(\n              (f) => f.id === floorZone.id\n            );\n            // Emit event to dispatch value of  this.selectedFloor in all poi/ticket/equipment/measure services\n            this.zoneChangeService.floorHasChanged.emit(this.selectedFloor);\n            this.onFloorClick(false).catch((e) => console.log(e.message));\n          }\n        }\n      });\n  }\n\n  async ngOnInit() {\n    await this.initLocations();\n    this.handleStartUrl();\n  }\n\n  ngOnDestroy() {\n    this.destroy$.next(true);\n    this.destroy$.complete();\n  }\n\n  // Capture the \"id\" in localisation/:id routes\n  handleStartUrl() {\n    if (this.router.url.includes('localisation/')) {\n      const paths = this.router.url.split('/'); // /dashboard/localisation/fc0aadb7-3c89-4349-ad1f-bfe9b44916c0\n      // eslint-disable-next-line prefer-destructuring\n      const locID = paths[3];\n      if (this.currentLocationID !== locID) {\n        this.clearData();\n        this.currentLocationID = locID;\n        this.selectedLocation = this.findLocationByID(locID);\n        this.navigatorService.currentNavBarLocationID = locID;\n        this.onSelectedLocationChanged().catch((e) => console.log(e.message));\n      }\n    }\n  }\n\n  async initLocations() {\n    this.locations = this.spaceService.locationsForUser;\n    if (this.locations.length === 0) {\n      this.locations = await this.spaceService.getLocationsForCurrentUser();\n    }\n    if (this.currentLocationID && this.locations.length > 0) {\n      this.selectedLocation = this.findLocationByID(this.currentLocationID);\n      if (this.selectedLocation) {\n        this.sendUpdateLocationEvent();\n      }\n    }\n  }\n\n  /**\n   * Find a location with a given ID\n   * @param id ID for the location\n   * @returns The location or null if no location were found\n   */\n  findLocationByID(id: string): Space {\n    const space = this.locations.find((loc) => loc.id === id);\n    return space || null; /** Convert to null if undefined */\n  }\n\n  clearData(clearVisits: boolean = true) {\n    this.floorsPerSpace = null;\n    this.selectedFloor = null;\n    this.zonesPerFloor = null;\n    this.childrenZones = null;\n    this.selectedModel3d = null;\n    this.sweepToGo = null;\n    this.floorToGo = null;\n    this.selectedZone = null;\n    this.selectedChildZone = null;\n    if (clearVisits) {\n      this.visitsPerSpace = null;\n      this.zonesPerSpace = null;\n    }\n    localStorage.removeItem('locationId');\n    localStorage.removeItem('floorId');\n    localStorage.removeItem('zoneId');\n    localStorage.removeItem('childZoneId');\n  }\n\n  /**\n   * When the selectedLocation changes\n   * Send a event to locationIDChange from NavigatorService\n   * The event will be catch by this component and the filter bar will be update\n   */\n  sendUpdateLocationEvent() {\n    const locationID = this.selectedLocation ? this.selectedLocation.id : null;\n    this.navigatorService.locationIDChange.next(locationID);\n    if (this.selectedLocation) {\n      localStorage.setItem('locationId', this.selectedLocation.id);\n    } else {\n      localStorage.removeItem('locationId');\n    }\n  }\n\n  async onSelectedLocationChanged() {\n    if (!this.selectedLocation) {\n      return;\n    }\n    try {\n      this.visitsPerSpace = await this.visitService.getVisitsForSpaceForUser(\n        this.selectedLocation.id\n      );\n      this.zonesPerSpace = await this.zoneService.getZonesBySpaceForUser(\n        this.selectedLocation.id\n      );\n      if (this.visitsPerSpace.length === 1) {\n        this.selectedModel3d = this.visitsPerSpace[0].model3d;\n        this.floorsPerSpace = this.zonesPerSpace.filter(\n          (zone) => zone.layer && zone.layer.name.includes('FLOOR')\n        );\n        // sort from highest floor to lowest\n        this.floorsPerSpace.sort((a, b) => {\n          if (a.metadata && b.metadata) {\n            const metadataA = JSON.parse(a.metadata);\n            const metadataB = JSON.parse(b.metadata);\n            return (\n              metadataB.matterportFloorSequence -\n              metadataA.matterportFloorSequence\n            );\n          }\n          return a.name.localeCompare(b.name);\n        });\n        const multiFloorZones = this.zonesPerSpace.filter(\n          (zone) => zone.isMultipleFloorZone\n        );\n        // sort alphabetically\n        multiFloorZones.sort((a, b) => a.name.localeCompare(b.name));\n        // merge multiFloor and Floors\n        this.floorsPerSpace = [...this.floorsPerSpace, ...multiFloorZones];\n        if (this.floorsPerSpace.length === 1) {\n          [this.selectedFloor] = this.floorsPerSpace;\n          this.onFloorClick(false).catch((e) => console.log(e.message));\n        }\n      }\n    } catch (error) {\n      console.log('error onChosenLocation', error);\n    }\n  }\n\n  onLocationClick() {\n    this.clearData();\n    this.sendUpdateLocationEvent();\n  }\n\n  async onFloorClick(emitEvent = true) {\n    if (this.selectedFloor) {\n      localStorage.setItem('floorId', this.selectedFloor.id);\n    } else {\n      localStorage.removeItem('floorId');\n    }\n    if (this.selectedFloor && this.selectedFloor.isMultipleFloorZone) {\n      this.selectedZone = this.selectedFloor;\n      this.onZoneClick().catch((e) => console.log(e.message));\n      return;\n    } else {\n      this.onZoneClick().catch((e) => console.log(e.message));\n    }\n    this.sweepToGo = null;\n    this.selectedZone = null;\n    this.selectedChildZone = null;\n    localStorage.removeItem('zoneId');\n    localStorage.removeItem('childZoneId');\n    if (this.selectedFloor === null) {\n      this.navigatorService.navBarZoneIDChange.next(null);\n      this.navigatorService.currentNavBarZoneID = null;\n      return;\n    }\n    if (emitEvent) {\n      this.navigatorService.navBarZoneIDChange.next(this.selectedFloor.id);\n    }\n\n    this.navigatorService.currentNavBarZoneID = this.selectedFloor.id;\n    await waitUntil(\n      () => this.zonesPerSpace !== null && this.zonesPerSpace !== undefined\n    );\n    this.zonesPerFloor = this.zonesPerSpace.filter(\n      (zone) =>\n        // zone.id === this.selectedFloor.id ||\n        zone.parentID === this.selectedFloor.id\n    );\n    this.zonesPerFloor.sort((a, b) => {\n      const Collator = new Intl.Collator(undefined, {\n        numeric: true,\n        sensitivity: 'accent',\n      });\n      return (\n        Collator.compare(a.code_ref, b.code_ref) ||\n        Collator.compare(a.name, b.name)\n      );\n    });\n  }\n\n  async onZoneClick() {\n    this.selectedChildZone = null;\n    localStorage.removeItem('childZoneId');\n    if (this.selectedZone) {\n      localStorage.setItem('zoneId', this.selectedZone.id);\n    } else {\n      localStorage.removeItem('zoneId');\n    }\n    if (this.selectedZone === null) {\n      if (this.selectedFloor === null) {\n        this.navigatorService.navBarZoneIDChange.next(null);\n        this.navigatorService.currentNavBarZoneID = null;\n      } else {\n        this.navigatorService.navBarZoneIDChange.next(this.selectedFloor.id);\n        this.navigatorService.currentNavBarZoneID = this.selectedFloor.id;\n      }\n      this.sendKinesisAnalyticsEventForZone(\n        this.selectedZone?.id,\n        this.selectedZone?.name\n      ).catch((e) => console.log(e.message));\n      return;\n    }\n    this.childrenZones = this.zonesPerSpace.filter(\n      (zone) => zone.parentID === this.selectedZone.id\n    );\n    this.navigatorService.navBarZoneIDChange.next(this.selectedZone.id);\n    this.navigatorService.currentNavBarZoneID = this.selectedZone.id;\n    this.sendKinesisAnalyticsEventForZone(\n      this.selectedZone?.id,\n      this.selectedZone?.name\n    ).catch((e) => console.log(e.message));\n  }\n\n  onChildZoneClick() {\n    if (this.selectedChildZone) {\n      localStorage.setItem('childZoneId', this.selectedChildZone?.id);\n    } else {\n      localStorage.removeItem('childZoneId');\n    }\n  }\n\n  async sendKinesisAnalyticsEventForZone(\n    zoneId: string,\n    zoneName: string\n  ): Promise<void> {\n    if (!!this.awsKinesisAnalytics && !!this.awsKinesisAnalytics.record && this.awsKinesisAnalytics.record()) {\n      this.awsKinesisAnalytics.getInstance().record(\n        // @ts-ignore\n        {\n          data: {\n            eventType: 'Zone Change',\n            zoneId: zoneId,\n            zoneName: zoneName,\n            locationId: this.selectedLocation?.id,\n            locationName: this.selectedLocation?.name,\n            user: this.userService?.cu,\n            timestamp: new Date(),\n            floorId: this.selectedFloor?.id,\n            childZoneId: this.selectedChildZone?.id,\n          },\n          streamName: 'smarterplanKinesis-analytics',\n          // partitionKey: \"\",\n        },\n        'AWSKinesis'\n      );\n    }\n  }\n\n  async onVisitClick(event) {\n    this.clearData(false);\n    const index = event.target.value;\n    const visit = this.visitsPerSpace[index];\n    this.selectedModel3d = visit.model3d;\n    const parentZoneForVisit = await this.visitService.getDefaultZoneForVisit(\n      visit\n    );\n    this.floorsPerSpace = this.zonesPerSpace.filter(\n      (zone) =>\n        zone.layer &&\n        zone.layer.name.includes('FLOOR') &&\n        zone.parentID === parentZoneForVisit.id\n    );\n  }\n\n  async goTo() {\n    if (this.selectedZone && !this.selectedZone.virtual) {\n      this.sweepToGo = this.selectedZone.startSweepID\n        ? this.selectedZone.startSweepID\n        : this.selectedZone.sweepIDs[0];\n    }\n    if (this.selectedFloor && !this.selectedZone) {\n      this.floorToGo = this.selectedFloor;\n    }\n    if (this.isWithinSameVisit()) {\n      this.goToSweepOrFloor();\n    } else {\n      if (this.sweepToGo) {\n        this.viewerService.setSweepToMove(this.sweepToGo);\n      }\n      if (this.floorToGo && this.floorsPerSpace.length !== 1) {\n        this.navigatorService.floorToGo = this.floorToGo;\n      }\n      this.router\n        .navigate(['visit', this.selectedLocation.id], {\n          queryParams: { model3D: this.selectedModel3d },\n        })\n        .catch((e) => console.log(e.message));\n    }\n  }\n\n  isWithinSameVisit(): boolean {\n    return (\n      this.currentLocationID === this.selectedLocation.id &&\n      this.selectedModel3d === this.currentModel3d\n    );\n  }\n\n  goToSweepOrFloor() {\n    if (this.sweepToGo) {\n      this.navigatorService.goToSweepWithRotation(this.sweepToGo);\n    }\n    if (this.floorToGo) {\n      this.navigatorService.goToFloor(this.floorToGo);\n    }\n  }\n\n  // hasHistory(): boolean {\n  //     return this.navigatorService.modelHasHistory(this.selectedModel3d);\n  // }\n\n  canGo(): boolean {\n    const viewerIsReady =\n      this.viewerService.isLoaded && this.viewerService.showingViewer;\n    const noViewer = !this.viewerService.showingViewer;\n    return viewerIsReady || noViewer;\n  }\n\n  showLocation(): string {\n    if (\n      window.innerWidth < 750 &&\n      this.navbarSelectMenu &&\n      this.navbarSelectMenu.nativeElement.className.search('show') === -1 &&\n      this.selectedLocation\n    ) {\n      return this.selectedLocation.name;\n    }\n    return '';\n  }\n}\n","<nav class=\"navbar navbar-expand-md navbar-dark navbar-inverse second-nav\">\n    <div class=\"d-flex col-12\">\n        <div #navbarSelectMenu class=\"collapse navbar-collapse\" id=\"nav-item-container-blue\">\n            <div class=\"d-flex flex-column flex-md-row \">\n                <select class=\"form-control flex-fill location select-menu\" [(ngModel)]=\"selectedLocation\"\n                    (ngModelChange)=\"onLocationClick()\">\n                    <option [ngValue]=\"null\" selected>{{ 'Location' | translate }}</option>\n                    <option *ngFor=\"let loc of locations; index as index\" [ngValue]=\"loc\"> {{ loc.name }}</option>\n                </select>\n                <select class=\"form-control flex-fill select-menu\" (change)=\"onVisitClick($event)\"\n                    *ngIf=\"visitsPerSpace && visitsPerSpace.length > 1\">\n                    <option value=\"default\" selected disabled hidden>{{'Visit' | translate}}</option>\n                    <option *ngFor=\"let visit of visitsPerSpace; index as index\" value=\"{{index}}\">{{ visit.name}}\n                    </option>\n                </select>\n                <select class=\"form-control flex-fill floor select-menu\" [(ngModel)]=\"selectedFloor\"\n                    (ngModelChange)=\"onFloorClick()\">\n                    <option [ngValue]=\"null\" selected>{{'Floor' | translate}}</option>\n                    <option *ngFor=\"let floor of floorsPerSpace\" [ngValue]=\"floor\">{{ floor.name}}</option>\n                </select>\n                <select class=\"form-control flex-fill select-menu zone\" [(ngModel)]=\"selectedZone\"\n                    (ngModelChange)=\"onZoneClick()\">\n                    <option [ngValue]=\"null\" selected>{{'Zone' | translate}}</option>\n                    <option *ngFor=\"let zone of zonesPerFloor\" [ngValue]=\"zone\"><span\n                            *ngIf=\"zone.code_ref\">{{zone.code_ref}}_</span>{{zone.name}}</option>\n                </select>\n                <select class=\"form-control flex-fill select-menu\" [(ngModel)]=\"selectedChildZone\"\n                    *ngIf=\"childrenZones && childrenZones.length>0\" (ngModelChange)=\"onChildZoneClick()\">\n                    <option [ngValue]=\"null\" selected disabled>{{'Zone' | translate}}</option>\n                    <option *ngFor=\"let zone of childrenZones\" [ngValue]=\"zone\">{{ zone.name}}</option>\n                </select>\n                <!-- <select class=\"form-control flex-fill\">\n                    <option i18n>{{'Favorites' | translate}}</option>\n                </select> -->\n            </div>\n            <div class=\"row\" style=\"margin-left: 0;\">\n                <div class=\"outer_circle\">\n                    <button id='btn-icon' [disabled]=\"!selectedLocation || !selectedModel3d || !canGo()\"\n                        (click)=\"goTo()\"></button>\n                </div>\n                <button (click)=\"goTo()\" class=\"btn rounded-pill btn-3d\"\n                    [disabled]=\"!selectedLocation || !selectedModel3d || !canGo()\">{{'3D visit' | translate}}</button>\n            </div>\n        </div>\n\n        <h4 style=\"line-height: 29px;margin: 0;\" *ngIf=\"showLocation()\">\n            {{ showLocation() }}\n        </h4>\n    </div>\n</nav>"]}
|
|
1
|
+
import { Component, Inject, ViewChild } from '@angular/core';
|
|
2
|
+
import { Subject, takeUntil } from 'rxjs';
|
|
3
|
+
import { waitUntil } from '../../../helpers.service';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/router";
|
|
6
|
+
import * as i2 from "../../../services/models/space.service";
|
|
7
|
+
import * as i3 from "../../../services/user.service";
|
|
8
|
+
import * as i4 from "../../../services/models/zone.service";
|
|
9
|
+
import * as i5 from "../../../services/models/visit.service";
|
|
10
|
+
import * as i6 from "../../../services/viewer.service";
|
|
11
|
+
import * as i7 from "../../../services/navigator.service";
|
|
12
|
+
import * as i8 from "../../../services/zoneChange.service";
|
|
13
|
+
import * as i9 from "@ng-bootstrap/ng-bootstrap";
|
|
14
|
+
import * as i10 from "@angular/forms";
|
|
15
|
+
import * as i11 from "@angular/common";
|
|
16
|
+
import * as i12 from "@ngx-translate/core";
|
|
17
|
+
export class NavigationBarComponent {
|
|
18
|
+
constructor(awsKinesisAnalyticsInjected, router, spaceService, userService, zoneService, visitService, viewerService, navigatorService, zoneChangeService) {
|
|
19
|
+
this.router = router;
|
|
20
|
+
this.spaceService = spaceService;
|
|
21
|
+
this.userService = userService;
|
|
22
|
+
this.zoneService = zoneService;
|
|
23
|
+
this.visitService = visitService;
|
|
24
|
+
this.viewerService = viewerService;
|
|
25
|
+
this.navigatorService = navigatorService;
|
|
26
|
+
this.zoneChangeService = zoneChangeService;
|
|
27
|
+
this.selectedLocation = null;
|
|
28
|
+
this.selectedFloor = null;
|
|
29
|
+
this.selectedZone = null;
|
|
30
|
+
this.selectedChildZone = null;
|
|
31
|
+
this.visitsPerSpace = null;
|
|
32
|
+
this.floorsPerSpace = null;
|
|
33
|
+
this.zonesPerSpace = null;
|
|
34
|
+
this.zonesPerFloor = null;
|
|
35
|
+
this.childrenZones = null;
|
|
36
|
+
this.destroy$ = new Subject();
|
|
37
|
+
this.awsKinesisAnalytics = awsKinesisAnalyticsInjected;
|
|
38
|
+
this.spaceService.locationUpdated
|
|
39
|
+
.pipe(takeUntil(this.destroy$))
|
|
40
|
+
.subscribe((locs) => {
|
|
41
|
+
this.locations = locs;
|
|
42
|
+
if (this.selectedLocation) {
|
|
43
|
+
this.selectedLocation = this.findLocationByID(this.selectedLocation.id); // Update Object (object address will change);
|
|
44
|
+
}
|
|
45
|
+
});
|
|
46
|
+
this.viewerService.viewerIsOn
|
|
47
|
+
.pipe(takeUntil(this.destroy$))
|
|
48
|
+
.subscribe((data) => {
|
|
49
|
+
// console.log('menu navigation received update', data);
|
|
50
|
+
this.currentLocationID = data.spaceID;
|
|
51
|
+
this.currentModel3d = data.model3D;
|
|
52
|
+
if (!data.spaceID) {
|
|
53
|
+
this.selectedLocation = null;
|
|
54
|
+
localStorage.removeItem('locationId');
|
|
55
|
+
this.sendUpdateLocationEvent();
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
if ((!this.selectedLocation ||
|
|
59
|
+
this.selectedLocation.id !== data.spaceID) &&
|
|
60
|
+
this.locations) {
|
|
61
|
+
this.selectedLocation = this.findLocationByID(data.spaceID);
|
|
62
|
+
this.sendUpdateLocationEvent();
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
/**
|
|
66
|
+
* We listen for Location change event
|
|
67
|
+
*/
|
|
68
|
+
this.navigatorService.locationIDChange
|
|
69
|
+
.pipe(takeUntil(this.destroy$))
|
|
70
|
+
.subscribe((id) => {
|
|
71
|
+
this.clearData();
|
|
72
|
+
this.currentLocationID = id;
|
|
73
|
+
this.selectedLocation = this.findLocationByID(id);
|
|
74
|
+
this.navigatorService.currentNavBarLocationID = id;
|
|
75
|
+
this.onSelectedLocationChanged().catch((e) => console.log(e.message));
|
|
76
|
+
});
|
|
77
|
+
this.zoneChangeService.zonesForUserChange
|
|
78
|
+
.pipe(takeUntil(this.destroy$))
|
|
79
|
+
.subscribe(async (zones) => {
|
|
80
|
+
if (zones) {
|
|
81
|
+
await waitUntil(() => this.floorsPerSpace !== null);
|
|
82
|
+
const floorZone = zones.find((zone) => zone.layer && zone.layer.name === 'FLOOR');
|
|
83
|
+
if (floorZone) {
|
|
84
|
+
this.selectedFloor = this.floorsPerSpace.find((f) => f.id === floorZone.id);
|
|
85
|
+
// Emit event to dispatch value of this.selectedFloor in all poi/ticket/equipment/measure services
|
|
86
|
+
this.zoneChangeService.floorHasChanged.emit(this.selectedFloor);
|
|
87
|
+
this.onFloorClick(false).catch((e) => console.log(e.message));
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
async ngOnInit() {
|
|
93
|
+
await this.initLocations();
|
|
94
|
+
this.handleStartUrl();
|
|
95
|
+
}
|
|
96
|
+
ngOnDestroy() {
|
|
97
|
+
this.destroy$.next(true);
|
|
98
|
+
this.destroy$.complete();
|
|
99
|
+
}
|
|
100
|
+
// Capture the "id" in localisation/:id routes
|
|
101
|
+
handleStartUrl() {
|
|
102
|
+
if (this.router.url.includes('localisation/')) {
|
|
103
|
+
const paths = this.router.url.split('/'); // /dashboard/localisation/fc0aadb7-3c89-4349-ad1f-bfe9b44916c0
|
|
104
|
+
// eslint-disable-next-line prefer-destructuring
|
|
105
|
+
const locID = paths[3];
|
|
106
|
+
if (this.currentLocationID !== locID) {
|
|
107
|
+
this.clearData();
|
|
108
|
+
this.currentLocationID = locID;
|
|
109
|
+
this.selectedLocation = this.findLocationByID(locID);
|
|
110
|
+
this.navigatorService.currentNavBarLocationID = locID;
|
|
111
|
+
this.onSelectedLocationChanged().catch((e) => console.log(e.message));
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
async initLocations() {
|
|
116
|
+
this.locations = this.spaceService.locationsForUser;
|
|
117
|
+
if (this.locations.length === 0) {
|
|
118
|
+
this.locations = await this.spaceService.getLocationsForCurrentUser();
|
|
119
|
+
}
|
|
120
|
+
if (this.currentLocationID && this.locations.length > 0) {
|
|
121
|
+
this.selectedLocation = this.findLocationByID(this.currentLocationID);
|
|
122
|
+
if (this.selectedLocation) {
|
|
123
|
+
this.sendUpdateLocationEvent();
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
/**
|
|
128
|
+
* Find a location with a given ID
|
|
129
|
+
* @param id ID for the location
|
|
130
|
+
* @returns The location or null if no location were found
|
|
131
|
+
*/
|
|
132
|
+
findLocationByID(id) {
|
|
133
|
+
const space = this.locations.find((loc) => loc.id === id);
|
|
134
|
+
return space || null; /** Convert to null if undefined */
|
|
135
|
+
}
|
|
136
|
+
clearData(clearVisits = true) {
|
|
137
|
+
this.floorsPerSpace = null;
|
|
138
|
+
this.selectedFloor = null;
|
|
139
|
+
this.zonesPerFloor = null;
|
|
140
|
+
this.childrenZones = null;
|
|
141
|
+
this.selectedModel3d = null;
|
|
142
|
+
this.sweepToGo = null;
|
|
143
|
+
this.floorToGo = null;
|
|
144
|
+
this.selectedZone = null;
|
|
145
|
+
this.selectedChildZone = null;
|
|
146
|
+
if (clearVisits) {
|
|
147
|
+
this.visitsPerSpace = null;
|
|
148
|
+
this.zonesPerSpace = null;
|
|
149
|
+
}
|
|
150
|
+
localStorage.removeItem('locationId');
|
|
151
|
+
localStorage.removeItem('floorId');
|
|
152
|
+
localStorage.removeItem('zoneId');
|
|
153
|
+
localStorage.removeItem('childZoneId');
|
|
154
|
+
}
|
|
155
|
+
/**
|
|
156
|
+
* When the selectedLocation changes
|
|
157
|
+
* Send a event to locationIDChange from NavigatorService
|
|
158
|
+
* The event will be catch by this component and the filter bar will be update
|
|
159
|
+
*/
|
|
160
|
+
sendUpdateLocationEvent() {
|
|
161
|
+
const locationID = this.selectedLocation ? this.selectedLocation.id : null;
|
|
162
|
+
this.navigatorService.locationIDChange.next(locationID);
|
|
163
|
+
if (this.selectedLocation) {
|
|
164
|
+
localStorage.setItem('locationId', this.selectedLocation.id);
|
|
165
|
+
}
|
|
166
|
+
else {
|
|
167
|
+
localStorage.removeItem('locationId');
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
async onSelectedLocationChanged() {
|
|
171
|
+
if (!this.selectedLocation) {
|
|
172
|
+
return;
|
|
173
|
+
}
|
|
174
|
+
try {
|
|
175
|
+
this.visitsPerSpace = await this.visitService.getVisitsForSpaceForUser(this.selectedLocation.id);
|
|
176
|
+
this.zonesPerSpace = await this.zoneService.getZonesBySpaceForUser(this.selectedLocation.id);
|
|
177
|
+
if (this.visitsPerSpace.length === 1) {
|
|
178
|
+
this.selectedModel3d = this.visitsPerSpace[0].model3d;
|
|
179
|
+
this.floorsPerSpace = this.zonesPerSpace.filter((zone) => zone.layer && zone.layer.name.includes('FLOOR'));
|
|
180
|
+
// sort from highest floor to lowest
|
|
181
|
+
this.floorsPerSpace.sort((a, b) => {
|
|
182
|
+
if (a.metadata && b.metadata) {
|
|
183
|
+
const metadataA = JSON.parse(a.metadata);
|
|
184
|
+
const metadataB = JSON.parse(b.metadata);
|
|
185
|
+
return (metadataB.matterportFloorSequence -
|
|
186
|
+
metadataA.matterportFloorSequence);
|
|
187
|
+
}
|
|
188
|
+
return a.name.localeCompare(b.name);
|
|
189
|
+
});
|
|
190
|
+
const multiFloorZones = this.zonesPerSpace.filter((zone) => zone.isMultipleFloorZone);
|
|
191
|
+
// sort alphabetically
|
|
192
|
+
multiFloorZones.sort((a, b) => a.name.localeCompare(b.name));
|
|
193
|
+
// merge multiFloor and Floors
|
|
194
|
+
this.floorsPerSpace = [...this.floorsPerSpace, ...multiFloorZones];
|
|
195
|
+
if (this.floorsPerSpace.length === 1) {
|
|
196
|
+
[this.selectedFloor] = this.floorsPerSpace;
|
|
197
|
+
this.onFloorClick(false).catch((e) => console.log(e.message));
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
catch (error) {
|
|
202
|
+
console.log('error onChosenLocation', error);
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
onLocationClick() {
|
|
206
|
+
this.clearData();
|
|
207
|
+
this.sendUpdateLocationEvent();
|
|
208
|
+
}
|
|
209
|
+
async onFloorClick(emitEvent = true) {
|
|
210
|
+
if (this.selectedFloor) {
|
|
211
|
+
localStorage.setItem('floorId', this.selectedFloor.id);
|
|
212
|
+
}
|
|
213
|
+
else {
|
|
214
|
+
localStorage.removeItem('floorId');
|
|
215
|
+
}
|
|
216
|
+
if (this.selectedFloor && this.selectedFloor.isMultipleFloorZone) {
|
|
217
|
+
this.selectedZone = this.selectedFloor;
|
|
218
|
+
this.onZoneClick().catch((e) => console.log(e.message));
|
|
219
|
+
return;
|
|
220
|
+
}
|
|
221
|
+
else {
|
|
222
|
+
this.onZoneClick().catch((e) => console.log(e.message));
|
|
223
|
+
}
|
|
224
|
+
this.sweepToGo = null;
|
|
225
|
+
this.selectedZone = null;
|
|
226
|
+
this.selectedChildZone = null;
|
|
227
|
+
localStorage.removeItem('zoneId');
|
|
228
|
+
localStorage.removeItem('childZoneId');
|
|
229
|
+
if (this.selectedFloor === null) {
|
|
230
|
+
this.navigatorService.navBarZoneIDChange.next(null);
|
|
231
|
+
this.navigatorService.currentNavBarZoneID = null;
|
|
232
|
+
return;
|
|
233
|
+
}
|
|
234
|
+
if (emitEvent) {
|
|
235
|
+
this.navigatorService.navBarZoneIDChange.next(this.selectedFloor.id);
|
|
236
|
+
}
|
|
237
|
+
this.navigatorService.currentNavBarZoneID = this.selectedFloor.id;
|
|
238
|
+
await waitUntil(() => this.zonesPerSpace !== null && this.zonesPerSpace !== undefined);
|
|
239
|
+
this.zonesPerFloor = this.zonesPerSpace.filter((zone) =>
|
|
240
|
+
// zone.id === this.selectedFloor.id ||
|
|
241
|
+
zone.parentID === this.selectedFloor.id);
|
|
242
|
+
this.zonesPerFloor.sort((a, b) => {
|
|
243
|
+
const Collator = new Intl.Collator(undefined, {
|
|
244
|
+
numeric: true,
|
|
245
|
+
sensitivity: 'accent',
|
|
246
|
+
});
|
|
247
|
+
return (Collator.compare(a.code_ref, b.code_ref) ||
|
|
248
|
+
Collator.compare(a.name, b.name));
|
|
249
|
+
});
|
|
250
|
+
}
|
|
251
|
+
async onZoneClick() {
|
|
252
|
+
this.selectedChildZone = null;
|
|
253
|
+
localStorage.removeItem('childZoneId');
|
|
254
|
+
if (this.selectedZone) {
|
|
255
|
+
localStorage.setItem('zoneId', this.selectedZone.id);
|
|
256
|
+
}
|
|
257
|
+
else {
|
|
258
|
+
localStorage.removeItem('zoneId');
|
|
259
|
+
}
|
|
260
|
+
if (this.selectedZone === null) {
|
|
261
|
+
if (this.selectedFloor === null) {
|
|
262
|
+
this.navigatorService.navBarZoneIDChange.next(null);
|
|
263
|
+
this.navigatorService.currentNavBarZoneID = null;
|
|
264
|
+
}
|
|
265
|
+
else {
|
|
266
|
+
this.navigatorService.navBarZoneIDChange.next(this.selectedFloor.id);
|
|
267
|
+
this.navigatorService.currentNavBarZoneID = this.selectedFloor.id;
|
|
268
|
+
}
|
|
269
|
+
this.sendKinesisAnalyticsEventForZone(this.selectedZone?.id, this.selectedZone?.name).catch((e) => console.log(e.message));
|
|
270
|
+
return;
|
|
271
|
+
}
|
|
272
|
+
this.childrenZones = this.zonesPerSpace.filter((zone) => zone.parentID === this.selectedZone.id);
|
|
273
|
+
this.navigatorService.navBarZoneIDChange.next(this.selectedZone.id);
|
|
274
|
+
this.navigatorService.currentNavBarZoneID = this.selectedZone.id;
|
|
275
|
+
this.sendKinesisAnalyticsEventForZone(this.selectedZone?.id, this.selectedZone?.name).catch((e) => console.log(e.message));
|
|
276
|
+
}
|
|
277
|
+
onChildZoneClick() {
|
|
278
|
+
if (this.selectedChildZone) {
|
|
279
|
+
localStorage.setItem('childZoneId', this.selectedChildZone?.id);
|
|
280
|
+
}
|
|
281
|
+
else {
|
|
282
|
+
localStorage.removeItem('childZoneId');
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
async sendKinesisAnalyticsEventForZone(zoneId, zoneName) {
|
|
286
|
+
if (!!this.awsKinesisAnalytics && !!this.awsKinesisAnalytics.record && this.awsKinesisAnalytics.record()) {
|
|
287
|
+
this.awsKinesisAnalytics.getInstance().record(
|
|
288
|
+
// @ts-ignore
|
|
289
|
+
{
|
|
290
|
+
data: {
|
|
291
|
+
eventType: 'Zone Change',
|
|
292
|
+
zoneId: zoneId,
|
|
293
|
+
zoneName: zoneName,
|
|
294
|
+
locationId: this.selectedLocation?.id,
|
|
295
|
+
locationName: this.selectedLocation?.name,
|
|
296
|
+
user: this.userService?.cu,
|
|
297
|
+
timestamp: new Date(),
|
|
298
|
+
floorId: this.selectedFloor?.id,
|
|
299
|
+
childZoneId: this.selectedChildZone?.id,
|
|
300
|
+
},
|
|
301
|
+
streamName: 'smarterplanKinesis-analytics',
|
|
302
|
+
// partitionKey: "",
|
|
303
|
+
}, 'AWSKinesis');
|
|
304
|
+
}
|
|
305
|
+
}
|
|
306
|
+
async onVisitClick(event) {
|
|
307
|
+
this.clearData(false);
|
|
308
|
+
const index = event.target.value;
|
|
309
|
+
const visit = this.visitsPerSpace[index];
|
|
310
|
+
this.selectedModel3d = visit.model3d;
|
|
311
|
+
const parentZoneForVisit = await this.visitService.getDefaultZoneForVisit(visit);
|
|
312
|
+
this.floorsPerSpace = this.zonesPerSpace.filter((zone) => zone.layer &&
|
|
313
|
+
zone.layer.name.includes('FLOOR') &&
|
|
314
|
+
zone.parentID === parentZoneForVisit.id);
|
|
315
|
+
}
|
|
316
|
+
async goTo() {
|
|
317
|
+
if (this.selectedZone && !this.selectedZone.virtual) {
|
|
318
|
+
this.sweepToGo = this.selectedZone.startSweepID
|
|
319
|
+
? this.selectedZone.startSweepID
|
|
320
|
+
: this.selectedZone.sweepIDs[0];
|
|
321
|
+
}
|
|
322
|
+
if (this.selectedFloor && !this.selectedZone) {
|
|
323
|
+
this.floorToGo = this.selectedFloor;
|
|
324
|
+
}
|
|
325
|
+
if (this.isWithinSameVisit()) {
|
|
326
|
+
this.goToSweepOrFloor();
|
|
327
|
+
}
|
|
328
|
+
else {
|
|
329
|
+
if (this.sweepToGo) {
|
|
330
|
+
this.viewerService.setSweepToMove(this.sweepToGo);
|
|
331
|
+
}
|
|
332
|
+
if (this.floorToGo && this.floorsPerSpace.length !== 1) {
|
|
333
|
+
this.navigatorService.floorToGo = this.floorToGo;
|
|
334
|
+
}
|
|
335
|
+
this.router
|
|
336
|
+
.navigate(['visit', this.selectedLocation.id], {
|
|
337
|
+
queryParams: { model3D: this.selectedModel3d },
|
|
338
|
+
})
|
|
339
|
+
.catch((e) => console.log(e.message));
|
|
340
|
+
}
|
|
341
|
+
}
|
|
342
|
+
isWithinSameVisit() {
|
|
343
|
+
return (this.currentLocationID === this.selectedLocation.id &&
|
|
344
|
+
this.selectedModel3d === this.currentModel3d);
|
|
345
|
+
}
|
|
346
|
+
goToSweepOrFloor() {
|
|
347
|
+
if (this.sweepToGo) {
|
|
348
|
+
this.navigatorService.goToSweepWithRotation(this.sweepToGo);
|
|
349
|
+
}
|
|
350
|
+
if (this.floorToGo) {
|
|
351
|
+
this.navigatorService.goToFloor(this.floorToGo);
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
// hasHistory(): boolean {
|
|
355
|
+
// return this.navigatorService.modelHasHistory(this.selectedModel3d);
|
|
356
|
+
// }
|
|
357
|
+
canGo() {
|
|
358
|
+
const viewerIsReady = this.viewerService.isLoaded && this.viewerService.showingViewer;
|
|
359
|
+
const noViewer = !this.viewerService.showingViewer;
|
|
360
|
+
return viewerIsReady || noViewer;
|
|
361
|
+
}
|
|
362
|
+
showLocation() {
|
|
363
|
+
if (window.innerWidth < 750 &&
|
|
364
|
+
this.navbarSelectMenu &&
|
|
365
|
+
this.navbarSelectMenu.nativeElement.className.search('show') === -1 &&
|
|
366
|
+
this.selectedLocation) {
|
|
367
|
+
return this.selectedLocation.name;
|
|
368
|
+
}
|
|
369
|
+
return '';
|
|
370
|
+
}
|
|
371
|
+
}
|
|
372
|
+
NavigationBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: NavigationBarComponent, deps: [{ token: 'currentAwsKinesisAnalyticsService' }, { token: i1.Router }, { token: i2.SpaceService }, { token: i3.BaseUserService }, { token: i4.ZoneService }, { token: i5.VisitService }, { token: i6.ViewerService }, { token: i7.NavigatorService }, { token: i8.ZoneChangeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
373
|
+
NavigationBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: NavigationBarComponent, selector: "lib-navigation-bar", viewQueries: [{ propertyName: "navbarSelectMenu", first: true, predicate: ["navbarSelectMenu"], descendants: true }], ngImport: i0, template: "<nav class=\"navbar navbar-expand-md navbar-dark navbar-inverse second-nav\">\r\n <div class=\"d-flex col-12\">\r\n <div #navbarSelectMenu class=\"collapse navbar-collapse\" id=\"nav-item-container-blue\">\r\n <div class=\"d-flex flex-column flex-md-row \">\r\n <select class=\"form-control flex-fill location select-menu\" [(ngModel)]=\"selectedLocation\"\r\n (ngModelChange)=\"onLocationClick()\">\r\n <option [ngValue]=\"null\" selected>{{ 'Location' | translate }}</option>\r\n <option *ngFor=\"let loc of locations; index as index\" [ngValue]=\"loc\"> {{ loc.name }}</option>\r\n </select>\r\n <select class=\"form-control flex-fill select-menu\" (change)=\"onVisitClick($event)\"\r\n *ngIf=\"visitsPerSpace && visitsPerSpace.length > 1\">\r\n <option value=\"default\" selected disabled hidden>{{'Visit' | translate}}</option>\r\n <option *ngFor=\"let visit of visitsPerSpace; index as index\" value=\"{{index}}\">{{ visit.name}}\r\n </option>\r\n </select>\r\n <select class=\"form-control flex-fill floor select-menu\" [(ngModel)]=\"selectedFloor\"\r\n (ngModelChange)=\"onFloorClick()\">\r\n <option [ngValue]=\"null\" selected>{{'Floor' | translate}}</option>\r\n <option *ngFor=\"let floor of floorsPerSpace\" [ngValue]=\"floor\">{{ floor.name}}</option>\r\n </select>\r\n <select class=\"form-control flex-fill select-menu zone\" [(ngModel)]=\"selectedZone\"\r\n (ngModelChange)=\"onZoneClick()\">\r\n <option [ngValue]=\"null\" selected>{{'Zone' | translate}}</option>\r\n <option *ngFor=\"let zone of zonesPerFloor\" [ngValue]=\"zone\"><span\r\n *ngIf=\"zone.code_ref\">{{zone.code_ref}}_</span>{{zone.name}}</option>\r\n </select>\r\n <select class=\"form-control flex-fill select-menu\" [(ngModel)]=\"selectedChildZone\"\r\n *ngIf=\"childrenZones && childrenZones.length>0\" (ngModelChange)=\"onChildZoneClick()\">\r\n <option [ngValue]=\"null\" selected disabled>{{'Zone' | translate}}</option>\r\n <option *ngFor=\"let zone of childrenZones\" [ngValue]=\"zone\">{{ zone.name}}</option>\r\n </select>\r\n <!-- <select class=\"form-control flex-fill\">\r\n <option i18n>{{'Favorites' | translate}}</option>\r\n </select> -->\r\n </div>\r\n <div class=\"row\" style=\"margin-left: 0;\">\r\n <div class=\"outer_circle\">\r\n <button id='btn-icon' [disabled]=\"!selectedLocation || !selectedModel3d || !canGo()\"\r\n (click)=\"goTo()\"></button>\r\n </div>\r\n <button (click)=\"goTo()\" class=\"btn rounded-pill btn-3d\"\r\n [disabled]=\"!selectedLocation || !selectedModel3d || !canGo()\">{{'3D visit' | translate}}</button>\r\n </div>\r\n </div>\r\n\r\n <h4 style=\"line-height: 29px;margin: 0;\" *ngIf=\"showLocation()\">\r\n {{ showLocation() }}\r\n </h4>\r\n </div>\r\n</nav>", styles: [":host{position:sticky;top:0;height:123px}.navbar{z-index:200;padding:.4rem 1rem}.navbar.second-nav{z-index:199;background-color:var(--smarterplan-primary)}input,select{margin-right:15px}.select{background:transparent;border:none;color:#fff;margin:6px 20px 0}.form-control{width:auto;min-width:80px;max-width:18%}.location{width:auto;max-width:35%}.floor,.zone{width:auto;max-width:30%}button{color:#fff;padding:5px 10px;font-size:1.1em}.btn-3d:active:hover:not([disabled]){color:var(--smarterplan-secondary)}.btn-3d[disabled]:hover{color:#fff}.navbar-toggler{margin-right:1em}.select-menu{max-width:inherit}#btn-icon{width:30px;height:30px;background:url(../../../../../assets/icons/goTo3d.svg);border:none;vertical-align:middle}#btn-icon:hover{background:url(../../../../../assets/icons/goTo3d-over.svg)}#btn-icon[disabled]:hover{background:url(../../../../../assets/icons/goTo3d.svg)}.outer_circle{background-color:#ebebeb;border-radius:50%;width:32px;height:32px;padding:1px}@media (max-width: 767px){.navbar{padding:.2rem .5rem}.form-control,.location,.floor,.zone{max-width:100%;margin-bottom:15px}input,select{margin-right:0;margin-bottom:15px}#btn-icon{width:20px;height:20px}}\n"], directives: [{ type: i9.NgbNavbar, selector: ".navbar" }, { type: i10.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { type: i10.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i10.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i10.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i10.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i11.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i11.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i12.TranslatePipe } });
|
|
374
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: NavigationBarComponent, decorators: [{
|
|
375
|
+
type: Component,
|
|
376
|
+
args: [{ selector: 'lib-navigation-bar', template: "<nav class=\"navbar navbar-expand-md navbar-dark navbar-inverse second-nav\">\r\n <div class=\"d-flex col-12\">\r\n <div #navbarSelectMenu class=\"collapse navbar-collapse\" id=\"nav-item-container-blue\">\r\n <div class=\"d-flex flex-column flex-md-row \">\r\n <select class=\"form-control flex-fill location select-menu\" [(ngModel)]=\"selectedLocation\"\r\n (ngModelChange)=\"onLocationClick()\">\r\n <option [ngValue]=\"null\" selected>{{ 'Location' | translate }}</option>\r\n <option *ngFor=\"let loc of locations; index as index\" [ngValue]=\"loc\"> {{ loc.name }}</option>\r\n </select>\r\n <select class=\"form-control flex-fill select-menu\" (change)=\"onVisitClick($event)\"\r\n *ngIf=\"visitsPerSpace && visitsPerSpace.length > 1\">\r\n <option value=\"default\" selected disabled hidden>{{'Visit' | translate}}</option>\r\n <option *ngFor=\"let visit of visitsPerSpace; index as index\" value=\"{{index}}\">{{ visit.name}}\r\n </option>\r\n </select>\r\n <select class=\"form-control flex-fill floor select-menu\" [(ngModel)]=\"selectedFloor\"\r\n (ngModelChange)=\"onFloorClick()\">\r\n <option [ngValue]=\"null\" selected>{{'Floor' | translate}}</option>\r\n <option *ngFor=\"let floor of floorsPerSpace\" [ngValue]=\"floor\">{{ floor.name}}</option>\r\n </select>\r\n <select class=\"form-control flex-fill select-menu zone\" [(ngModel)]=\"selectedZone\"\r\n (ngModelChange)=\"onZoneClick()\">\r\n <option [ngValue]=\"null\" selected>{{'Zone' | translate}}</option>\r\n <option *ngFor=\"let zone of zonesPerFloor\" [ngValue]=\"zone\"><span\r\n *ngIf=\"zone.code_ref\">{{zone.code_ref}}_</span>{{zone.name}}</option>\r\n </select>\r\n <select class=\"form-control flex-fill select-menu\" [(ngModel)]=\"selectedChildZone\"\r\n *ngIf=\"childrenZones && childrenZones.length>0\" (ngModelChange)=\"onChildZoneClick()\">\r\n <option [ngValue]=\"null\" selected disabled>{{'Zone' | translate}}</option>\r\n <option *ngFor=\"let zone of childrenZones\" [ngValue]=\"zone\">{{ zone.name}}</option>\r\n </select>\r\n <!-- <select class=\"form-control flex-fill\">\r\n <option i18n>{{'Favorites' | translate}}</option>\r\n </select> -->\r\n </div>\r\n <div class=\"row\" style=\"margin-left: 0;\">\r\n <div class=\"outer_circle\">\r\n <button id='btn-icon' [disabled]=\"!selectedLocation || !selectedModel3d || !canGo()\"\r\n (click)=\"goTo()\"></button>\r\n </div>\r\n <button (click)=\"goTo()\" class=\"btn rounded-pill btn-3d\"\r\n [disabled]=\"!selectedLocation || !selectedModel3d || !canGo()\">{{'3D visit' | translate}}</button>\r\n </div>\r\n </div>\r\n\r\n <h4 style=\"line-height: 29px;margin: 0;\" *ngIf=\"showLocation()\">\r\n {{ showLocation() }}\r\n </h4>\r\n </div>\r\n</nav>", styles: [":host{position:sticky;top:0;height:123px}.navbar{z-index:200;padding:.4rem 1rem}.navbar.second-nav{z-index:199;background-color:var(--smarterplan-primary)}input,select{margin-right:15px}.select{background:transparent;border:none;color:#fff;margin:6px 20px 0}.form-control{width:auto;min-width:80px;max-width:18%}.location{width:auto;max-width:35%}.floor,.zone{width:auto;max-width:30%}button{color:#fff;padding:5px 10px;font-size:1.1em}.btn-3d:active:hover:not([disabled]){color:var(--smarterplan-secondary)}.btn-3d[disabled]:hover{color:#fff}.navbar-toggler{margin-right:1em}.select-menu{max-width:inherit}#btn-icon{width:30px;height:30px;background:url(../../../../../assets/icons/goTo3d.svg);border:none;vertical-align:middle}#btn-icon:hover{background:url(../../../../../assets/icons/goTo3d-over.svg)}#btn-icon[disabled]:hover{background:url(../../../../../assets/icons/goTo3d.svg)}.outer_circle{background-color:#ebebeb;border-radius:50%;width:32px;height:32px;padding:1px}@media (max-width: 767px){.navbar{padding:.2rem .5rem}.form-control,.location,.floor,.zone{max-width:100%;margin-bottom:15px}input,select{margin-right:0;margin-bottom:15px}#btn-icon{width:20px;height:20px}}\n"] }]
|
|
377
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
378
|
+
type: Inject,
|
|
379
|
+
args: ['currentAwsKinesisAnalyticsService']
|
|
380
|
+
}] }, { type: i1.Router }, { type: i2.SpaceService }, { type: i3.BaseUserService }, { type: i4.ZoneService }, { type: i5.VisitService }, { type: i6.ViewerService }, { type: i7.NavigatorService }, { type: i8.ZoneChangeService }]; }, propDecorators: { navbarSelectMenu: [{
|
|
381
|
+
type: ViewChild,
|
|
382
|
+
args: ['navbarSelectMenu']
|
|
383
|
+
}] } });
|
|
384
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation-bar.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-smarterplan-core/src/lib/components/menu-bar/navigation-bar/navigation-bar.component.ts","../../../../../../../projects/ngx-smarterplan-core/src/lib/components/menu-bar/navigation-bar/navigation-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, OnInit, ViewChild } from '@angular/core';\r\nimport { NavigationEnd, Router } from '@angular/router';\r\nimport { Observable, Subject, takeUntil } from 'rxjs';\r\nimport { waitUntil } from '../../../helpers.service';\r\nimport { SpaceService } from '../../../services/models/space.service';\r\nimport { VisitService } from '../../../services/models/visit.service';\r\nimport { ZoneService } from '../../../services/models/zone.service';\r\nimport { NavigatorService } from '../../../services/navigator.service';\r\nimport { ViewerService } from '../../../services/viewer.service';\r\nimport { Space, Visit, Zone } from '../../../types.service';\r\nimport { BaseUserService } from '../../../services/user.service';\r\nimport {ZoneChangeService} from \"../../../services/zoneChange.service\";\r\n\r\n@Component({\r\n  selector: 'lib-navigation-bar',\r\n  templateUrl: './navigation-bar.component.html',\r\n  styleUrls: ['./navigation-bar.component.scss'],\r\n})\r\nexport class NavigationBarComponent implements OnInit {\r\n  awsKinesisAnalytics: any; //AWS\r\n\r\n  @ViewChild('navbarSelectMenu') navbarSelectMenu!: any;\r\n\r\n  locations: Space[];\r\n\r\n  currentLocationID: string;\r\n\r\n  currentModel3d: string;\r\n\r\n  selectedLocation: Space = null;\r\n\r\n  selectedModel3d: string;\r\n\r\n  selectedFloor: Zone = null;\r\n\r\n  selectedZone: Zone = null;\r\n\r\n  selectedChildZone: Zone = null;\r\n\r\n  visitsPerSpace: Visit[] = null;\r\n\r\n  floorsPerSpace: Zone[] = null;\r\n\r\n  zonesPerSpace: Zone[] = null;\r\n\r\n  zonesPerFloor: Zone[] = null;\r\n\r\n  childrenZones: Zone[] = null;\r\n\r\n  sweepToGo: string;\r\n\r\n  floorToGo: Zone;\r\n\r\n  destroy$ = new Subject();\r\n\r\n  navEvents: Observable<NavigationEnd>;\r\n\r\n  constructor(\r\n    @Inject('currentAwsKinesisAnalyticsService')\r\n    awsKinesisAnalyticsInjected: any,\r\n    private router: Router,\r\n    private spaceService: SpaceService,\r\n    private userService: BaseUserService,\r\n    private zoneService: ZoneService,\r\n    private visitService: VisitService,\r\n    private viewerService: ViewerService,\r\n    private navigatorService: NavigatorService,\r\n    private zoneChangeService: ZoneChangeService\r\n  ) {\r\n    this.awsKinesisAnalytics = awsKinesisAnalyticsInjected;\r\n    this.spaceService.locationUpdated\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((locs) => {\r\n        this.locations = locs;\r\n        if (this.selectedLocation) {\r\n          this.selectedLocation = this.findLocationByID(\r\n            this.selectedLocation.id\r\n          ); // Update Object (object address will change);\r\n        }\r\n      });\r\n    this.viewerService.viewerIsOn\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe(\r\n        (data: { spaceID: string; model3D: string; sweep: string | null }) => {\r\n          // console.log('menu navigation received update', data);\r\n          this.currentLocationID = data.spaceID;\r\n          this.currentModel3d = data.model3D;\r\n          if (!data.spaceID) {\r\n            this.selectedLocation = null;\r\n            localStorage.removeItem('locationId');\r\n            this.sendUpdateLocationEvent();\r\n            return;\r\n          }\r\n          if (\r\n            (!this.selectedLocation ||\r\n              this.selectedLocation.id !== data.spaceID) &&\r\n            this.locations\r\n          ) {\r\n            this.selectedLocation = this.findLocationByID(data.spaceID);\r\n            this.sendUpdateLocationEvent();\r\n          }\r\n        }\r\n      );\r\n\r\n    /**\r\n     * We listen for Location change event\r\n     */\r\n    this.navigatorService.locationIDChange\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((id: string) => {\r\n        this.clearData();\r\n        this.currentLocationID = id;\r\n        this.selectedLocation = this.findLocationByID(id);\r\n        this.navigatorService.currentNavBarLocationID = id;\r\n        this.onSelectedLocationChanged().catch((e) => console.log(e.message));\r\n      });\r\n\r\n    this.zoneChangeService.zonesForUserChange\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe(async (zones) => {\r\n        if (zones) {\r\n          await waitUntil(() => this.floorsPerSpace !== null);\r\n          const floorZone = zones.find(\r\n            (zone) => zone.layer && zone.layer.name === 'FLOOR'\r\n          );\r\n          if (floorZone) {\r\n            this.selectedFloor = this.floorsPerSpace.find(\r\n              (f) => f.id === floorZone.id\r\n            );\r\n            // Emit event to dispatch value of  this.selectedFloor in all poi/ticket/equipment/measure services\r\n            this.zoneChangeService.floorHasChanged.emit(this.selectedFloor);\r\n            this.onFloorClick(false).catch((e) => console.log(e.message));\r\n          }\r\n        }\r\n      });\r\n  }\r\n\r\n  async ngOnInit() {\r\n    await this.initLocations();\r\n    this.handleStartUrl();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroy$.next(true);\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  // Capture the \"id\" in localisation/:id routes\r\n  handleStartUrl() {\r\n    if (this.router.url.includes('localisation/')) {\r\n      const paths = this.router.url.split('/'); // /dashboard/localisation/fc0aadb7-3c89-4349-ad1f-bfe9b44916c0\r\n      // eslint-disable-next-line prefer-destructuring\r\n      const locID = paths[3];\r\n      if (this.currentLocationID !== locID) {\r\n        this.clearData();\r\n        this.currentLocationID = locID;\r\n        this.selectedLocation = this.findLocationByID(locID);\r\n        this.navigatorService.currentNavBarLocationID = locID;\r\n        this.onSelectedLocationChanged().catch((e) => console.log(e.message));\r\n      }\r\n    }\r\n  }\r\n\r\n  async initLocations() {\r\n    this.locations = this.spaceService.locationsForUser;\r\n    if (this.locations.length === 0) {\r\n      this.locations = await this.spaceService.getLocationsForCurrentUser();\r\n    }\r\n    if (this.currentLocationID && this.locations.length > 0) {\r\n      this.selectedLocation = this.findLocationByID(this.currentLocationID);\r\n      if (this.selectedLocation) {\r\n        this.sendUpdateLocationEvent();\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Find a location with a given ID\r\n   * @param id ID for the location\r\n   * @returns The location or null if no location were found\r\n   */\r\n  findLocationByID(id: string): Space {\r\n    const space = this.locations.find((loc) => loc.id === id);\r\n    return space || null; /** Convert to null if undefined */\r\n  }\r\n\r\n  clearData(clearVisits: boolean = true) {\r\n    this.floorsPerSpace = null;\r\n    this.selectedFloor = null;\r\n    this.zonesPerFloor = null;\r\n    this.childrenZones = null;\r\n    this.selectedModel3d = null;\r\n    this.sweepToGo = null;\r\n    this.floorToGo = null;\r\n    this.selectedZone = null;\r\n    this.selectedChildZone = null;\r\n    if (clearVisits) {\r\n      this.visitsPerSpace = null;\r\n      this.zonesPerSpace = null;\r\n    }\r\n    localStorage.removeItem('locationId');\r\n    localStorage.removeItem('floorId');\r\n    localStorage.removeItem('zoneId');\r\n    localStorage.removeItem('childZoneId');\r\n  }\r\n\r\n  /**\r\n   * When the selectedLocation changes\r\n   * Send a event to locationIDChange from NavigatorService\r\n   * The event will be catch by this component and the filter bar will be update\r\n   */\r\n  sendUpdateLocationEvent() {\r\n    const locationID = this.selectedLocation ? this.selectedLocation.id : null;\r\n    this.navigatorService.locationIDChange.next(locationID);\r\n    if (this.selectedLocation) {\r\n      localStorage.setItem('locationId', this.selectedLocation.id);\r\n    } else {\r\n      localStorage.removeItem('locationId');\r\n    }\r\n  }\r\n\r\n  async onSelectedLocationChanged() {\r\n    if (!this.selectedLocation) {\r\n      return;\r\n    }\r\n    try {\r\n      this.visitsPerSpace = await this.visitService.getVisitsForSpaceForUser(\r\n        this.selectedLocation.id\r\n      );\r\n      this.zonesPerSpace = await this.zoneService.getZonesBySpaceForUser(\r\n        this.selectedLocation.id\r\n      );\r\n      if (this.visitsPerSpace.length === 1) {\r\n        this.selectedModel3d = this.visitsPerSpace[0].model3d;\r\n        this.floorsPerSpace = this.zonesPerSpace.filter(\r\n          (zone) => zone.layer && zone.layer.name.includes('FLOOR')\r\n        );\r\n        // sort from highest floor to lowest\r\n        this.floorsPerSpace.sort((a, b) => {\r\n          if (a.metadata && b.metadata) {\r\n            const metadataA = JSON.parse(a.metadata);\r\n            const metadataB = JSON.parse(b.metadata);\r\n            return (\r\n              metadataB.matterportFloorSequence -\r\n              metadataA.matterportFloorSequence\r\n            );\r\n          }\r\n          return a.name.localeCompare(b.name);\r\n        });\r\n        const multiFloorZones = this.zonesPerSpace.filter(\r\n          (zone) => zone.isMultipleFloorZone\r\n        );\r\n        // sort alphabetically\r\n        multiFloorZones.sort((a, b) => a.name.localeCompare(b.name));\r\n        // merge multiFloor and Floors\r\n        this.floorsPerSpace = [...this.floorsPerSpace, ...multiFloorZones];\r\n        if (this.floorsPerSpace.length === 1) {\r\n          [this.selectedFloor] = this.floorsPerSpace;\r\n          this.onFloorClick(false).catch((e) => console.log(e.message));\r\n        }\r\n      }\r\n    } catch (error) {\r\n      console.log('error onChosenLocation', error);\r\n    }\r\n  }\r\n\r\n  onLocationClick() {\r\n    this.clearData();\r\n    this.sendUpdateLocationEvent();\r\n  }\r\n\r\n  async onFloorClick(emitEvent = true) {\r\n    if (this.selectedFloor) {\r\n      localStorage.setItem('floorId', this.selectedFloor.id);\r\n    } else {\r\n      localStorage.removeItem('floorId');\r\n    }\r\n    if (this.selectedFloor && this.selectedFloor.isMultipleFloorZone) {\r\n      this.selectedZone = this.selectedFloor;\r\n      this.onZoneClick().catch((e) => console.log(e.message));\r\n      return;\r\n    } else {\r\n      this.onZoneClick().catch((e) => console.log(e.message));\r\n    }\r\n    this.sweepToGo = null;\r\n    this.selectedZone = null;\r\n    this.selectedChildZone = null;\r\n    localStorage.removeItem('zoneId');\r\n    localStorage.removeItem('childZoneId');\r\n    if (this.selectedFloor === null) {\r\n      this.navigatorService.navBarZoneIDChange.next(null);\r\n      this.navigatorService.currentNavBarZoneID = null;\r\n      return;\r\n    }\r\n    if (emitEvent) {\r\n      this.navigatorService.navBarZoneIDChange.next(this.selectedFloor.id);\r\n    }\r\n\r\n    this.navigatorService.currentNavBarZoneID = this.selectedFloor.id;\r\n    await waitUntil(\r\n      () => this.zonesPerSpace !== null && this.zonesPerSpace !== undefined\r\n    );\r\n    this.zonesPerFloor = this.zonesPerSpace.filter(\r\n      (zone) =>\r\n        // zone.id === this.selectedFloor.id ||\r\n        zone.parentID === this.selectedFloor.id\r\n    );\r\n    this.zonesPerFloor.sort((a, b) => {\r\n      const Collator = new Intl.Collator(undefined, {\r\n        numeric: true,\r\n        sensitivity: 'accent',\r\n      });\r\n      return (\r\n        Collator.compare(a.code_ref, b.code_ref) ||\r\n        Collator.compare(a.name, b.name)\r\n      );\r\n    });\r\n  }\r\n\r\n  async onZoneClick() {\r\n    this.selectedChildZone = null;\r\n    localStorage.removeItem('childZoneId');\r\n    if (this.selectedZone) {\r\n      localStorage.setItem('zoneId', this.selectedZone.id);\r\n    } else {\r\n      localStorage.removeItem('zoneId');\r\n    }\r\n    if (this.selectedZone === null) {\r\n      if (this.selectedFloor === null) {\r\n        this.navigatorService.navBarZoneIDChange.next(null);\r\n        this.navigatorService.currentNavBarZoneID = null;\r\n      } else {\r\n        this.navigatorService.navBarZoneIDChange.next(this.selectedFloor.id);\r\n        this.navigatorService.currentNavBarZoneID = this.selectedFloor.id;\r\n      }\r\n      this.sendKinesisAnalyticsEventForZone(\r\n        this.selectedZone?.id,\r\n        this.selectedZone?.name\r\n      ).catch((e) => console.log(e.message));\r\n      return;\r\n    }\r\n    this.childrenZones = this.zonesPerSpace.filter(\r\n      (zone) => zone.parentID === this.selectedZone.id\r\n    );\r\n    this.navigatorService.navBarZoneIDChange.next(this.selectedZone.id);\r\n    this.navigatorService.currentNavBarZoneID = this.selectedZone.id;\r\n    this.sendKinesisAnalyticsEventForZone(\r\n      this.selectedZone?.id,\r\n      this.selectedZone?.name\r\n    ).catch((e) => console.log(e.message));\r\n  }\r\n\r\n  onChildZoneClick() {\r\n    if (this.selectedChildZone) {\r\n      localStorage.setItem('childZoneId', this.selectedChildZone?.id);\r\n    } else {\r\n      localStorage.removeItem('childZoneId');\r\n    }\r\n  }\r\n\r\n  async sendKinesisAnalyticsEventForZone(\r\n    zoneId: string,\r\n    zoneName: string\r\n  ): Promise<void> {\r\n    if (!!this.awsKinesisAnalytics && !!this.awsKinesisAnalytics.record && this.awsKinesisAnalytics.record()) {\r\n      this.awsKinesisAnalytics.getInstance().record(\r\n        // @ts-ignore\r\n        {\r\n          data: {\r\n            eventType: 'Zone Change',\r\n            zoneId: zoneId,\r\n            zoneName: zoneName,\r\n            locationId: this.selectedLocation?.id,\r\n            locationName: this.selectedLocation?.name,\r\n            user: this.userService?.cu,\r\n            timestamp: new Date(),\r\n            floorId: this.selectedFloor?.id,\r\n            childZoneId: this.selectedChildZone?.id,\r\n          },\r\n          streamName: 'smarterplanKinesis-analytics',\r\n          // partitionKey: \"\",\r\n        },\r\n        'AWSKinesis'\r\n      );\r\n    }\r\n  }\r\n\r\n  async onVisitClick(event) {\r\n    this.clearData(false);\r\n    const index = event.target.value;\r\n    const visit = this.visitsPerSpace[index];\r\n    this.selectedModel3d = visit.model3d;\r\n    const parentZoneForVisit = await this.visitService.getDefaultZoneForVisit(\r\n      visit\r\n    );\r\n    this.floorsPerSpace = this.zonesPerSpace.filter(\r\n      (zone) =>\r\n        zone.layer &&\r\n        zone.layer.name.includes('FLOOR') &&\r\n        zone.parentID === parentZoneForVisit.id\r\n    );\r\n  }\r\n\r\n  async goTo() {\r\n    if (this.selectedZone && !this.selectedZone.virtual) {\r\n      this.sweepToGo = this.selectedZone.startSweepID\r\n        ? this.selectedZone.startSweepID\r\n        : this.selectedZone.sweepIDs[0];\r\n    }\r\n    if (this.selectedFloor && !this.selectedZone) {\r\n      this.floorToGo = this.selectedFloor;\r\n    }\r\n    if (this.isWithinSameVisit()) {\r\n      this.goToSweepOrFloor();\r\n    } else {\r\n      if (this.sweepToGo) {\r\n        this.viewerService.setSweepToMove(this.sweepToGo);\r\n      }\r\n      if (this.floorToGo && this.floorsPerSpace.length !== 1) {\r\n        this.navigatorService.floorToGo = this.floorToGo;\r\n      }\r\n      this.router\r\n        .navigate(['visit', this.selectedLocation.id], {\r\n          queryParams: { model3D: this.selectedModel3d },\r\n        })\r\n        .catch((e) => console.log(e.message));\r\n    }\r\n  }\r\n\r\n  isWithinSameVisit(): boolean {\r\n    return (\r\n      this.currentLocationID === this.selectedLocation.id &&\r\n      this.selectedModel3d === this.currentModel3d\r\n    );\r\n  }\r\n\r\n  goToSweepOrFloor() {\r\n    if (this.sweepToGo) {\r\n      this.navigatorService.goToSweepWithRotation(this.sweepToGo);\r\n    }\r\n    if (this.floorToGo) {\r\n      this.navigatorService.goToFloor(this.floorToGo);\r\n    }\r\n  }\r\n\r\n  // hasHistory(): boolean {\r\n  //     return this.navigatorService.modelHasHistory(this.selectedModel3d);\r\n  // }\r\n\r\n  canGo(): boolean {\r\n    const viewerIsReady =\r\n      this.viewerService.isLoaded && this.viewerService.showingViewer;\r\n    const noViewer = !this.viewerService.showingViewer;\r\n    return viewerIsReady || noViewer;\r\n  }\r\n\r\n  showLocation(): string {\r\n    if (\r\n      window.innerWidth < 750 &&\r\n      this.navbarSelectMenu &&\r\n      this.navbarSelectMenu.nativeElement.className.search('show') === -1 &&\r\n      this.selectedLocation\r\n    ) {\r\n      return this.selectedLocation.name;\r\n    }\r\n    return '';\r\n  }\r\n}\r\n","<nav class=\"navbar navbar-expand-md navbar-dark navbar-inverse second-nav\">\r\n    <div class=\"d-flex col-12\">\r\n        <div #navbarSelectMenu class=\"collapse navbar-collapse\" id=\"nav-item-container-blue\">\r\n            <div class=\"d-flex flex-column flex-md-row \">\r\n                <select class=\"form-control flex-fill location select-menu\" [(ngModel)]=\"selectedLocation\"\r\n                    (ngModelChange)=\"onLocationClick()\">\r\n                    <option [ngValue]=\"null\" selected>{{ 'Location' | translate }}</option>\r\n                    <option *ngFor=\"let loc of locations; index as index\" [ngValue]=\"loc\"> {{ loc.name }}</option>\r\n                </select>\r\n                <select class=\"form-control flex-fill select-menu\" (change)=\"onVisitClick($event)\"\r\n                    *ngIf=\"visitsPerSpace && visitsPerSpace.length > 1\">\r\n                    <option value=\"default\" selected disabled hidden>{{'Visit' | translate}}</option>\r\n                    <option *ngFor=\"let visit of visitsPerSpace; index as index\" value=\"{{index}}\">{{ visit.name}}\r\n                    </option>\r\n                </select>\r\n                <select class=\"form-control flex-fill floor select-menu\" [(ngModel)]=\"selectedFloor\"\r\n                    (ngModelChange)=\"onFloorClick()\">\r\n                    <option [ngValue]=\"null\" selected>{{'Floor' | translate}}</option>\r\n                    <option *ngFor=\"let floor of floorsPerSpace\" [ngValue]=\"floor\">{{ floor.name}}</option>\r\n                </select>\r\n                <select class=\"form-control flex-fill select-menu zone\" [(ngModel)]=\"selectedZone\"\r\n                    (ngModelChange)=\"onZoneClick()\">\r\n                    <option [ngValue]=\"null\" selected>{{'Zone' | translate}}</option>\r\n                    <option *ngFor=\"let zone of zonesPerFloor\" [ngValue]=\"zone\"><span\r\n                            *ngIf=\"zone.code_ref\">{{zone.code_ref}}_</span>{{zone.name}}</option>\r\n                </select>\r\n                <select class=\"form-control flex-fill select-menu\" [(ngModel)]=\"selectedChildZone\"\r\n                    *ngIf=\"childrenZones && childrenZones.length>0\" (ngModelChange)=\"onChildZoneClick()\">\r\n                    <option [ngValue]=\"null\" selected disabled>{{'Zone' | translate}}</option>\r\n                    <option *ngFor=\"let zone of childrenZones\" [ngValue]=\"zone\">{{ zone.name}}</option>\r\n                </select>\r\n                <!-- <select class=\"form-control flex-fill\">\r\n                    <option i18n>{{'Favorites' | translate}}</option>\r\n                </select> -->\r\n            </div>\r\n            <div class=\"row\" style=\"margin-left: 0;\">\r\n                <div class=\"outer_circle\">\r\n                    <button id='btn-icon' [disabled]=\"!selectedLocation || !selectedModel3d || !canGo()\"\r\n                        (click)=\"goTo()\"></button>\r\n                </div>\r\n                <button (click)=\"goTo()\" class=\"btn rounded-pill btn-3d\"\r\n                    [disabled]=\"!selectedLocation || !selectedModel3d || !canGo()\">{{'3D visit' | translate}}</button>\r\n            </div>\r\n        </div>\r\n\r\n        <h4 style=\"line-height: 29px;margin: 0;\" *ngIf=\"showLocation()\">\r\n            {{ showLocation() }}\r\n        </h4>\r\n    </div>\r\n</nav>"]}
|