@smarterplan/ngx-smarterplan-admin 0.1.27

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.
Files changed (46) hide show
  1. package/README.md +24 -0
  2. package/esm2020/lib/admin/admin.component.mjs +33 -0
  3. package/esm2020/lib/chevron/chevron.component.mjs +19 -0
  4. package/esm2020/lib/guest-link/guest-link.component.mjs +62 -0
  5. package/esm2020/lib/guide.guard.mjs +25 -0
  6. package/esm2020/lib/name-from-id.pipe.mjs +29 -0
  7. package/esm2020/lib/ngx-smarterplan-admin-routing.module.mjs +47 -0
  8. package/esm2020/lib/ngx-smarterplan-admin.module.mjs +90 -0
  9. package/esm2020/lib/ngx-smarterplan-admin.service.mjs +14 -0
  10. package/esm2020/lib/organisation/organisation.component.mjs +166 -0
  11. package/esm2020/lib/sp-admin.guard.mjs +31 -0
  12. package/esm2020/lib/user/detail-organisation/detail-organisation.component.mjs +160 -0
  13. package/esm2020/lib/user/form-mission/form-mission.component.mjs +205 -0
  14. package/esm2020/lib/user/form-organisation/form-organisation.component.mjs +125 -0
  15. package/esm2020/lib/user/user-mission-form/user-mission-form.component.mjs +106 -0
  16. package/esm2020/lib/user/user.component.mjs +325 -0
  17. package/esm2020/lib/visitor/create-batch/create-batch.component.mjs +108 -0
  18. package/esm2020/lib/visitor/template/template.component.mjs +219 -0
  19. package/esm2020/lib/visitor/visitor.component.mjs +284 -0
  20. package/esm2020/public-api.mjs +6 -0
  21. package/esm2020/smarterplan-ngx-smarterplan-admin.mjs +5 -0
  22. package/fesm2015/smarterplan-ngx-smarterplan-admin.mjs +2026 -0
  23. package/fesm2015/smarterplan-ngx-smarterplan-admin.mjs.map +1 -0
  24. package/fesm2020/smarterplan-ngx-smarterplan-admin.mjs +1921 -0
  25. package/fesm2020/smarterplan-ngx-smarterplan-admin.mjs.map +1 -0
  26. package/lib/admin/admin.component.d.ts +13 -0
  27. package/lib/chevron/chevron.component.d.ts +9 -0
  28. package/lib/guest-link/guest-link.component.d.ts +20 -0
  29. package/lib/guide.guard.d.ts +11 -0
  30. package/lib/name-from-id.pipe.d.ts +11 -0
  31. package/lib/ngx-smarterplan-admin-routing.module.d.ts +7 -0
  32. package/lib/ngx-smarterplan-admin.module.d.ts +26 -0
  33. package/lib/ngx-smarterplan-admin.service.d.ts +6 -0
  34. package/lib/organisation/organisation.component.d.ts +53 -0
  35. package/lib/sp-admin.guard.d.ts +12 -0
  36. package/lib/user/detail-organisation/detail-organisation.component.d.ts +39 -0
  37. package/lib/user/form-mission/form-mission.component.d.ts +54 -0
  38. package/lib/user/form-organisation/form-organisation.component.d.ts +32 -0
  39. package/lib/user/user-mission-form/user-mission-form.component.d.ts +28 -0
  40. package/lib/user/user.component.d.ts +100 -0
  41. package/lib/visitor/create-batch/create-batch.component.d.ts +23 -0
  42. package/lib/visitor/template/template.component.d.ts +52 -0
  43. package/lib/visitor/visitor.component.d.ts +65 -0
  44. package/package.json +39 -0
  45. package/public-api.d.ts +2 -0
  46. package/smarterplan-ngx-smarterplan-admin.d.ts +5 -0
