@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,206 +1,206 @@
|
|
|
1
|
-
/* eslint-disable class-methods-use-this */
|
|
2
|
-
import { Inject, Injectable } from "@angular/core";
|
|
3
|
-
import { Subject } from "rxjs";
|
|
4
|
-
import { dateHasExpired } from "../../helpers.service";
|
|
5
|
-
import { ProfileStatus, RoleStatus } from "../../types.service";
|
|
6
|
-
import { DateTime } from "luxon";
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
export class MissionService {
|
|
9
|
-
constructor(
|
|
10
|
-
// private affectationService: AffectationService,
|
|
11
|
-
apiInjected) {
|
|
12
|
-
this.currentMissionsUpdated = new Subject();
|
|
13
|
-
this.API = apiInjected;
|
|
14
|
-
}
|
|
15
|
-
async getMissionsFromUserID(userID) {
|
|
16
|
-
return this.API.__proto__.MissionsByUser(userID).then((missions) => {
|
|
17
|
-
return missions.items.filter((mis) => !mis.deletedAt);
|
|
18
|
-
});
|
|
19
|
-
}
|
|
20
|
-
async getMissionsByOrderedOrganisation(orderedOrgID) {
|
|
21
|
-
return this.API.__proto__.MissionsByOrderedOrganisation(orderedOrgID).then((response) => response.items);
|
|
22
|
-
}
|
|
23
|
-
async getMissionsByOrganisation(orgID) {
|
|
24
|
-
return this.API.__proto__.MissionsByOrganisation(orgID).then((response) => response.items);
|
|
25
|
-
}
|
|
26
|
-
async create(mission) {
|
|
27
|
-
const updMission = await this.API.__proto__.CreateMission(mission);
|
|
28
|
-
console.log("Mission created", updMission);
|
|
29
|
-
await this.checkIfCurrentUserMissionChanged(updMission);
|
|
30
|
-
return updMission;
|
|
31
|
-
}
|
|
32
|
-
async update(mission) {
|
|
33
|
-
const updMission = await this.API.__proto__.UpdateMission(mission);
|
|
34
|
-
console.log("Mission updated", updMission);
|
|
35
|
-
await this.checkIfCurrentUserMissionChanged(updMission);
|
|
36
|
-
return updMission;
|
|
37
|
-
}
|
|
38
|
-
async assertRoleForUserInOrg(user, org, role) {
|
|
39
|
-
return this.getMissionsFromUserID(user.id).then((missions) => {
|
|
40
|
-
if (missions) {
|
|
41
|
-
const misOrg = missions.filter((mis) => {
|
|
42
|
-
return mis.organisationID === org.id && mis.role === role;
|
|
43
|
-
});
|
|
44
|
-
return misOrg.length > 0;
|
|
45
|
-
}
|
|
46
|
-
return false;
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
async getMissionsByOrderedOrganisationBySpace(ordOrgID, spaceID) {
|
|
50
|
-
return this.API.__proto__.MissionsByOrderedOrganisationBySpace(ordOrgID, {
|
|
51
|
-
eq: spaceID,
|
|
52
|
-
}).then((mis) => mis.items);
|
|
53
|
-
}
|
|
54
|
-
async softDeleteMission(missionID) {
|
|
55
|
-
// const hardDelete = await this.canHardDeteleMission(mission.id);
|
|
56
|
-
// if (hardDelete) {
|
|
57
|
-
// return this.hardDeleteMission(mission.id);
|
|
58
|
-
// }
|
|
59
|
-
console.log("Soft Deleting mission");
|
|
60
|
-
const missionUpd = await this.update({
|
|
61
|
-
id: missionID,
|
|
62
|
-
deletedAt: Date.now(),
|
|
63
|
-
});
|
|
64
|
-
await this.checkIfCurrentUserMissionChanged(missionUpd);
|
|
65
|
-
return missionUpd;
|
|
66
|
-
}
|
|
67
|
-
async list() {
|
|
68
|
-
const mis = await this.API.__proto__.ListMissions();
|
|
69
|
-
return mis.items.filter((m) => !m.deletedAt);
|
|
70
|
-
}
|
|
71
|
-
// async canHardDeteleMission(missionID: string): Promise<boolean> {
|
|
72
|
-
// const events = (
|
|
73
|
-
// await this.API.ListEvents({ ownerID: { eq: missionID } })
|
|
74
|
-
// ).items;
|
|
75
|
-
// if (events.length > 0) {
|
|
76
|
-
// return false;
|
|
77
|
-
// }
|
|
78
|
-
// const comments = (
|
|
79
|
-
// await this.API.ListComments({ ownerID: { eq: missionID } })
|
|
80
|
-
// ).items;
|
|
81
|
-
// if (comments.length > 0) {
|
|
82
|
-
// return false;
|
|
83
|
-
// }
|
|
84
|
-
// const affectations =
|
|
85
|
-
// await this.affectationService.getAffectationsFromMissionID(
|
|
86
|
-
// missionID,
|
|
87
|
-
// );
|
|
88
|
-
// if (affectations.length > 0) {
|
|
89
|
-
// return false;
|
|
90
|
-
// }
|
|
91
|
-
// return true;
|
|
92
|
-
// }
|
|
93
|
-
async hardDeleteMission(missionID) {
|
|
94
|
-
return this.API.__proto__.DeleteMission({ id: missionID });
|
|
95
|
-
}
|
|
96
|
-
getActivatedMissions(missions) {
|
|
97
|
-
const activated = [];
|
|
98
|
-
missions.map(async (mission) => {
|
|
99
|
-
const isActivated = mission.groups && mission.groups.includes(ProfileStatus.ACTIVE);
|
|
100
|
-
if (isActivated) {
|
|
101
|
-
activated.push(mission);
|
|
102
|
-
}
|
|
103
|
-
});
|
|
104
|
-
return activated;
|
|
105
|
-
}
|
|
106
|
-
async getMissionsForZone(zoneID) {
|
|
107
|
-
return (await this.API.__proto__.MissionsByZone(zoneID)).items.filter((mis) => !mis.deletedAt);
|
|
108
|
-
}
|
|
109
|
-
async getMissionsForSpace(spaceID) {
|
|
110
|
-
return this.API.__proto__.MissionsBySpace(spaceID).then((missions) => missions.items);
|
|
111
|
-
}
|
|
112
|
-
activateMission(mis) {
|
|
113
|
-
if (mis &&
|
|
114
|
-
(!mis.groups || !mis.groups.includes(ProfileStatus.ACTIVE))) {
|
|
115
|
-
const groups = mis.groups ? mis.groups : [];
|
|
116
|
-
groups.push(ProfileStatus.ACTIVE);
|
|
117
|
-
this.update({ id: mis.id, groups });
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
async getMissionsByTemplate(templateID) {
|
|
121
|
-
return (await this.API.__proto__.MissionsByTemplate(templateID)).items.filter((mis) => !mis.deletedAt);
|
|
122
|
-
}
|
|
123
|
-
async getMission(missionID) {
|
|
124
|
-
return this.API.__proto__.GetMission(missionID);
|
|
125
|
-
}
|
|
126
|
-
async getMissionsByZoneByRole(zoneID, role) {
|
|
127
|
-
return (await this.API.__proto__.MissionsByZoneByRole(zoneID, { eq: role }, null, { deletedAt: { attributeExists: false } }, 200)).items;
|
|
128
|
-
}
|
|
129
|
-
async checkIfCurrentUserMissionChanged(changedMission) {
|
|
130
|
-
if (this.currentUserID === changedMission.userID) {
|
|
131
|
-
this.currentMissionsUpdated.next(true);
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
async instantMissionsOfCurrent(currentUserID) {
|
|
135
|
-
this.currentUserID = currentUserID;
|
|
136
|
-
let missions = await this.getMissionsFromUserID(currentUserID);
|
|
137
|
-
/** Filter to keep only available missions */
|
|
138
|
-
missions = missions.filter((mission) => {
|
|
139
|
-
const hasExpired = dateHasExpired(mission.endDateTime);
|
|
140
|
-
/** Update this.lastExpiredMission */
|
|
141
|
-
if (hasExpired) {
|
|
142
|
-
const lastExpiredDate = this.lastExpiredMission
|
|
143
|
-
? new Date(this.lastExpiredMission.endDateTime)
|
|
144
|
-
: null;
|
|
145
|
-
const dateExpired = new Date(mission.endDateTime);
|
|
146
|
-
if (!lastExpiredDate || dateExpired > lastExpiredDate) {
|
|
147
|
-
this.lastExpiredMission = mission;
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
return !hasExpired;
|
|
151
|
-
});
|
|
152
|
-
if (missions.some((mis) => mis.role === RoleStatus.VISITOR_MUSEUM) && missions.length > 0) {
|
|
153
|
-
// workflow for VISITOR_MUSEUM
|
|
154
|
-
return missions;
|
|
155
|
-
}
|
|
156
|
-
/** Keep only started missions */
|
|
157
|
-
let nextMissionDate = null;
|
|
158
|
-
missions = missions.filter((mission) => {
|
|
159
|
-
const started = mission.startDateTime
|
|
160
|
-
? dateHasExpired(mission.startDateTime)
|
|
161
|
-
: true;
|
|
162
|
-
/** Update next mission to start */
|
|
163
|
-
if (!started) {
|
|
164
|
-
const missionDate = new Date(mission.startDateTime);
|
|
165
|
-
if (!nextMissionDate || missionDate < nextMissionDate) {
|
|
166
|
-
this.nextMissionToStart = mission;
|
|
167
|
-
nextMissionDate = missionDate;
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
return started;
|
|
171
|
-
});
|
|
172
|
-
return missions.length > 0 ? missions : null;
|
|
173
|
-
}
|
|
174
|
-
/**
|
|
175
|
-
* Filters the missions that assisted to live of the visit (by comparing the realStartTime of VisitTemplate and connectedAt time)
|
|
176
|
-
* @param template VisitTemplate
|
|
177
|
-
* @param missions Mission[] missions for this visit
|
|
178
|
-
* @returns Mission[] filtered missions
|
|
179
|
-
*/
|
|
180
|
-
filterMissionsAssitedToLiveForTemplate(template, missions) {
|
|
181
|
-
const visitStartTimestamp = template.realStartedAt;
|
|
182
|
-
return missions.filter((mis) => {
|
|
183
|
-
if (!mis.connectedToLiveAt) {
|
|
184
|
-
return false;
|
|
185
|
-
}
|
|
186
|
-
if (mis.connectedToLiveAt.length === 0) {
|
|
187
|
-
return false;
|
|
188
|
-
}
|
|
189
|
-
const lastConnectedAt = mis.connectedToLiveAt[mis.connectedToLiveAt.length - 1];
|
|
190
|
-
const lastConnectedAtTimestamp = DateTime.fromISO(lastConnectedAt).toMillis();
|
|
191
|
-
return lastConnectedAtTimestamp > visitStartTimestamp;
|
|
192
|
-
});
|
|
193
|
-
}
|
|
194
|
-
}
|
|
195
|
-
MissionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: MissionService, deps: [{ token: 'currentAPIService' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
196
|
-
MissionService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: MissionService, providedIn: "root" });
|
|
197
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: MissionService, decorators: [{
|
|
198
|
-
type: Injectable,
|
|
199
|
-
args: [{
|
|
200
|
-
providedIn: "root",
|
|
201
|
-
}]
|
|
202
|
-
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
203
|
-
type: Inject,
|
|
204
|
-
args: ['currentAPIService']
|
|
205
|
-
}] }]; } });
|
|
206
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mission.service.js","sourceRoot":"","sources":["../../../../../../projects/ngx-smarterplan-core/src/lib/services/models/mission.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable class-methods-use-this */\nimport { Inject, Injectable } from \"@angular/core\";\nimport { Subject } from \"rxjs\";\nimport { dateHasExpired } from \"../../helpers.service\";\nimport { Mission, Organisation, Profile, ProfileStatus, RoleStatus, VisitTemplate } from \"../../types.service\";\nimport { DateTime } from \"luxon\";\n\n@Injectable({\n    providedIn: \"root\",\n})\nexport class MissionService {\n    currentMissionsUpdated = new Subject<boolean>();\n\n    lastExpiredMission: Mission;\n\n    nextMissionToStart: Mission;\n\n    currentUserID: string;\n\n    API: any; //AWS\n\n    constructor(\n        // private affectationService: AffectationService,\n        @Inject('currentAPIService') apiInjected: any\n    ) {\n        this.API = apiInjected;\n    }\n\n    async getMissionsFromUserID(userID: string): Promise<Mission[]> {\n        return this.API.__proto__.MissionsByUser(userID).then((missions) => {\n            return missions.items.filter((mis) => !mis.deletedAt);\n        });\n    }\n\n    async getMissionsByOrderedOrganisation(\n        orderedOrgID: string,\n    ): Promise<Mission[]> {\n        return this.API.__proto__.MissionsByOrderedOrganisation(orderedOrgID).then(\n            (response) => response.items,\n        );\n    }\n\n    async getMissionsByOrganisation(orgID: string): Promise<Mission[]> {\n        return this.API.__proto__.MissionsByOrganisation(orgID).then(\n            (response) => response.items,\n        );\n    }\n\n    async create(mission: Mission): Promise<Mission> {\n        const updMission = await this.API.__proto__.CreateMission(mission);\n        console.log(\"Mission created\", updMission);\n        await this.checkIfCurrentUserMissionChanged(updMission);\n        return updMission;\n    }\n\n    async update(mission: any): Promise<Mission> {\n        const updMission = await this.API.__proto__.UpdateMission(mission);\n        console.log(\"Mission updated\", updMission);\n        await this.checkIfCurrentUserMissionChanged(updMission);\n        return updMission;\n    }\n\n    async assertRoleForUserInOrg(\n        user: Profile,\n        org: Organisation,\n        role: RoleStatus,\n    ): Promise<boolean> {\n        return this.getMissionsFromUserID(user.id).then((missions) => {\n            if (missions) {\n                const misOrg = missions.filter((mis) => {\n                    return mis.organisationID === org.id && mis.role === role;\n                });\n                return misOrg.length > 0;\n            }\n            return false;\n        });\n    }\n\n    async getMissionsByOrderedOrganisationBySpace(\n        ordOrgID: string,\n        spaceID: string,\n    ): Promise<Mission[]> {\n        return this.API.__proto__.MissionsByOrderedOrganisationBySpace(ordOrgID, {\n            eq: spaceID,\n        }).then((mis) => mis.items);\n    }\n\n    async softDeleteMission(missionID: string): Promise<Mission> {\n        // const hardDelete = await this.canHardDeteleMission(mission.id);\n        // if (hardDelete) {\n        //     return this.hardDeleteMission(mission.id);\n        // }\n        console.log(\"Soft Deleting mission\");\n        const missionUpd = await this.update({\n            id: missionID,\n            deletedAt: Date.now(),\n        });\n        await this.checkIfCurrentUserMissionChanged(missionUpd);\n        return missionUpd;\n    }\n\n    async list(): Promise<Mission[]> {\n        const mis = await this.API.__proto__.ListMissions();\n        return mis.items.filter((m) => !m.deletedAt);\n    }\n\n    // async canHardDeteleMission(missionID: string): Promise<boolean> {\n    //     const events = (\n    //         await this.API.ListEvents({ ownerID: { eq: missionID } })\n    //     ).items;\n    //     if (events.length > 0) {\n    //         return false;\n    //     }\n    //     const comments = (\n    //         await this.API.ListComments({ ownerID: { eq: missionID } })\n    //     ).items;\n    //     if (comments.length > 0) {\n    //         return false;\n    //     }\n    //     const affectations =\n    //         await this.affectationService.getAffectationsFromMissionID(\n    //             missionID,\n    //         );\n    //     if (affectations.length > 0) {\n    //         return false;\n    //     }\n    //     return true;\n    // }\n\n    async hardDeleteMission(missionID: string): Promise<Mission> {\n        return this.API.__proto__.DeleteMission({ id: missionID });\n    }\n\n    getActivatedMissions(missions: Mission[]): Mission[] {\n        const activated = [];\n        missions.map(async (mission) => {\n            const isActivated =\n                mission.groups && mission.groups.includes(ProfileStatus.ACTIVE);\n            if (isActivated) {\n                activated.push(mission);\n            }\n        });\n        return activated;\n    }\n\n    async getMissionsForZone(zoneID: string): Promise<Mission[]> {\n        return (await this.API.__proto__.MissionsByZone(zoneID)).items.filter(\n            (mis) => !mis.deletedAt,\n        );\n    }\n\n    async getMissionsForSpace(spaceID: string): Promise<Mission[]> {\n        return this.API.__proto__.MissionsBySpace(spaceID).then((missions) => missions.items);\n    }\n\n    activateMission(mis: Mission) {\n        if (\n            mis &&\n            (!mis.groups || !mis.groups.includes(ProfileStatus.ACTIVE))\n        ) {\n            const groups = mis.groups ? mis.groups : [];\n            groups.push(ProfileStatus.ACTIVE);\n            this.update({ id: mis.id, groups });\n        }\n    }\n\n    async getMissionsByTemplate(templateID: string): Promise<Mission[]> {\n        return (await this.API.__proto__.MissionsByTemplate(templateID)).items.filter(\n            (mis) => !mis.deletedAt,\n        );\n    }\n\n    async getMission(missionID: string): Promise<Mission> {\n        return this.API.__proto__.GetMission(missionID);\n    }\n\n    async getMissionsByZoneByRole(\n        zoneID: string,\n        role: RoleStatus,\n    ): Promise<Mission[]> {\n        return (\n            await this.API.__proto__.MissionsByZoneByRole(\n                zoneID,\n                { eq: role },\n                null,\n                { deletedAt: { attributeExists: false } },\n                200,\n            )\n        ).items;\n    }\n\n    async checkIfCurrentUserMissionChanged(changedMission: Mission) {\n        if (this.currentUserID === changedMission.userID) {\n            this.currentMissionsUpdated.next(true);\n        }\n    }\n\n    async instantMissionsOfCurrent(\n        currentUserID: string,\n    ): Promise<Mission[] | null> {\n        this.currentUserID = currentUserID;\n        let missions = await this.getMissionsFromUserID(currentUserID);\n\n        /** Filter to keep only available missions */\n        missions = missions.filter((mission) => {\n            const hasExpired = dateHasExpired(mission.endDateTime);\n\n            /** Update this.lastExpiredMission */\n            if (hasExpired) {\n                const lastExpiredDate = this.lastExpiredMission\n                    ? new Date(this.lastExpiredMission.endDateTime)\n                    : null;\n                const dateExpired = new Date(mission.endDateTime);\n                if (!lastExpiredDate || dateExpired > lastExpiredDate) {\n                    this.lastExpiredMission = mission;\n                }\n            }\n            return !hasExpired;\n        });\n\n        if (missions.some((mis) => mis.role === RoleStatus.VISITOR_MUSEUM) && missions.length > 0) {\n            // workflow for VISITOR_MUSEUM\n            return missions;\n        }\n        /** Keep only started missions */\n        let nextMissionDate = null;\n        missions = missions.filter((mission) => {\n            const started = mission.startDateTime\n                ? dateHasExpired(mission.startDateTime)\n                : true;\n            /** Update next mission to start */\n            if (!started) {\n                const missionDate = new Date(mission.startDateTime);\n                if (!nextMissionDate || missionDate < nextMissionDate) {\n                    this.nextMissionToStart = mission;\n                    nextMissionDate = missionDate;\n                }\n            }\n            return started;\n        });\n        return missions.length > 0 ? missions : null;\n    }\n\n    /**\n     * Filters the missions that assisted to live of the visit (by comparing the realStartTime of VisitTemplate and connectedAt time)\n     * @param template VisitTemplate \n     * @param missions Mission[] missions for this visit\n     * @returns Mission[] filtered missions\n     */\n    filterMissionsAssitedToLiveForTemplate(template: VisitTemplate, missions: Mission[]): Mission[] {\n        const visitStartTimestamp = template.realStartedAt;\n        return missions.filter((mis) => {\n            if (!mis.connectedToLiveAt) {\n                return false;\n            }\n            if (mis.connectedToLiveAt.length === 0) {\n                return false;\n            }\n            const lastConnectedAt = mis.connectedToLiveAt[mis.connectedToLiveAt.length - 1];\n            const lastConnectedAtTimestamp = DateTime.fromISO(lastConnectedAt).toMillis();\n            return lastConnectedAtTimestamp > visitStartTimestamp;\n        });\n    }\n}\n"]}
|
|
1
|
+
/* eslint-disable class-methods-use-this */
|
|
2
|
+
import { Inject, Injectable } from "@angular/core";
|
|
3
|
+
import { Subject } from "rxjs";
|
|
4
|
+
import { dateHasExpired } from "../../helpers.service";
|
|
5
|
+
import { ProfileStatus, RoleStatus } from "../../types.service";
|
|
6
|
+
import { DateTime } from "luxon";
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export class MissionService {
|
|
9
|
+
constructor(
|
|
10
|
+
// private affectationService: AffectationService,
|
|
11
|
+
apiInjected) {
|
|
12
|
+
this.currentMissionsUpdated = new Subject();
|
|
13
|
+
this.API = apiInjected;
|
|
14
|
+
}
|
|
15
|
+
async getMissionsFromUserID(userID) {
|
|
16
|
+
return this.API.__proto__.MissionsByUser(userID).then((missions) => {
|
|
17
|
+
return missions.items.filter((mis) => !mis.deletedAt);
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
async getMissionsByOrderedOrganisation(orderedOrgID) {
|
|
21
|
+
return this.API.__proto__.MissionsByOrderedOrganisation(orderedOrgID).then((response) => response.items);
|
|
22
|
+
}
|
|
23
|
+
async getMissionsByOrganisation(orgID) {
|
|
24
|
+
return this.API.__proto__.MissionsByOrganisation(orgID).then((response) => response.items);
|
|
25
|
+
}
|
|
26
|
+
async create(mission) {
|
|
27
|
+
const updMission = await this.API.__proto__.CreateMission(mission);
|
|
28
|
+
console.log("Mission created", updMission);
|
|
29
|
+
await this.checkIfCurrentUserMissionChanged(updMission);
|
|
30
|
+
return updMission;
|
|
31
|
+
}
|
|
32
|
+
async update(mission) {
|
|
33
|
+
const updMission = await this.API.__proto__.UpdateMission(mission);
|
|
34
|
+
console.log("Mission updated", updMission);
|
|
35
|
+
await this.checkIfCurrentUserMissionChanged(updMission);
|
|
36
|
+
return updMission;
|
|
37
|
+
}
|
|
38
|
+
async assertRoleForUserInOrg(user, org, role) {
|
|
39
|
+
return this.getMissionsFromUserID(user.id).then((missions) => {
|
|
40
|
+
if (missions) {
|
|
41
|
+
const misOrg = missions.filter((mis) => {
|
|
42
|
+
return mis.organisationID === org.id && mis.role === role;
|
|
43
|
+
});
|
|
44
|
+
return misOrg.length > 0;
|
|
45
|
+
}
|
|
46
|
+
return false;
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
async getMissionsByOrderedOrganisationBySpace(ordOrgID, spaceID) {
|
|
50
|
+
return this.API.__proto__.MissionsByOrderedOrganisationBySpace(ordOrgID, {
|
|
51
|
+
eq: spaceID,
|
|
52
|
+
}).then((mis) => mis.items);
|
|
53
|
+
}
|
|
54
|
+
async softDeleteMission(missionID) {
|
|
55
|
+
// const hardDelete = await this.canHardDeteleMission(mission.id);
|
|
56
|
+
// if (hardDelete) {
|
|
57
|
+
// return this.hardDeleteMission(mission.id);
|
|
58
|
+
// }
|
|
59
|
+
console.log("Soft Deleting mission");
|
|
60
|
+
const missionUpd = await this.update({
|
|
61
|
+
id: missionID,
|
|
62
|
+
deletedAt: Date.now(),
|
|
63
|
+
});
|
|
64
|
+
await this.checkIfCurrentUserMissionChanged(missionUpd);
|
|
65
|
+
return missionUpd;
|
|
66
|
+
}
|
|
67
|
+
async list() {
|
|
68
|
+
const mis = await this.API.__proto__.ListMissions();
|
|
69
|
+
return mis.items.filter((m) => !m.deletedAt);
|
|
70
|
+
}
|
|
71
|
+
// async canHardDeteleMission(missionID: string): Promise<boolean> {
|
|
72
|
+
// const events = (
|
|
73
|
+
// await this.API.ListEvents({ ownerID: { eq: missionID } })
|
|
74
|
+
// ).items;
|
|
75
|
+
// if (events.length > 0) {
|
|
76
|
+
// return false;
|
|
77
|
+
// }
|
|
78
|
+
// const comments = (
|
|
79
|
+
// await this.API.ListComments({ ownerID: { eq: missionID } })
|
|
80
|
+
// ).items;
|
|
81
|
+
// if (comments.length > 0) {
|
|
82
|
+
// return false;
|
|
83
|
+
// }
|
|
84
|
+
// const affectations =
|
|
85
|
+
// await this.affectationService.getAffectationsFromMissionID(
|
|
86
|
+
// missionID,
|
|
87
|
+
// );
|
|
88
|
+
// if (affectations.length > 0) {
|
|
89
|
+
// return false;
|
|
90
|
+
// }
|
|
91
|
+
// return true;
|
|
92
|
+
// }
|
|
93
|
+
async hardDeleteMission(missionID) {
|
|
94
|
+
return this.API.__proto__.DeleteMission({ id: missionID });
|
|
95
|
+
}
|
|
96
|
+
getActivatedMissions(missions) {
|
|
97
|
+
const activated = [];
|
|
98
|
+
missions.map(async (mission) => {
|
|
99
|
+
const isActivated = mission.groups && mission.groups.includes(ProfileStatus.ACTIVE);
|
|
100
|
+
if (isActivated) {
|
|
101
|
+
activated.push(mission);
|
|
102
|
+
}
|
|
103
|
+
});
|
|
104
|
+
return activated;
|
|
105
|
+
}
|
|
106
|
+
async getMissionsForZone(zoneID) {
|
|
107
|
+
return (await this.API.__proto__.MissionsByZone(zoneID)).items.filter((mis) => !mis.deletedAt);
|
|
108
|
+
}
|
|
109
|
+
async getMissionsForSpace(spaceID) {
|
|
110
|
+
return this.API.__proto__.MissionsBySpace(spaceID).then((missions) => missions.items);
|
|
111
|
+
}
|
|
112
|
+
activateMission(mis) {
|
|
113
|
+
if (mis &&
|
|
114
|
+
(!mis.groups || !mis.groups.includes(ProfileStatus.ACTIVE))) {
|
|
115
|
+
const groups = mis.groups ? mis.groups : [];
|
|
116
|
+
groups.push(ProfileStatus.ACTIVE);
|
|
117
|
+
this.update({ id: mis.id, groups });
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
async getMissionsByTemplate(templateID) {
|
|
121
|
+
return (await this.API.__proto__.MissionsByTemplate(templateID)).items.filter((mis) => !mis.deletedAt);
|
|
122
|
+
}
|
|
123
|
+
async getMission(missionID) {
|
|
124
|
+
return this.API.__proto__.GetMission(missionID);
|
|
125
|
+
}
|
|
126
|
+
async getMissionsByZoneByRole(zoneID, role) {
|
|
127
|
+
return (await this.API.__proto__.MissionsByZoneByRole(zoneID, { eq: role }, null, { deletedAt: { attributeExists: false } }, 200)).items;
|
|
128
|
+
}
|
|
129
|
+
async checkIfCurrentUserMissionChanged(changedMission) {
|
|
130
|
+
if (this.currentUserID === changedMission.userID) {
|
|
131
|
+
this.currentMissionsUpdated.next(true);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
async instantMissionsOfCurrent(currentUserID) {
|
|
135
|
+
this.currentUserID = currentUserID;
|
|
136
|
+
let missions = await this.getMissionsFromUserID(currentUserID);
|
|
137
|
+
/** Filter to keep only available missions */
|
|
138
|
+
missions = missions.filter((mission) => {
|
|
139
|
+
const hasExpired = dateHasExpired(mission.endDateTime);
|
|
140
|
+
/** Update this.lastExpiredMission */
|
|
141
|
+
if (hasExpired) {
|
|
142
|
+
const lastExpiredDate = this.lastExpiredMission
|
|
143
|
+
? new Date(this.lastExpiredMission.endDateTime)
|
|
144
|
+
: null;
|
|
145
|
+
const dateExpired = new Date(mission.endDateTime);
|
|
146
|
+
if (!lastExpiredDate || dateExpired > lastExpiredDate) {
|
|
147
|
+
this.lastExpiredMission = mission;
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
return !hasExpired;
|
|
151
|
+
});
|
|
152
|
+
if (missions.some((mis) => mis.role === RoleStatus.VISITOR_MUSEUM) && missions.length > 0) {
|
|
153
|
+
// workflow for VISITOR_MUSEUM
|
|
154
|
+
return missions;
|
|
155
|
+
}
|
|
156
|
+
/** Keep only started missions */
|
|
157
|
+
let nextMissionDate = null;
|
|
158
|
+
missions = missions.filter((mission) => {
|
|
159
|
+
const started = mission.startDateTime
|
|
160
|
+
? dateHasExpired(mission.startDateTime)
|
|
161
|
+
: true;
|
|
162
|
+
/** Update next mission to start */
|
|
163
|
+
if (!started) {
|
|
164
|
+
const missionDate = new Date(mission.startDateTime);
|
|
165
|
+
if (!nextMissionDate || missionDate < nextMissionDate) {
|
|
166
|
+
this.nextMissionToStart = mission;
|
|
167
|
+
nextMissionDate = missionDate;
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
return started;
|
|
171
|
+
});
|
|
172
|
+
return missions.length > 0 ? missions : null;
|
|
173
|
+
}
|
|
174
|
+
/**
|
|
175
|
+
* Filters the missions that assisted to live of the visit (by comparing the realStartTime of VisitTemplate and connectedAt time)
|
|
176
|
+
* @param template VisitTemplate
|
|
177
|
+
* @param missions Mission[] missions for this visit
|
|
178
|
+
* @returns Mission[] filtered missions
|
|
179
|
+
*/
|
|
180
|
+
filterMissionsAssitedToLiveForTemplate(template, missions) {
|
|
181
|
+
const visitStartTimestamp = template.realStartedAt;
|
|
182
|
+
return missions.filter((mis) => {
|
|
183
|
+
if (!mis.connectedToLiveAt) {
|
|
184
|
+
return false;
|
|
185
|
+
}
|
|
186
|
+
if (mis.connectedToLiveAt.length === 0) {
|
|
187
|
+
return false;
|
|
188
|
+
}
|
|
189
|
+
const lastConnectedAt = mis.connectedToLiveAt[mis.connectedToLiveAt.length - 1];
|
|
190
|
+
const lastConnectedAtTimestamp = DateTime.fromISO(lastConnectedAt).toMillis();
|
|
191
|
+
return lastConnectedAtTimestamp > visitStartTimestamp;
|
|
192
|
+
});
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
MissionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: MissionService, deps: [{ token: 'currentAPIService' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
196
|
+
MissionService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: MissionService, providedIn: "root" });
|
|
197
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: MissionService, decorators: [{
|
|
198
|
+
type: Injectable,
|
|
199
|
+
args: [{
|
|
200
|
+
providedIn: "root",
|
|
201
|
+
}]
|
|
202
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
203
|
+
type: Inject,
|
|
204
|
+
args: ['currentAPIService']
|
|
205
|
+
}] }]; } });
|
|
206
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mission.service.js","sourceRoot":"","sources":["../../../../../../projects/ngx-smarterplan-core/src/lib/services/models/mission.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable class-methods-use-this */\r\nimport { Inject, Injectable } from \"@angular/core\";\r\nimport { Subject } from \"rxjs\";\r\nimport { dateHasExpired } from \"../../helpers.service\";\r\nimport { Mission, Organisation, Profile, ProfileStatus, RoleStatus, VisitTemplate } from \"../../types.service\";\r\nimport { DateTime } from \"luxon\";\r\n\r\n@Injectable({\r\n    providedIn: \"root\",\r\n})\r\nexport class MissionService {\r\n    currentMissionsUpdated = new Subject<boolean>();\r\n\r\n    lastExpiredMission: Mission;\r\n\r\n    nextMissionToStart: Mission;\r\n\r\n    currentUserID: string;\r\n\r\n    API: any; //AWS\r\n\r\n    constructor(\r\n        // private affectationService: AffectationService,\r\n        @Inject('currentAPIService') apiInjected: any\r\n    ) {\r\n        this.API = apiInjected;\r\n    }\r\n\r\n    async getMissionsFromUserID(userID: string): Promise<Mission[]> {\r\n        return this.API.__proto__.MissionsByUser(userID).then((missions) => {\r\n            return missions.items.filter((mis) => !mis.deletedAt);\r\n        });\r\n    }\r\n\r\n    async getMissionsByOrderedOrganisation(\r\n        orderedOrgID: string,\r\n    ): Promise<Mission[]> {\r\n        return this.API.__proto__.MissionsByOrderedOrganisation(orderedOrgID).then(\r\n            (response) => response.items,\r\n        );\r\n    }\r\n\r\n    async getMissionsByOrganisation(orgID: string): Promise<Mission[]> {\r\n        return this.API.__proto__.MissionsByOrganisation(orgID).then(\r\n            (response) => response.items,\r\n        );\r\n    }\r\n\r\n    async create(mission: Mission): Promise<Mission> {\r\n        const updMission = await this.API.__proto__.CreateMission(mission);\r\n        console.log(\"Mission created\", updMission);\r\n        await this.checkIfCurrentUserMissionChanged(updMission);\r\n        return updMission;\r\n    }\r\n\r\n    async update(mission: any): Promise<Mission> {\r\n        const updMission = await this.API.__proto__.UpdateMission(mission);\r\n        console.log(\"Mission updated\", updMission);\r\n        await this.checkIfCurrentUserMissionChanged(updMission);\r\n        return updMission;\r\n    }\r\n\r\n    async assertRoleForUserInOrg(\r\n        user: Profile,\r\n        org: Organisation,\r\n        role: RoleStatus,\r\n    ): Promise<boolean> {\r\n        return this.getMissionsFromUserID(user.id).then((missions) => {\r\n            if (missions) {\r\n                const misOrg = missions.filter((mis) => {\r\n                    return mis.organisationID === org.id && mis.role === role;\r\n                });\r\n                return misOrg.length > 0;\r\n            }\r\n            return false;\r\n        });\r\n    }\r\n\r\n    async getMissionsByOrderedOrganisationBySpace(\r\n        ordOrgID: string,\r\n        spaceID: string,\r\n    ): Promise<Mission[]> {\r\n        return this.API.__proto__.MissionsByOrderedOrganisationBySpace(ordOrgID, {\r\n            eq: spaceID,\r\n        }).then((mis) => mis.items);\r\n    }\r\n\r\n    async softDeleteMission(missionID: string): Promise<Mission> {\r\n        // const hardDelete = await this.canHardDeteleMission(mission.id);\r\n        // if (hardDelete) {\r\n        //     return this.hardDeleteMission(mission.id);\r\n        // }\r\n        console.log(\"Soft Deleting mission\");\r\n        const missionUpd = await this.update({\r\n            id: missionID,\r\n            deletedAt: Date.now(),\r\n        });\r\n        await this.checkIfCurrentUserMissionChanged(missionUpd);\r\n        return missionUpd;\r\n    }\r\n\r\n    async list(): Promise<Mission[]> {\r\n        const mis = await this.API.__proto__.ListMissions();\r\n        return mis.items.filter((m) => !m.deletedAt);\r\n    }\r\n\r\n    // async canHardDeteleMission(missionID: string): Promise<boolean> {\r\n    //     const events = (\r\n    //         await this.API.ListEvents({ ownerID: { eq: missionID } })\r\n    //     ).items;\r\n    //     if (events.length > 0) {\r\n    //         return false;\r\n    //     }\r\n    //     const comments = (\r\n    //         await this.API.ListComments({ ownerID: { eq: missionID } })\r\n    //     ).items;\r\n    //     if (comments.length > 0) {\r\n    //         return false;\r\n    //     }\r\n    //     const affectations =\r\n    //         await this.affectationService.getAffectationsFromMissionID(\r\n    //             missionID,\r\n    //         );\r\n    //     if (affectations.length > 0) {\r\n    //         return false;\r\n    //     }\r\n    //     return true;\r\n    // }\r\n\r\n    async hardDeleteMission(missionID: string): Promise<Mission> {\r\n        return this.API.__proto__.DeleteMission({ id: missionID });\r\n    }\r\n\r\n    getActivatedMissions(missions: Mission[]): Mission[] {\r\n        const activated = [];\r\n        missions.map(async (mission) => {\r\n            const isActivated =\r\n                mission.groups && mission.groups.includes(ProfileStatus.ACTIVE);\r\n            if (isActivated) {\r\n                activated.push(mission);\r\n            }\r\n        });\r\n        return activated;\r\n    }\r\n\r\n    async getMissionsForZone(zoneID: string): Promise<Mission[]> {\r\n        return (await this.API.__proto__.MissionsByZone(zoneID)).items.filter(\r\n            (mis) => !mis.deletedAt,\r\n        );\r\n    }\r\n\r\n    async getMissionsForSpace(spaceID: string): Promise<Mission[]> {\r\n        return this.API.__proto__.MissionsBySpace(spaceID).then((missions) => missions.items);\r\n    }\r\n\r\n    activateMission(mis: Mission) {\r\n        if (\r\n            mis &&\r\n            (!mis.groups || !mis.groups.includes(ProfileStatus.ACTIVE))\r\n        ) {\r\n            const groups = mis.groups ? mis.groups : [];\r\n            groups.push(ProfileStatus.ACTIVE);\r\n            this.update({ id: mis.id, groups });\r\n        }\r\n    }\r\n\r\n    async getMissionsByTemplate(templateID: string): Promise<Mission[]> {\r\n        return (await this.API.__proto__.MissionsByTemplate(templateID)).items.filter(\r\n            (mis) => !mis.deletedAt,\r\n        );\r\n    }\r\n\r\n    async getMission(missionID: string): Promise<Mission> {\r\n        return this.API.__proto__.GetMission(missionID);\r\n    }\r\n\r\n    async getMissionsByZoneByRole(\r\n        zoneID: string,\r\n        role: RoleStatus,\r\n    ): Promise<Mission[]> {\r\n        return (\r\n            await this.API.__proto__.MissionsByZoneByRole(\r\n                zoneID,\r\n                { eq: role },\r\n                null,\r\n                { deletedAt: { attributeExists: false } },\r\n                200,\r\n            )\r\n        ).items;\r\n    }\r\n\r\n    async checkIfCurrentUserMissionChanged(changedMission: Mission) {\r\n        if (this.currentUserID === changedMission.userID) {\r\n            this.currentMissionsUpdated.next(true);\r\n        }\r\n    }\r\n\r\n    async instantMissionsOfCurrent(\r\n        currentUserID: string,\r\n    ): Promise<Mission[] | null> {\r\n        this.currentUserID = currentUserID;\r\n        let missions = await this.getMissionsFromUserID(currentUserID);\r\n\r\n        /** Filter to keep only available missions */\r\n        missions = missions.filter((mission) => {\r\n            const hasExpired = dateHasExpired(mission.endDateTime);\r\n\r\n            /** Update this.lastExpiredMission */\r\n            if (hasExpired) {\r\n                const lastExpiredDate = this.lastExpiredMission\r\n                    ? new Date(this.lastExpiredMission.endDateTime)\r\n                    : null;\r\n                const dateExpired = new Date(mission.endDateTime);\r\n                if (!lastExpiredDate || dateExpired > lastExpiredDate) {\r\n                    this.lastExpiredMission = mission;\r\n                }\r\n            }\r\n            return !hasExpired;\r\n        });\r\n\r\n        if (missions.some((mis) => mis.role === RoleStatus.VISITOR_MUSEUM) && missions.length > 0) {\r\n            // workflow for VISITOR_MUSEUM\r\n            return missions;\r\n        }\r\n        /** Keep only started missions */\r\n        let nextMissionDate = null;\r\n        missions = missions.filter((mission) => {\r\n            const started = mission.startDateTime\r\n                ? dateHasExpired(mission.startDateTime)\r\n                : true;\r\n            /** Update next mission to start */\r\n            if (!started) {\r\n                const missionDate = new Date(mission.startDateTime);\r\n                if (!nextMissionDate || missionDate < nextMissionDate) {\r\n                    this.nextMissionToStart = mission;\r\n                    nextMissionDate = missionDate;\r\n                }\r\n            }\r\n            return started;\r\n        });\r\n        return missions.length > 0 ? missions : null;\r\n    }\r\n\r\n    /**\r\n     * Filters the missions that assisted to live of the visit (by comparing the realStartTime of VisitTemplate and connectedAt time)\r\n     * @param template VisitTemplate \r\n     * @param missions Mission[] missions for this visit\r\n     * @returns Mission[] filtered missions\r\n     */\r\n    filterMissionsAssitedToLiveForTemplate(template: VisitTemplate, missions: Mission[]): Mission[] {\r\n        const visitStartTimestamp = template.realStartedAt;\r\n        return missions.filter((mis) => {\r\n            if (!mis.connectedToLiveAt) {\r\n                return false;\r\n            }\r\n            if (mis.connectedToLiveAt.length === 0) {\r\n                return false;\r\n            }\r\n            const lastConnectedAt = mis.connectedToLiveAt[mis.connectedToLiveAt.length - 1];\r\n            const lastConnectedAtTimestamp = DateTime.fromISO(lastConnectedAt).toMillis();\r\n            return lastConnectedAtTimestamp > visitStartTimestamp;\r\n        });\r\n    }\r\n}\r\n"]}
|