@@ -0,0 +1,284 @@
1
+ import { Component, ViewChild } from '@angular/core';
2
+ import { RoleStatus, ProfileEntity, EmailStatus } from 'ngx-smarterplan-core';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "ngx-smarterplan-core";
5
+ import * as i2 from "@angular/router";
6
+ import * as i3 from "@ngx-translate/core";
7
+ import * as i4 from "@ng-bootstrap/ng-bootstrap";
8
+ import * as i5 from "../chevron/chevron.component";
9
+ import * as i6 from "./template/template.component";
10
+ import * as i7 from "./create-batch/create-batch.component";
11
+ import * as i8 from "@angular/common";
12
+ import * as i9 from "@angular/forms";
13
+ export class VisitorComponent {
14
+ constructor(userService, missionService, router, translate, spaceService, zoneService, modalService, templateService) {
15
+ this.userService = userService;
16
+ this.missionService = missionService;
17
+ this.router = router;
18
+ this.translate = translate;
19
+ this.spaceService = spaceService;
20
+ this.zoneService = zoneService;
21
+ this.modalService = modalService;
22
+ this.templateService = templateService;
23
+ this.editing = false;
24
+ this.creating = false;
25
+ this.isAddingBatch = false;
26
+ this.allZoneTemplatesMap = new Map(); // zone=>its templates
27
+ this.allTemplateMissionsMap = new Map(); // templateID, its derived Missions
28
+ this.detailsForZones = [];
29
+ this.csvHeaders = [
30
+ "email",
31
+ "user_status",
32
+ "zone",
33
+ "location",
34
+ "start_date_time",
35
+ "end_date_time",
36
+ "access_level",
37
+ ];
38
+ this.loading = false;
39
+ this.toDuplicate = false;
40
+ this.userService.isChanged.subscribe(() => this.setup());
41
+ }
42
+ ngOnInit() {
43
+ this.setup();
44
+ }
45
+ setup() {
46
+ this.setupUser();
47
+ this.setZonesTemplates();
48
+ }
49
+ async setZonesTemplates() {
50
+ if (!this.currentOrg) {
51
+ return;
52
+ }
53
+ this.loading = true;
54
+ this.allZoneTemplatesMap = new Map();
55
+ this.allTemplateMissionsMap = new Map();
56
+ let locations = this.spaceService.locationsForUser;
57
+ if (locations.length === 0) {
58
+ locations = await this.spaceService.getLocationsForCurrentUser();
59
+ }
60
+ await Promise.all(locations.map(async (space) => {
61
+ let zones = await this.zoneService.getZonesBySpace(space.id);
62
+ zones = zones.filter((zone) => zone.isMuseumVisitZone);
63
+ await Promise.all(zones.map(async (zone) => {
64
+ const visitorsMissions = await this.missionService.getMissionsByZoneByRole(zone.id, RoleStatus.VISITOR_MUSEUM);
65
+ let templates = await this.templateService.getTemplatesByZone(zone.id);
66
+ templates = templates.filter((template) => !template.deletedAt);
67
+ templates = templates.sort((a, b) =>
68
+ // @ts-ignore
69
+ // eslint-disable-next-line prettier/prettier
70
+ new Date(b.startDateTime) - new Date(a.startDateTime));
71
+ for (const template of templates) {
72
+ const missionsFromTemplate = visitorsMissions.filter((mis) => mis.templateMissionID === template.id);
73
+ this.allTemplateMissionsMap.set(template.id, missionsFromTemplate);
74
+ }
75
+ this.allZoneTemplatesMap.set(zone, templates);
76
+ }));
77
+ }));
78
+ // sort list by zone name alphabetically
79
+ this.allZoneTemplatesMapFiltered =
80
+ new Map([...this.allZoneTemplatesMap.entries()].sort((a, b) => a[0].name.localeCompare(b[0].name)));
81
+ this.loading = false;
82
+ }
83
+ setupUser() {
84
+ this.currentOrg = this.userService.currentOrganisation();
85
+ }
86
+ onCreateTemplate() {
87
+ this.creating = true;
88
+ }
89
+ async onDeleteMission(mission) {
90
+ await this.missionService.softDeleteMission(mission.id);
91
+ this.setZonesTemplates();
92
+ }
93
+ async onEditTemplate(template) {
94
+ this.editing = true;
95
+ this.templateToEdit = template;
96
+ }
97
+ onUpdatedEvent(isAdded) {
98
+ this.editing = false;
99
+ this.templateToEdit = null;
100
+ this.isAddingBatch = false;
101
+ this.chosenTemplate = null;
102
+ if (isAdded) {
103
+ this.setZonesTemplates();
104
+ }
105
+ }
106
+ async onUpdatedTemplate(template) {
107
+ this.loading = true;
108
+ this.editing = false;
109
+ this.templateToEdit = null;
110
+ if (template) {
111
+ if (this.toDuplicate) {
112
+ // create new template
113
+ delete template.id;
114
+ await this.templateService.create(template);
115
+ this.toDuplicate = false;
116
+ await this.setZonesTemplates();
117
+ return;
118
+ }
119
+ await this.templateService.update(template);
120
+ await this.setZonesTemplates();
121
+ // update related Missions
122
+ const missionsForTemplate = await this.missionService.getMissionsByTemplate(template.id);
123
+ await Promise.all(missionsForTemplate.map(async (mission) => {
124
+ const missionUpdate = {
125
+ id: mission.id,
126
+ level: template.level,
127
+ startDateTime: template.startDateTime,
128
+ endDateTime: template.endDateTime,
129
+ locale: template.locale,
130
+ zoneID: template.zoneID,
131
+ spaceID: template.spaceID,
132
+ hashtags: template.hashtags,
133
+ };
134
+ await this.missionService.update(missionUpdate);
135
+ }));
136
+ }
137
+ this.loading = false;
138
+ }
139
+ async onCreatedTemplate(template) {
140
+ this.loading = true;
141
+ this.creating = false;
142
+ if (template) {
143
+ await this.templateService.create(template);
144
+ this.setZonesTemplates();
145
+ }
146
+ this.loading = false;
147
+ }
148
+ onToggleMissionsForZone(zoneID) {
149
+ if (this.detailsForZones.includes(zoneID)) {
150
+ const index = this.detailsForZones.indexOf(zoneID);
151
+ this.detailsForZones.splice(index, 1);
152
+ }
153
+ else {
154
+ this.detailsForZones.push(zoneID);
155
+ }
156
+ }
157
+ onToggleTemplateDetails(template) {
158
+ this.templateShowing =
159
+ this.templateShowing === template.id ? null : template.id;
160
+ }
161
+ onAddNewTemplateToZone(zone) {
162
+ this.zoneIDForNewTemplate = zone.id;
163
+ this.creating = true;
164
+ }
165
+ async onArchiveTemplate(template) {
166
+ const message = this.translate.instant("confirm.archiveTemplate");
167
+ if (window.confirm(message)) {
168
+ const missionsToDelete = this.allTemplateMissionsMap.get(template.id);
169
+ await Promise.all(missionsToDelete.map(async (mission) => {
170
+ await this.missionService.softDeleteMission(mission.id);
171
+ }));
172
+ await this.templateService.softDelete(template.id);
173
+ this.setZonesTemplates();
174
+ }
175
+ }
176
+ onGenerateBatch(template) {
177
+ this.chosenTemplate = template;
178
+ this.isAddingBatch = true;
179
+ }
180
+ generateCSVUsers(template) {
181
+ const data = [];
182
+ for (const mission of this.allTemplateMissionsMap.get(template.id)) {
183
+ const user = new ProfileEntity(mission.user);
184
+ data.push([
185
+ user.email,
186
+ mission.user.status,
187
+ mission.zone.name,
188
+ mission.space.name,
189
+ mission.startDateTime,
190
+ mission.endDateTime,
191
+ mission.level,
192
+ ]);
193
+ }
194
+ return data;
195
+ }
196
+ async onSendInvitation(template) {
197
+ await Promise.all(this.allTemplateMissionsMap
198
+ .get(template.id)
199
+ .map(async (mission) => {
200
+ if (mission.emailStatus !== EmailStatus.SENT) {
201
+ await this.missionService.update({
202
+ id: mission.id,
203
+ emailStatus: EmailStatus.CREATION_TO_DELIVER,
204
+ });
205
+ }
206
+ }));
207
+ }
208
+ async onSendUpdate(template) {
209
+ await Promise.all(this.allTemplateMissionsMap
210
+ .get(template.id)
211
+ .map(async (mission) => {
212
+ await this.missionService.update({
213
+ id: mission.id,
214
+ emailStatus: EmailStatus.UPDATE_TO_DELIVER,
215
+ });
216
+ }));
217
+ }
218
+ async onCancelTemplate(template) {
219
+ const message = this.translate.instant("confirm.cancelTemplate");
220
+ if (window.confirm(message)) {
221
+ await Promise.all(this.allTemplateMissionsMap
222
+ .get(template.id)
223
+ .map(async (mission) => {
224
+ await this.missionService.update({
225
+ id: mission.id,
226
+ emailStatus: EmailStatus.CANCELLATION_TO_DELIVER,
227
+ deletedAt: Date.now(),
228
+ });
229
+ }));
230
+ }
231
+ }
232
+ applyResultsSearchBar(results) {
233
+ this.allZoneTemplatesMapFiltered = results || this.allZoneTemplatesMap;
234
+ }
235
+ onDeleteUsers(mis) {
236
+ this.currentTemplateUsers = [];
237
+ for (const mission of this.allTemplateMissionsMap.get(mis.id)) {
238
+ this.currentTemplateUsers.push({
239
+ mission,
240
+ profile: new ProfileEntity(mission.user),
241
+ checked: false,
242
+ index: this.allTemplateMissionsMap.get(mis.id).indexOf(mission),
243
+ });
244
+ }
245
+ this.modalRef = this.modalService.open(this.modal);
246
+ }
247
+ /**
248
+ * Deletes mission of the user and checks if can hard delete the Profile (no other missions)
249
+ */
250
+ async onDeleteChosen() {
251
+ const listToDelete = this.currentTemplateUsers.filter((object) => object.checked);
252
+ await Promise.all(listToDelete.map(async (object) => {
253
+ await this.missionService.softDeleteMission(object.mission.id);
254
+ await this.userService.softDeleteUser(object.profile.id);
255
+ this.allTemplateMissionsMap
256
+ .get(object.mission.templateMissionID)
257
+ .splice(object.index, 1);
258
+ }));
259
+ this.modalRef.close();
260
+ }
261
+ onDuplicateTemplate(template) {
262
+ this.editing = true;
263
+ this.templateToEdit = template;
264
+ this.toDuplicate = true;
265
+ }
266
+ async onCleanTimeTemplate(template) {
267
+ await this.templateService.update({
268
+ id: template.id,
269
+ realEndedAt: null,
270
+ realStartedAt: null
271
+ });
272
+ await this.setZonesTemplates();
273
+ }
274
+ }
275
+ VisitorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: VisitorComponent, deps: [{ token: i1.BaseUserService }, { token: i1.MissionService }, { token: i2.Router }, { token: i3.TranslateService }, { token: i1.SpaceService }, { token: i1.ZoneService }, { token: i4.NgbModal }, { token: i1.TemplateService }], target: i0.ɵɵFactoryTarget.Component });
276
+ VisitorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: VisitorComponent, selector: "lib-visitor", viewQueries: [{ propertyName: "modal", first: true, predicate: ["deleteUsers"], descendants: true }], ngImport: i0, template: "<div class=\"dashboard-tab\">\r\n <div class=\"header-dashboard-tab\">\r\n <h3>{{'Museum Visitors' | translate}}</h3>\r\n <!-- <app-search-bar [searchable]=\"allZoneTemplatesMap\" objectType=\"TEMPLATE\"\r\n (searchEvent)=\"applyResultsSearchBar($event)\">\r\n </app-search-bar> -->\r\n <hr>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-8 col-lg-7\">\r\n <div class=\"row ml-0 mb-2\">\r\n <h4 class=\"header-small\">{{'Itineraries' | translate}}</h4>\r\n </div>\r\n <div class=\"row ml-0 mb-2\" *ngIf=\"!editing && !creating\">\r\n <button class=\"btn btn-outline-primary rounded-pill ml-3 add-button\" (click)=\"onCreateTemplate()\">\r\n {{'Create template for new itinerary' | translate}}</button>\r\n </div>\r\n <div class=\"d-flex justify-content-center\" *ngIf=\"loading\">\r\n <lib-loader></lib-loader>\r\n </div>\r\n <div *ngIf=\"!editing && !creating\">\r\n <ul class=\"list-group list-group-flush\">\r\n <li class=\"list-group-item\" *ngFor=\"let pair of allZoneTemplatesMapFiltered | keyvalue\">\r\n <h4>{{pair.key.name}} <span style=\"font-size:0.8em\"> - {{pair.key.space.name}}</span> </h4>\r\n <div class=\"d-flex justify-content-between align-items-center\"\r\n (click)=\"onToggleMissionsForZone(pair.key.id)\">\r\n <ng-container *ngIf=\"pair.value.length <= 1\">\r\n {{pair.value.length}} {{'visit template found' | translate}}\r\n </ng-container>\r\n <ng-container *ngIf=\"pair.value.length > 1\">\r\n {{pair.value.length}} {{'visit templates found' | translate}}\r\n </ng-container>\r\n <lib-chevron [conditionShowing]=\"detailsForZones.includes(pair.key.id)\"></lib-chevron>\r\n\r\n </div>\r\n <div *ngIf=\"detailsForZones.includes(pair.key.id)\">\r\n <button class=\"btn btn-outline-primary rounded-pill mt-3 mb-3 ml-2\"\r\n (click)=\"onAddNewTemplateToZone(pair.key)\">{{'Add new template' | translate}}</button>\r\n\r\n <ul class=\"container-fluid list-group list-group-flush\">\r\n <li class=\"list-group-item\" *ngFor=\"let template of pair.value\">\r\n <div class=\"d-flex justify-content-between align-items-center\"\r\n (click)=\"onToggleTemplateDetails(template)\">\r\n <h5>{{template.title}}</h5>\r\n <lib-chevron [conditionShowing]=\"templateShowing === template.id\"></lib-chevron>\r\n </div>\r\n <div *ngIf=\"templateShowing === template.id\">\r\n <ul class=\"list-group list-group-flush\">\r\n <li class=\"list-group-item bg-transparent\">{{'Description' | translate }}:\r\n {{ template.description}}</li>\r\n <li class=\"list-group-item bg-transparent\">{{'Language' | translate }}:\r\n {{ template.locale ? template.locale : ('Not applicable' | translate)}}</li>\r\n <li class=\"list-group-item bg-transparent\"\r\n *ngIf=\"template.hashtags && template.hashtags.length> 0\">\r\n {{'Hashtags' | translate}}:\r\n <ul class=\"keywordsDisplay no-border\">\r\n <div class=\"keywordsdisplayContainer\"\r\n *ngIf=\"template.hashtags.length> 0\">\r\n <li class=\"keywordsItem\" *ngFor=\"let hashtag of template.hashtags\">{{\r\n hashtag | hashtagFromID | async }}</li>\r\n </div>\r\n </ul>\r\n </li>\r\n <li class=\"list-group-item bg-transparent\">{{'Access level' | translate }}:\r\n {{ template.level}}</li>\r\n <li class=\"list-group-item bg-transparent\">{{'Planned at' | translate }} :\r\n {{ template.startDateTime ? (template.startDateTime |\r\n timeDateString:\"day_time_zone\" | async) :\r\n \"No data\" | translate }} - \r\n {{ template.endDateTime ?\r\n (template.endDateTime | timeDateString:\"day_time_zone\" | async) : \"No data\" |\r\n translate}}\r\n </li>\r\n <li class=\"list-group-item bg-transparent\">\r\n {{'Effective start/end time ' | translate }}: \r\n {{ template.realStartedAt ? (template.realStartedAt |\r\n timeDateString:\"day_time_zone\" | async) : ('No data' | translate)}} / \r\n {{ template.realEndedAt ? (template.realEndedAt |\r\n timeDateString:\"day_time_zone\" | async) : ('No data' | translate)}}\r\n </li>\r\n <li class=\"list-group-item bg-transparent\"\r\n *ngIf=\"allTemplateMissionsMap.get(template.id)\">\r\n {{'Visitors created' |\r\n translate}}:{{allTemplateMissionsMap.get(template.id).length}}\r\n <lib-csv-export [headers]=\"csvHeaders\" [title]=\"'Users'\"\r\n buttonLabel=\"Download users\" [rowsInput]=\"generateCSVUsers(template)\">\r\n </lib-csv-export>\r\n </li>\r\n \r\n </ul>\r\n <div class=\"action-button-container\">\r\n <div class=\"d-inline-block mr-2 action-button\" ngbDropdown\r\n #myDrop=\"ngbDropdown\">\r\n <button class=\"btn btn-label-file rounded-pill\" id=\"dropdownManual\"\r\n ngbDropdownToggle>{{'Manage users' |\r\n translate}}</button>\r\n <div ngbDropdownMenu aria-labelledby=\"dropdownManual\">\r\n <button (click)=\"onGenerateBatch(template)\" ngbDropdownItem>\r\n {{'Create users from this template' | translate}}</button>\r\n <button (click)=\"onSendInvitation(template)\" ngbDropdownItem>\r\n {{'Send invitation to all users' | translate}}\r\n </button>\r\n <button (click)=\"onSendUpdate(template)\" ngbDropdownItem>\r\n {{'Send update to all users' | translate}}\r\n </button>\r\n <button (click)=\"onDeleteUsers(template)\" ngbDropdownItem>\r\n {{'Remove users' | translate}}\r\n </button>\r\n </div>\r\n </div>\r\n <div class=\"d-inline-block mr-2 action-button\" ngbDropdown\r\n #myDrop2=\"ngbDropdown\">\r\n <button class=\"btn btn-label-file rounded-pill\" id=\"dropdown2\"\r\n ngbDropdownToggle>{{'Manage template' |\r\n translate}}</button>\r\n <div ngbDropdownMenu aria-labelledby=\"dropdown2\">\r\n <button (click)=\"onEditTemplate(template)\" ngbDropdownItem>\r\n {{'Edit template' | translate}}</button>\r\n <button (click)=\"onCleanTimeTemplate(template)\" ngbDropdownItem>\r\n {{'Clean effective times' | translate}}\r\n </button>\r\n <button (click)=\"onArchiveTemplate(template)\" ngbDropdownItem>\r\n {{'Archive template' | translate}}\r\n </button>\r\n <button (click)=\"onCancelTemplate(template)\" ngbDropdownItem>\r\n {{'Cancel visit' | translate}}\r\n </button>\r\n <button (click)=\"onDuplicateTemplate(template)\" ngbDropdownItem>\r\n {{'Duplicate' | translate}}\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n <!-- <button type=\"button\" class=\"btn btn-primary rounded-pill mr-2 ml-auto\"\r\n (click)=\"onEdit(mis)\">\r\n {{'Edit' | translate}}</button>\r\n <button class=\"btn btn-primary rounded-pill mt-3 mb-3 ml-auto\"\r\n (click)=\"onArchiveTemplate(mis)\">{{'Archive' | translate}}</button> -->\r\n </div>\r\n\r\n </li>\r\n </ul>\r\n </div>\r\n </li>\r\n </ul>\r\n </div>\r\n <div *ngIf=\"editing\">\r\n <lib-template [editTemplate]=\"templateToEdit\" [currentOrg]=\"currentOrg\"\r\n (updatedTemplate)=\"onUpdatedTemplate($event)\"></lib-template>\r\n </div>\r\n <div *ngIf=\"creating\">\r\n <lib-template [currentOrg]=\"currentOrg\" [zoneID]=\"zoneIDForNewTemplate\"\r\n (createdTemplate)=\"onCreatedTemplate($event)\"></lib-template>\r\n </div>\r\n </div>\r\n <div class=\"col-md-4 col-lg-5\" *ngIf=\"isAddingBatch\">\r\n <lib-create-batch [template]=\"chosenTemplate\" (createdMissions)=\"onUpdatedEvent($event)\"></lib-create-batch>\r\n </div>\r\n <ng-template #deleteUsers let-modal>\r\n <div class=\"modal-header\">\r\n <h4 class=\"modal-title\" id=\"modal-basic-title\">{{\"Delete users\" | translate}}\r\n </h4>\r\n <button type=\"button\" class=\"close\" aria-label=\"Close\" (click)=\"modalRef.close()\">\r\n <span aria-hidden=\"true\">&times;</span>\r\n </button>\r\n </div>\r\n <div class=\"modal-body\">\r\n <div class=\"column align-items-center\">\r\n <div class=\"row\" style=\"padding: 0 1.25rem;\">\r\n <ul class=\"container-fluid list-group list-group-flush\">\r\n <li class=\"list-group-item\" *ngFor=\"let object of currentTemplateUsers\">\r\n <input type=\"checkbox\" [(ngModel)]=\"object.checked\"> {{object.profile.email}}\r\n </li>\r\n </ul>\r\n </div>\r\n\r\n <div class=\"row\" style=\"padding: 1.25rem;\">\r\n <button class=\"btn btn-outline-primary rounded-pill mr-4\" (click)=\"onDeleteChosen()\">{{\"Apply\" |\r\n translate}}\r\n </button>\r\n <button class=\"btn btn-outline-primary rounded-pill\" (click)=\"modalRef.close()\">{{\"Cancel\" |\r\n translate}}\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </div>\r\n</div>", styles: [".add-button{width:-moz-fit-content;width:fit-content;margin-left:.5rem}li.ml-4{margin-left:3rem}.action-button-container{display:flex;justify-content:space-evenly}.action-button-container .action-button{width:145px!important}\n"], components: [{ type: i1.LoaderComponent, selector: "lib-loader" }, { type: i5.ChevronComponent, selector: "lib-chevron", inputs: ["conditionShowing"] }, { type: i1.CsvExportComponent, selector: "lib-csv-export", inputs: ["headers", "rowsInput", "getRows", "title", "buttonLabel"] }, { type: i6.TemplateComponent, selector: "lib-template", inputs: ["currentOrg", "editTemplate", "zoneID"], outputs: ["updatedTemplate", "createdTemplate"] }, { type: i7.CreateBatchComponent, selector: "lib-create-batch", inputs: ["template"], outputs: ["createdMissions"] }], directives: [{ type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.NgbDropdown, selector: "[ngbDropdown]", inputs: ["autoClose", "dropdownClass", "open", "placement", "container", "display"], outputs: ["openChange"], exportAs: ["ngbDropdown"] }, { type: i4.NgbDropdownToggle, selector: "[ngbDropdownToggle]" }, { type: i4.NgbDropdownMenu, selector: "[ngbDropdownMenu]" }, { type: i4.NgbDropdownItem, selector: "[ngbDropdownItem]", inputs: ["disabled"] }, { type: i9.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "translate": i3.TranslatePipe, "keyvalue": i8.KeyValuePipe, "async": i8.AsyncPipe, "hashtagFromID": i1.HashtagFromIdPipe, "timeDateString": i1.TimeDateToLocalStringPipe } });
277
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: VisitorComponent, decorators: [{
278
+ type: Component,
279
+ args: [{ selector: 'lib-visitor', template: "<div class=\"dashboard-tab\">\r\n <div class=\"header-dashboard-tab\">\r\n <h3>{{'Museum Visitors' | translate}}</h3>\r\n <!-- <app-search-bar [searchable]=\"allZoneTemplatesMap\" objectType=\"TEMPLATE\"\r\n (searchEvent)=\"applyResultsSearchBar($event)\">\r\n </app-search-bar> -->\r\n <hr>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-8 col-lg-7\">\r\n <div class=\"row ml-0 mb-2\">\r\n <h4 class=\"header-small\">{{'Itineraries' | translate}}</h4>\r\n </div>\r\n <div class=\"row ml-0 mb-2\" *ngIf=\"!editing && !creating\">\r\n <button class=\"btn btn-outline-primary rounded-pill ml-3 add-button\" (click)=\"onCreateTemplate()\">\r\n {{'Create template for new itinerary' | translate}}</button>\r\n </div>\r\n <div class=\"d-flex justify-content-center\" *ngIf=\"loading\">\r\n <lib-loader></lib-loader>\r\n </div>\r\n <div *ngIf=\"!editing && !creating\">\r\n <ul class=\"list-group list-group-flush\">\r\n <li class=\"list-group-item\" *ngFor=\"let pair of allZoneTemplatesMapFiltered | keyvalue\">\r\n <h4>{{pair.key.name}} <span style=\"font-size:0.8em\"> - {{pair.key.space.name}}</span> </h4>\r\n <div class=\"d-flex justify-content-between align-items-center\"\r\n (click)=\"onToggleMissionsForZone(pair.key.id)\">\r\n <ng-container *ngIf=\"pair.value.length <= 1\">\r\n {{pair.value.length}} {{'visit template found' | translate}}\r\n </ng-container>\r\n <ng-container *ngIf=\"pair.value.length > 1\">\r\n {{pair.value.length}} {{'visit templates found' | translate}}\r\n </ng-container>\r\n <lib-chevron [conditionShowing]=\"detailsForZones.includes(pair.key.id)\"></lib-chevron>\r\n\r\n </div>\r\n <div *ngIf=\"detailsForZones.includes(pair.key.id)\">\r\n <button class=\"btn btn-outline-primary rounded-pill mt-3 mb-3 ml-2\"\r\n (click)=\"onAddNewTemplateToZone(pair.key)\">{{'Add new template' | translate}}</button>\r\n\r\n <ul class=\"container-fluid list-group list-group-flush\">\r\n <li class=\"list-group-item\" *ngFor=\"let template of pair.value\">\r\n <div class=\"d-flex justify-content-between align-items-center\"\r\n (click)=\"onToggleTemplateDetails(template)\">\r\n <h5>{{template.title}}</h5>\r\n <lib-chevron [conditionShowing]=\"templateShowing === template.id\"></lib-chevron>\r\n </div>\r\n <div *ngIf=\"templateShowing === template.id\">\r\n <ul class=\"list-group list-group-flush\">\r\n <li class=\"list-group-item bg-transparent\">{{'Description' | translate }}:\r\n {{ template.description}}</li>\r\n <li class=\"list-group-item bg-transparent\">{{'Language' | translate }}:\r\n {{ template.locale ? template.locale : ('Not applicable' | translate)}}</li>\r\n <li class=\"list-group-item bg-transparent\"\r\n *ngIf=\"template.hashtags && template.hashtags.length> 0\">\r\n {{'Hashtags' | translate}}:\r\n <ul class=\"keywordsDisplay no-border\">\r\n <div class=\"keywordsdisplayContainer\"\r\n *ngIf=\"template.hashtags.length> 0\">\r\n <li class=\"keywordsItem\" *ngFor=\"let hashtag of template.hashtags\">{{\r\n hashtag | hashtagFromID | async }}</li>\r\n </div>\r\n </ul>\r\n </li>\r\n <li class=\"list-group-item bg-transparent\">{{'Access level' | translate }}:\r\n {{ template.level}}</li>\r\n <li class=\"list-group-item bg-transparent\">{{'Planned at' | translate }} :\r\n {{ template.startDateTime ? (template.startDateTime |\r\n timeDateString:\"day_time_zone\" | async) :\r\n \"No data\" | translate }} - \r\n {{ template.endDateTime ?\r\n (template.endDateTime | timeDateString:\"day_time_zone\" | async) : \"No data\" |\r\n translate}}\r\n </li>\r\n <li class=\"list-group-item bg-transparent\">\r\n {{'Effective start/end time ' | translate }}: \r\n {{ template.realStartedAt ? (template.realStartedAt |\r\n timeDateString:\"day_time_zone\" | async) : ('No data' | translate)}} / \r\n {{ template.realEndedAt ? (template.realEndedAt |\r\n timeDateString:\"day_time_zone\" | async) : ('No data' | translate)}}\r\n </li>\r\n <li class=\"list-group-item bg-transparent\"\r\n *ngIf=\"allTemplateMissionsMap.get(template.id)\">\r\n {{'Visitors created' |\r\n translate}}:{{allTemplateMissionsMap.get(template.id).length}}\r\n <lib-csv-export [headers]=\"csvHeaders\" [title]=\"'Users'\"\r\n buttonLabel=\"Download users\" [rowsInput]=\"generateCSVUsers(template)\">\r\n </lib-csv-export>\r\n </li>\r\n \r\n </ul>\r\n <div class=\"action-button-container\">\r\n <div class=\"d-inline-block mr-2 action-button\" ngbDropdown\r\n #myDrop=\"ngbDropdown\">\r\n <button class=\"btn btn-label-file rounded-pill\" id=\"dropdownManual\"\r\n ngbDropdownToggle>{{'Manage users' |\r\n translate}}</button>\r\n <div ngbDropdownMenu aria-labelledby=\"dropdownManual\">\r\n <button (click)=\"onGenerateBatch(template)\" ngbDropdownItem>\r\n {{'Create users from this template' | translate}}</button>\r\n <button (click)=\"onSendInvitation(template)\" ngbDropdownItem>\r\n {{'Send invitation to all users' | translate}}\r\n </button>\r\n <button (click)=\"onSendUpdate(template)\" ngbDropdownItem>\r\n {{'Send update to all users' | translate}}\r\n </button>\r\n <button (click)=\"onDeleteUsers(template)\" ngbDropdownItem>\r\n {{'Remove users' | translate}}\r\n </button>\r\n </div>\r\n </div>\r\n <div class=\"d-inline-block mr-2 action-button\" ngbDropdown\r\n #myDrop2=\"ngbDropdown\">\r\n <button class=\"btn btn-label-file rounded-pill\" id=\"dropdown2\"\r\n ngbDropdownToggle>{{'Manage template' |\r\n translate}}</button>\r\n <div ngbDropdownMenu aria-labelledby=\"dropdown2\">\r\n <button (click)=\"onEditTemplate(template)\" ngbDropdownItem>\r\n {{'Edit template' | translate}}</button>\r\n <button (click)=\"onCleanTimeTemplate(template)\" ngbDropdownItem>\r\n {{'Clean effective times' | translate}}\r\n </button>\r\n <button (click)=\"onArchiveTemplate(template)\" ngbDropdownItem>\r\n {{'Archive template' | translate}}\r\n </button>\r\n <button (click)=\"onCancelTemplate(template)\" ngbDropdownItem>\r\n {{'Cancel visit' | translate}}\r\n </button>\r\n <button (click)=\"onDuplicateTemplate(template)\" ngbDropdownItem>\r\n {{'Duplicate' | translate}}\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n <!-- <button type=\"button\" class=\"btn btn-primary rounded-pill mr-2 ml-auto\"\r\n (click)=\"onEdit(mis)\">\r\n {{'Edit' | translate}}</button>\r\n <button class=\"btn btn-primary rounded-pill mt-3 mb-3 ml-auto\"\r\n (click)=\"onArchiveTemplate(mis)\">{{'Archive' | translate}}</button> -->\r\n </div>\r\n\r\n </li>\r\n </ul>\r\n </div>\r\n </li>\r\n </ul>\r\n </div>\r\n <div *ngIf=\"editing\">\r\n <lib-template [editTemplate]=\"templateToEdit\" [currentOrg]=\"currentOrg\"\r\n (updatedTemplate)=\"onUpdatedTemplate($event)\"></lib-template>\r\n </div>\r\n <div *ngIf=\"creating\">\r\n <lib-template [currentOrg]=\"currentOrg\" [zoneID]=\"zoneIDForNewTemplate\"\r\n (createdTemplate)=\"onCreatedTemplate($event)\"></lib-template>\r\n </div>\r\n </div>\r\n <div class=\"col-md-4 col-lg-5\" *ngIf=\"isAddingBatch\">\r\n <lib-create-batch [template]=\"chosenTemplate\" (createdMissions)=\"onUpdatedEvent($event)\"></lib-create-batch>\r\n </div>\r\n <ng-template #deleteUsers let-modal>\r\n <div class=\"modal-header\">\r\n <h4 class=\"modal-title\" id=\"modal-basic-title\">{{\"Delete users\" | translate}}\r\n </h4>\r\n <button type=\"button\" class=\"close\" aria-label=\"Close\" (click)=\"modalRef.close()\">\r\n <span aria-hidden=\"true\">&times;</span>\r\n </button>\r\n </div>\r\n <div class=\"modal-body\">\r\n <div class=\"column align-items-center\">\r\n <div class=\"row\" style=\"padding: 0 1.25rem;\">\r\n <ul class=\"container-fluid list-group list-group-flush\">\r\n <li class=\"list-group-item\" *ngFor=\"let object of currentTemplateUsers\">\r\n <input type=\"checkbox\" [(ngModel)]=\"object.checked\"> {{object.profile.email}}\r\n </li>\r\n </ul>\r\n </div>\r\n\r\n <div class=\"row\" style=\"padding: 1.25rem;\">\r\n <button class=\"btn btn-outline-primary rounded-pill mr-4\" (click)=\"onDeleteChosen()\">{{\"Apply\" |\r\n translate}}\r\n </button>\r\n <button class=\"btn btn-outline-primary rounded-pill\" (click)=\"modalRef.close()\">{{\"Cancel\" |\r\n translate}}\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </div>\r\n</div>", styles: [".add-button{width:-moz-fit-content;width:fit-content;margin-left:.5rem}li.ml-4{margin-left:3rem}.action-button-container{display:flex;justify-content:space-evenly}.action-button-container .action-button{width:145px!important}\n"] }]
280
+ }], ctorParameters: function () { return [{ type: i1.BaseUserService }, { type: i1.MissionService }, { type: i2.Router }, { type: i3.TranslateService }, { type: i1.SpaceService }, { type: i1.ZoneService }, { type: i4.NgbModal }, { type: i1.TemplateService }]; }, propDecorators: { modal: [{
281
+ type: ViewChild,
282
+ args: ["deleteUsers"]
283
+ }] } });
284
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"visitor.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-smarterplan-admin/src/lib/visitor/visitor.component.ts","../../../../../projects/ngx-smarterplan-admin/src/lib/visitor/visitor.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { NgbModal } from '@ng-bootstrap/ng-bootstrap';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport {\r\n    Mission, Zone, Organisation, BaseUserService, MissionService,\r\n    SpaceService, ZoneService, RoleStatus, ProfileEntity, EmailStatus, TemplateService, VisitTemplate, sortAlphabeticallyOnName\r\n} from 'ngx-smarterplan-core';\r\n\r\n@Component({\r\n    selector: 'lib-visitor',\r\n    templateUrl: './visitor.component.html',\r\n    styleUrls: ['./visitor.component.scss']\r\n})\r\nexport class VisitorComponent implements OnInit {\r\n    @ViewChild(\"deleteUsers\") modal;\r\n\r\n    chosenTemplate: VisitTemplate;\r\n\r\n    allOrderedMissions: Mission[];\r\n\r\n    currentOrg: Organisation;\r\n\r\n    templateToEdit: VisitTemplate;\r\n\r\n    editing = false;\r\n\r\n    creating = false;\r\n\r\n    zoneIDForNewTemplate: string;\r\n\r\n    isAddingBatch = false;\r\n\r\n    allZoneTemplatesMap: Map<Zone, VisitTemplate[]> = new Map(); // zone=>its templates\r\n\r\n    allZoneTemplatesMapFiltered: Map<Zone, VisitTemplate[]>;\r\n\r\n    allTemplateMissionsMap: Map<string, Mission[]> = new Map(); // templateID, its derived Missions\r\n\r\n    detailsForZones: string[] = [];\r\n\r\n    csvHeaders = [\r\n        \"email\",\r\n        \"user_status\",\r\n        \"zone\",\r\n        \"location\",\r\n        \"start_date_time\",\r\n        \"end_date_time\",\r\n        \"access_level\",\r\n    ];\r\n\r\n    templateShowing: string;\r\n\r\n    loading = false;\r\n\r\n    currentTemplateUsers;\r\n\r\n    modalRef;\r\n\r\n    toDuplicate = false;\r\n\r\n    constructor(\r\n        private userService: BaseUserService,\r\n        private missionService: MissionService,\r\n        private router: Router,\r\n        private translate: TranslateService,\r\n        private spaceService: SpaceService,\r\n        private zoneService: ZoneService,\r\n        private modalService: NgbModal,\r\n        private templateService: TemplateService,\r\n    ) {\r\n        this.userService.isChanged.subscribe(() => this.setup());\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this.setup();\r\n    }\r\n\r\n    setup() {\r\n        this.setupUser();\r\n        this.setZonesTemplates();\r\n    }\r\n\r\n    async setZonesTemplates() {\r\n        if (!this.currentOrg) {\r\n            return;\r\n        }\r\n        this.loading = true;\r\n        this.allZoneTemplatesMap = new Map();\r\n        this.allTemplateMissionsMap = new Map();\r\n        let locations = this.spaceService.locationsForUser;\r\n        if (locations.length === 0) {\r\n            locations = await this.spaceService.getLocationsForCurrentUser();\r\n        }\r\n        await Promise.all(\r\n            locations.map(async (space) => {\r\n                let zones = await this.zoneService.getZonesBySpace(space.id);\r\n                zones = zones.filter((zone) => zone.isMuseumVisitZone);\r\n                await Promise.all(\r\n                    zones.map(async (zone) => {\r\n                        const visitorsMissions =\r\n                            await this.missionService.getMissionsByZoneByRole(\r\n                                zone.id,\r\n                                RoleStatus.VISITOR_MUSEUM,\r\n                            );\r\n                        let templates =\r\n                            await this.templateService.getTemplatesByZone(zone.id);\r\n                        templates = templates.filter((template) => !template.deletedAt);\r\n                        templates = templates.sort(\r\n                            (a, b) =>\r\n                                // @ts-ignore\r\n                                // eslint-disable-next-line prettier/prettier\r\n                                new Date(b.startDateTime) - new Date(a.startDateTime),\r\n                        );\r\n                        for (const template of templates) {\r\n                            const missionsFromTemplate =\r\n                                visitorsMissions.filter(\r\n                                    (mis) =>\r\n                                        mis.templateMissionID === template.id,\r\n                                );\r\n\r\n                            this.allTemplateMissionsMap.set(\r\n                                template.id,\r\n                                missionsFromTemplate,\r\n                            );\r\n                        }\r\n                        this.allZoneTemplatesMap.set(zone, templates);\r\n                    }),\r\n                );\r\n            }),\r\n        );\r\n        // sort list by zone name alphabetically\r\n        this.allZoneTemplatesMapFiltered =\r\n            new Map([...this.allZoneTemplatesMap.entries()].sort((a, b) => a[0].name.localeCompare(b[0].name)));\r\n        this.loading = false;\r\n    }\r\n\r\n    setupUser() {\r\n        this.currentOrg = this.userService.currentOrganisation();\r\n    }\r\n\r\n    onCreateTemplate() {\r\n        this.creating = true;\r\n    }\r\n\r\n    async onDeleteMission(mission: Mission) {\r\n        await this.missionService.softDeleteMission(mission.id);\r\n        this.setZonesTemplates();\r\n    }\r\n\r\n    async onEditTemplate(template: VisitTemplate) {\r\n        this.editing = true;\r\n        this.templateToEdit = template;\r\n    }\r\n\r\n    onUpdatedEvent(isAdded: Mission[]) {\r\n        this.editing = false;\r\n        this.templateToEdit = null;\r\n        this.isAddingBatch = false;\r\n        this.chosenTemplate = null;\r\n        if (isAdded) {\r\n            this.setZonesTemplates();\r\n        }\r\n    }\r\n\r\n    async onUpdatedTemplate(template: VisitTemplate) {\r\n        this.loading = true;\r\n        this.editing = false;\r\n        this.templateToEdit = null;\r\n        if (template) {\r\n            if (this.toDuplicate) {\r\n                // create new template\r\n                delete template.id;\r\n                await this.templateService.create(template);\r\n                this.toDuplicate = false;\r\n                await this.setZonesTemplates();\r\n                return;\r\n            }\r\n            await this.templateService.update(template);\r\n            await this.setZonesTemplates();\r\n            // update related Missions\r\n            const missionsForTemplate =\r\n                await this.missionService.getMissionsByTemplate(template.id);\r\n            await Promise.all(\r\n                missionsForTemplate.map(async (mission) => {\r\n                    const missionUpdate = {\r\n                        id: mission.id,\r\n                        level: template.level,\r\n                        startDateTime: template.startDateTime,\r\n                        endDateTime: template.endDateTime,\r\n                        locale: template.locale,\r\n                        zoneID: template.zoneID,\r\n                        spaceID: template.spaceID,\r\n                        hashtags: template.hashtags,\r\n                    };\r\n                    await this.missionService.update(missionUpdate);\r\n                }),\r\n            );\r\n        }\r\n\r\n        this.loading = false;\r\n    }\r\n\r\n    async onCreatedTemplate(template: VisitTemplate) {\r\n        this.loading = true;\r\n        this.creating = false;\r\n        if (template) {\r\n            await this.templateService.create(template);\r\n            this.setZonesTemplates();\r\n        }\r\n        this.loading = false;\r\n    }\r\n\r\n    onToggleMissionsForZone(zoneID: string) {\r\n        if (this.detailsForZones.includes(zoneID)) {\r\n            const index = this.detailsForZones.indexOf(zoneID);\r\n            this.detailsForZones.splice(index, 1);\r\n        } else {\r\n            this.detailsForZones.push(zoneID);\r\n        }\r\n    }\r\n\r\n    onToggleTemplateDetails(template) {\r\n        this.templateShowing =\r\n            this.templateShowing === template.id ? null : template.id;\r\n    }\r\n\r\n    onAddNewTemplateToZone(zone: Zone) {\r\n        this.zoneIDForNewTemplate = zone.id;\r\n        this.creating = true;\r\n    }\r\n\r\n    async onArchiveTemplate(template: VisitTemplate) {\r\n        const message = this.translate.instant(\"confirm.archiveTemplate\");\r\n        if (window.confirm(message)) {\r\n            const missionsToDelete = this.allTemplateMissionsMap.get(template.id);\r\n            await Promise.all(\r\n                missionsToDelete.map(async (mission) => {\r\n                    await this.missionService.softDeleteMission(mission.id);\r\n                }),\r\n            );\r\n            await this.templateService.softDelete(template.id);\r\n            this.setZonesTemplates();\r\n        }\r\n    }\r\n\r\n    onGenerateBatch(template: VisitTemplate) {\r\n        this.chosenTemplate = template;\r\n        this.isAddingBatch = true;\r\n    }\r\n\r\n    generateCSVUsers(template: VisitTemplate) {\r\n        const data = [];\r\n        for (const mission of this.allTemplateMissionsMap.get(template.id)) {\r\n            const user = new ProfileEntity(mission.user);\r\n            data.push([\r\n                user.email,\r\n                mission.user.status,\r\n                mission.zone.name,\r\n                mission.space.name,\r\n                mission.startDateTime,\r\n                mission.endDateTime,\r\n                mission.level,\r\n            ]);\r\n        }\r\n        return data;\r\n    }\r\n\r\n    async onSendInvitation(template: VisitTemplate) {\r\n        await Promise.all(\r\n            this.allTemplateMissionsMap\r\n                .get(template.id)\r\n                .map(async (mission) => {\r\n                    if (mission.emailStatus !== EmailStatus.SENT) {\r\n                        await this.missionService.update({\r\n                            id: mission.id,\r\n                            emailStatus: EmailStatus.CREATION_TO_DELIVER,\r\n                        });\r\n                    }\r\n                }),\r\n        );\r\n    }\r\n\r\n    async onSendUpdate(template: VisitTemplate) {\r\n        await Promise.all(\r\n            this.allTemplateMissionsMap\r\n                .get(template.id)\r\n                .map(async (mission) => {\r\n                    await this.missionService.update({\r\n                        id: mission.id,\r\n                        emailStatus: EmailStatus.UPDATE_TO_DELIVER,\r\n                    });\r\n                }),\r\n        );\r\n    }\r\n\r\n    async onCancelTemplate(template: VisitTemplate) {\r\n        const message = this.translate.instant(\"confirm.cancelTemplate\");\r\n        if (window.confirm(message)) {\r\n            await Promise.all(\r\n                this.allTemplateMissionsMap\r\n                    .get(template.id)\r\n                    .map(async (mission) => {\r\n                        await this.missionService.update({\r\n                            id: mission.id,\r\n                            emailStatus: EmailStatus.CANCELLATION_TO_DELIVER,\r\n                            deletedAt: Date.now(),\r\n                        });\r\n                    }),\r\n            );\r\n        }\r\n    }\r\n\r\n    applyResultsSearchBar(results) {\r\n        this.allZoneTemplatesMapFiltered = results || this.allZoneTemplatesMap;\r\n    }\r\n\r\n    onDeleteUsers(mis: VisitTemplate) {\r\n        this.currentTemplateUsers = [];\r\n        for (const mission of this.allTemplateMissionsMap.get(mis.id)) {\r\n            this.currentTemplateUsers.push({\r\n                mission,\r\n                profile: new ProfileEntity(mission.user),\r\n                checked: false,\r\n                index: this.allTemplateMissionsMap.get(mis.id).indexOf(mission),\r\n            });\r\n        }\r\n        this.modalRef = this.modalService.open(this.modal);\r\n    }\r\n\r\n    /**\r\n     * Deletes mission of the user and checks if can hard delete the Profile (no other missions)\r\n     */\r\n    async onDeleteChosen() {\r\n        const listToDelete = this.currentTemplateUsers.filter(\r\n            (object) => object.checked,\r\n        );\r\n        await Promise.all(\r\n            listToDelete.map(async (object) => {\r\n                await this.missionService.softDeleteMission(object.mission.id);\r\n                await this.userService.softDeleteUser(object.profile.id);\r\n\r\n                this.allTemplateMissionsMap\r\n                    .get(object.mission.templateMissionID)\r\n                    .splice(object.index, 1);\r\n            }),\r\n        );\r\n        this.modalRef.close();\r\n    }\r\n\r\n    onDuplicateTemplate(template: VisitTemplate) {\r\n        this.editing = true;\r\n        this.templateToEdit = template;\r\n        this.toDuplicate = true;\r\n    }\r\n\r\n    async onCleanTimeTemplate(template: VisitTemplate) {\r\n        await this.templateService.update({\r\n            id: template.id,\r\n            realEndedAt: null,\r\n            realStartedAt: null\r\n        });\r\n        await this.setZonesTemplates();\r\n    }\r\n\r\n}\r\n","<div class=\"dashboard-tab\">\r\n    <div class=\"header-dashboard-tab\">\r\n        <h3>{{'Museum Visitors' | translate}}</h3>\r\n        <!-- <app-search-bar [searchable]=\"allZoneTemplatesMap\" objectType=\"TEMPLATE\"\r\n            (searchEvent)=\"applyResultsSearchBar($event)\">\r\n        </app-search-bar> -->\r\n        <hr>\r\n    </div>\r\n    <div class=\"row\">\r\n        <div class=\"col-md-8 col-lg-7\">\r\n            <div class=\"row ml-0 mb-2\">\r\n                <h4 class=\"header-small\">{{'Itineraries' | translate}}</h4>\r\n            </div>\r\n            <div class=\"row ml-0 mb-2\" *ngIf=\"!editing && !creating\">\r\n                <button class=\"btn btn-outline-primary rounded-pill ml-3 add-button\" (click)=\"onCreateTemplate()\">\r\n                    {{'Create template for new itinerary' | translate}}</button>\r\n            </div>\r\n            <div class=\"d-flex justify-content-center\" *ngIf=\"loading\">\r\n                <lib-loader></lib-loader>\r\n            </div>\r\n            <div *ngIf=\"!editing && !creating\">\r\n                <ul class=\"list-group list-group-flush\">\r\n                    <li class=\"list-group-item\" *ngFor=\"let pair of allZoneTemplatesMapFiltered | keyvalue\">\r\n                        <h4>{{pair.key.name}} <span style=\"font-size:0.8em\"> - {{pair.key.space.name}}</span> </h4>\r\n                        <div class=\"d-flex justify-content-between align-items-center\"\r\n                            (click)=\"onToggleMissionsForZone(pair.key.id)\">\r\n                            <ng-container *ngIf=\"pair.value.length <= 1\">\r\n                                {{pair.value.length}} {{'visit template found' | translate}}\r\n                            </ng-container>\r\n                            <ng-container *ngIf=\"pair.value.length > 1\">\r\n                                {{pair.value.length}} {{'visit templates found' | translate}}\r\n                            </ng-container>\r\n                            <lib-chevron [conditionShowing]=\"detailsForZones.includes(pair.key.id)\"></lib-chevron>\r\n\r\n                        </div>\r\n                        <div *ngIf=\"detailsForZones.includes(pair.key.id)\">\r\n                            <button class=\"btn btn-outline-primary rounded-pill mt-3 mb-3 ml-2\"\r\n                                (click)=\"onAddNewTemplateToZone(pair.key)\">{{'Add new template' | translate}}</button>\r\n\r\n                            <ul class=\"container-fluid list-group list-group-flush\">\r\n                                <li class=\"list-group-item\" *ngFor=\"let template of pair.value\">\r\n                                    <div class=\"d-flex justify-content-between align-items-center\"\r\n                                        (click)=\"onToggleTemplateDetails(template)\">\r\n                                        <h5>{{template.title}}</h5>\r\n                                        <lib-chevron [conditionShowing]=\"templateShowing === template.id\"></lib-chevron>\r\n                                    </div>\r\n                                    <div *ngIf=\"templateShowing === template.id\">\r\n                                        <ul class=\"list-group list-group-flush\">\r\n                                            <li class=\"list-group-item bg-transparent\">{{'Description' | translate }}:\r\n                                                {{ template.description}}</li>\r\n                                            <li class=\"list-group-item bg-transparent\">{{'Language' | translate }}:\r\n                                                {{ template.locale ? template.locale : ('Not applicable' | translate)}}</li>\r\n                                            <li class=\"list-group-item bg-transparent\"\r\n                                                *ngIf=\"template.hashtags && template.hashtags.length> 0\">\r\n                                                {{'Hashtags' | translate}}:\r\n                                                <ul class=\"keywordsDisplay no-border\">\r\n                                                    <div class=\"keywordsdisplayContainer\"\r\n                                                        *ngIf=\"template.hashtags.length> 0\">\r\n                                                        <li class=\"keywordsItem\" *ngFor=\"let hashtag of template.hashtags\">{{\r\n                                                            hashtag | hashtagFromID | async }}</li>\r\n                                                    </div>\r\n                                                </ul>\r\n                                            </li>\r\n                                            <li class=\"list-group-item bg-transparent\">{{'Access level' | translate }}:\r\n                                                {{ template.level}}</li>\r\n                                            <li class=\"list-group-item bg-transparent\">{{'Planned at' | translate }} :\r\n                                                {{ template.startDateTime ? (template.startDateTime |\r\n                                                timeDateString:\"day_time_zone\" | async) :\r\n                                                \"No data\" | translate }} - \r\n                                                {{ template.endDateTime ?\r\n                                                (template.endDateTime | timeDateString:\"day_time_zone\" | async) : \"No data\" |\r\n                                                translate}}\r\n                                            </li>\r\n                                            <li class=\"list-group-item bg-transparent\">\r\n                                                {{'Effective start/end time ' | translate }}: \r\n                                                {{ template.realStartedAt ? (template.realStartedAt |\r\n                                                    timeDateString:\"day_time_zone\" | async) : ('No data' | translate)}} / \r\n                                                    {{ template.realEndedAt ? (template.realEndedAt |\r\n                                                        timeDateString:\"day_time_zone\" | async) : ('No data' | translate)}}\r\n                                            </li>\r\n                                            <li class=\"list-group-item bg-transparent\"\r\n                                                *ngIf=\"allTemplateMissionsMap.get(template.id)\">\r\n                                                {{'Visitors created' |\r\n                                                translate}}:{{allTemplateMissionsMap.get(template.id).length}}\r\n                                                <lib-csv-export [headers]=\"csvHeaders\" [title]=\"'Users'\"\r\n                                                    buttonLabel=\"Download users\" [rowsInput]=\"generateCSVUsers(template)\">\r\n                                                </lib-csv-export>\r\n                                            </li>\r\n                                            \r\n                                        </ul>\r\n                                        <div class=\"action-button-container\">\r\n                                            <div class=\"d-inline-block mr-2 action-button\" ngbDropdown\r\n                                                #myDrop=\"ngbDropdown\">\r\n                                                <button class=\"btn btn-label-file rounded-pill\" id=\"dropdownManual\"\r\n                                                    ngbDropdownToggle>{{'Manage users' |\r\n                                                    translate}}</button>\r\n                                                <div ngbDropdownMenu aria-labelledby=\"dropdownManual\">\r\n                                                    <button (click)=\"onGenerateBatch(template)\" ngbDropdownItem>\r\n                                                        {{'Create users from this template' | translate}}</button>\r\n                                                    <button (click)=\"onSendInvitation(template)\" ngbDropdownItem>\r\n                                                        {{'Send invitation to all users' | translate}}\r\n                                                    </button>\r\n                                                    <button (click)=\"onSendUpdate(template)\" ngbDropdownItem>\r\n                                                        {{'Send update to all users' | translate}}\r\n                                                    </button>\r\n                                                    <button (click)=\"onDeleteUsers(template)\" ngbDropdownItem>\r\n                                                        {{'Remove users' | translate}}\r\n                                                    </button>\r\n                                                </div>\r\n                                            </div>\r\n                                            <div class=\"d-inline-block mr-2 action-button\" ngbDropdown\r\n                                                #myDrop2=\"ngbDropdown\">\r\n                                                <button class=\"btn btn-label-file rounded-pill\" id=\"dropdown2\"\r\n                                                    ngbDropdownToggle>{{'Manage template' |\r\n                                                    translate}}</button>\r\n                                                <div ngbDropdownMenu aria-labelledby=\"dropdown2\">\r\n                                                    <button (click)=\"onEditTemplate(template)\" ngbDropdownItem>\r\n                                                        {{'Edit template' | translate}}</button>\r\n                                                    <button (click)=\"onCleanTimeTemplate(template)\" ngbDropdownItem>\r\n                                                        {{'Clean effective times' | translate}}\r\n                                                    </button>\r\n                                                    <button (click)=\"onArchiveTemplate(template)\" ngbDropdownItem>\r\n                                                        {{'Archive template' | translate}}\r\n                                                    </button>\r\n                                                    <button (click)=\"onCancelTemplate(template)\" ngbDropdownItem>\r\n                                                        {{'Cancel visit' | translate}}\r\n                                                    </button>\r\n                                                    <button (click)=\"onDuplicateTemplate(template)\" ngbDropdownItem>\r\n                                                        {{'Duplicate' | translate}}\r\n                                                    </button>\r\n                                                </div>\r\n                                            </div>\r\n                                        </div>\r\n                                        <!-- <button type=\"button\" class=\"btn btn-primary rounded-pill mr-2 ml-auto\"\r\n                                            (click)=\"onEdit(mis)\">\r\n                                            {{'Edit' | translate}}</button>\r\n                                        <button class=\"btn btn-primary rounded-pill mt-3 mb-3 ml-auto\"\r\n                                            (click)=\"onArchiveTemplate(mis)\">{{'Archive' | translate}}</button> -->\r\n                                    </div>\r\n\r\n                                </li>\r\n                            </ul>\r\n                        </div>\r\n                    </li>\r\n                </ul>\r\n            </div>\r\n            <div *ngIf=\"editing\">\r\n                <lib-template [editTemplate]=\"templateToEdit\" [currentOrg]=\"currentOrg\"\r\n                    (updatedTemplate)=\"onUpdatedTemplate($event)\"></lib-template>\r\n            </div>\r\n            <div *ngIf=\"creating\">\r\n                <lib-template [currentOrg]=\"currentOrg\" [zoneID]=\"zoneIDForNewTemplate\"\r\n                    (createdTemplate)=\"onCreatedTemplate($event)\"></lib-template>\r\n            </div>\r\n        </div>\r\n        <div class=\"col-md-4 col-lg-5\" *ngIf=\"isAddingBatch\">\r\n            <lib-create-batch [template]=\"chosenTemplate\" (createdMissions)=\"onUpdatedEvent($event)\"></lib-create-batch>\r\n        </div>\r\n        <ng-template #deleteUsers let-modal>\r\n            <div class=\"modal-header\">\r\n                <h4 class=\"modal-title\" id=\"modal-basic-title\">{{\"Delete users\" | translate}}\r\n                </h4>\r\n                <button type=\"button\" class=\"close\" aria-label=\"Close\" (click)=\"modalRef.close()\">\r\n                    <span aria-hidden=\"true\">&times;</span>\r\n                </button>\r\n            </div>\r\n            <div class=\"modal-body\">\r\n                <div class=\"column align-items-center\">\r\n                    <div class=\"row\" style=\"padding: 0 1.25rem;\">\r\n                        <ul class=\"container-fluid list-group list-group-flush\">\r\n                            <li class=\"list-group-item\" *ngFor=\"let object of currentTemplateUsers\">\r\n                                <input type=\"checkbox\" [(ngModel)]=\"object.checked\"> {{object.profile.email}}\r\n                            </li>\r\n                        </ul>\r\n                    </div>\r\n\r\n                    <div class=\"row\" style=\"padding: 1.25rem;\">\r\n                        <button class=\"btn btn-outline-primary rounded-pill mr-4\" (click)=\"onDeleteChosen()\">{{\"Apply\" |\r\n                            translate}}\r\n                        </button>\r\n                        <button class=\"btn btn-outline-primary rounded-pill\" (click)=\"modalRef.close()\">{{\"Cancel\" |\r\n                            translate}}\r\n                        </button>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </ng-template>\r\n    </div>\r\n</div>"]}
@@ -0,0 +1,6 @@
1
+ /*
2
+ * Public API Surface of ngx-smarterplan-admin
3
+ */
4
+ export * from './lib/ngx-smarterplan-admin.service';
5
+ export * from './lib/ngx-smarterplan-admin.module';
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25neC1zbWFydGVycGxhbi1hZG1pbi9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyxvQ0FBb0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2Ygbmd4LXNtYXJ0ZXJwbGFuLWFkbWluXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvbmd4LXNtYXJ0ZXJwbGFuLWFkbWluLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbmd4LXNtYXJ0ZXJwbGFuLWFkbWluLm1vZHVsZSc7XG4iXX0=
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRlcnBsYW4tbmd4LXNtYXJ0ZXJwbGFuLWFkbWluLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvbmd4LXNtYXJ0ZXJwbGFuLWFkbWluL3NyYy9zbWFydGVycGxhbi1uZ3gtc21hcnRlcnBsYW4tYWRtaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==