@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,106 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { Validators } from '@angular/forms';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/forms";
5
+ import * as i2 from "ngx-smarterplan-core";
6
+ import * as i3 from "@ngx-translate/core";
7
+ import * as i4 from "../form-mission/form-mission.component";
8
+ import * as i5 from "@ng-bootstrap/ng-bootstrap";
9
+ import * as i6 from "@angular/common";
10
+ export class UserMissionFormComponent {
11
+ constructor(fb, userService, translate) {
12
+ this.fb = fb;
13
+ this.userService = userService;
14
+ this.translate = translate;
15
+ this.createForExistingUser = false;
16
+ this.added = new EventEmitter();
17
+ this.working = false;
18
+ }
19
+ ngOnInit() {
20
+ this.onAddNewUserMissionToOrg();
21
+ }
22
+ async onAddNewUserMissionToOrg() {
23
+ this.form = this.fb.group({
24
+ email: [null, [Validators.required]],
25
+ lastName: [""],
26
+ firstName: [""],
27
+ });
28
+ }
29
+ onCancel() {
30
+ this.added.emit(false);
31
+ }
32
+ get email() {
33
+ return this.form.get("email");
34
+ }
35
+ async onSubmit() {
36
+ this.working = true;
37
+ let p;
38
+ try {
39
+ const formValue = this.form.value;
40
+ p = await this.userService.profileForMail(formValue.email);
41
+ if (p) {
42
+ alert("User with this email exists already!");
43
+ this.working = false;
44
+ return;
45
+ }
46
+ try {
47
+ const profile = await this.userService.createUserAWSandProfile(formValue, true);
48
+ console.log("User created!", profile.metadata);
49
+ this.createdUser = profile;
50
+ }
51
+ catch (error) {
52
+ this.working = false;
53
+ alert(this.translate.instant(JSON.stringify(error)));
54
+ return;
55
+ }
56
+ }
57
+ catch (error) {
58
+ console.error(error);
59
+ }
60
+ this.working = false;
61
+ }
62
+ // async updateAllMissionsFromTemplate(missionInput: UpdateMissionInput) {
63
+ // // all missions of this organisation
64
+ // const missionsFromTemplate =
65
+ // await this.missionService.getMissionsByTemplate(
66
+ // this.missionToEdit.id,
67
+ // );
68
+ // await Promise.all(
69
+ // missionsFromTemplate.map(async (mission) => {
70
+ // const missionTemplate = { ...missionInput };
71
+ // if (this.sendUpdate) {
72
+ // missionTemplate.emailStatus = EmailStatus.UPDATE_TO_DELIVER;
73
+ // }
74
+ // missionTemplate.id = mission.id;
75
+ // await this.missionService.update(missionTemplate);
76
+ // }),
77
+ // );
78
+ // }
79
+ async onMissionInput(mission) {
80
+ if (mission) {
81
+ this.missionInput = mission;
82
+ await this.userService.createOrUpdateMissionForOrgWithProperty(this.missionInput, this.missionInput.organisationID);
83
+ this.added.emit(true);
84
+ }
85
+ else {
86
+ this.added.emit(false);
87
+ }
88
+ }
89
+ }
90
+ UserMissionFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: UserMissionFormComponent, deps: [{ token: i1.FormBuilder }, { token: i2.BaseUserService }, { token: i3.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
91
+ UserMissionFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: UserMissionFormComponent, selector: "lib-user-mission-form", inputs: { addToOrganisation: "addToOrganisation", isSP: "isSP", createForExistingUser: "createForExistingUser", currentOrg: "currentOrg" }, outputs: { added: "added" }, ngImport: i0, template: "<div *ngIf=\"form\">\r\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\">\r\n <div id=\"personalInfo\">\r\n <div style=\"margin-top: 1rem;\">\r\n <h4>{{ 'User Personal Information' | translate }}</h4>\r\n </div>\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-4 col-form-label\">{{'Email' | translate}} *</label>\r\n <div class=\"col-sm-8\">\r\n <input type=\"text\" class=\"form-control\" [class.is-invalid]=\"email.invalid && email.touched\" required\r\n formControlName=\"email\">\r\n <div class=\"invalid-feedback\">\r\n {{'An email is required' | translate}}.\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-4 col-form-label\">{{'Last name' | translate}}</label>\r\n <div class=\"col-sm-8\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"lastName\">\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-4 col-form-label\">{{'First name' | translate}}</label>\r\n <div class=\"col-sm-8\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"firstName\">\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"d-flex justify-content-center\" *ngIf=\"working\">\r\n <lib-loader></lib-loader>\r\n </div>\r\n\r\n <div *ngIf=\"createdUser; else waitingForUser\">\r\n <div class=\"alert alert-info\">\r\n {{'User successfully created' | translate}}\r\n </div>\r\n <lib-form-mission [organisationForMission]=\"addToOrganisation\" [userForMissionID]=\"createdUser.id\"\r\n [currentUserOrganisation]=\"currentOrg\" [isSP]=\"isSP\" (addedMissionInput)=\"onMissionInput($event)\">\r\n </lib-form-mission>\r\n </div>\r\n <ng-template #waitingForUser>\r\n <div class=\"action-button-container\">\r\n <button type=\"submit\" class=\"btn btn-outline-primary rounded-pill mr-3 action-button\"\r\n [disabled]=\"working || form.invalid\">{{'Create user' | translate}}</button>\r\n <button type=\"button\" (click)=\"onCancel()\" [disabled]=\"working\"\r\n class=\"btn btn-outline-primary rounded-pill action-button\">{{'Cancel' | translate}}</button>\r\n </div>\r\n <div style=\"margin-top: 1rem;\">\r\n <h4>{{ 'Mission details' | translate }}</h4>\r\n </div>\r\n <ngb-alert type=\"warning\" [dismissible]=\"false\">{{'Please create a user first' | translate}}.</ngb-alert>\r\n\r\n </ng-template>\r\n </form>\r\n</div>", styles: [".form-group{margin:1.5rem 0}.action-button-container{display:flex;justify-content:space-evenly}.action-button-container .action-button{width:145px}\n"], components: [{ type: i2.LoaderComponent, selector: "lib-loader" }, { type: i4.FormMissionComponent, selector: "lib-form-mission", inputs: ["missionToEdit", "organisationForMission", "isSP", "userForMissionID", "currentUserOrganisation"], outputs: ["addedMissionInput"] }, { type: i5.NgbAlert, selector: "ngb-alert", inputs: ["animation", "dismissible", "type"], outputs: ["closed"], exportAs: ["ngbAlert"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }], pipes: { "translate": i3.TranslatePipe } });
92
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: UserMissionFormComponent, decorators: [{
93
+ type: Component,
94
+ args: [{ selector: 'lib-user-mission-form', template: "<div *ngIf=\"form\">\r\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\">\r\n <div id=\"personalInfo\">\r\n <div style=\"margin-top: 1rem;\">\r\n <h4>{{ 'User Personal Information' | translate }}</h4>\r\n </div>\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-4 col-form-label\">{{'Email' | translate}} *</label>\r\n <div class=\"col-sm-8\">\r\n <input type=\"text\" class=\"form-control\" [class.is-invalid]=\"email.invalid && email.touched\" required\r\n formControlName=\"email\">\r\n <div class=\"invalid-feedback\">\r\n {{'An email is required' | translate}}.\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-4 col-form-label\">{{'Last name' | translate}}</label>\r\n <div class=\"col-sm-8\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"lastName\">\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-4 col-form-label\">{{'First name' | translate}}</label>\r\n <div class=\"col-sm-8\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"firstName\">\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"d-flex justify-content-center\" *ngIf=\"working\">\r\n <lib-loader></lib-loader>\r\n </div>\r\n\r\n <div *ngIf=\"createdUser; else waitingForUser\">\r\n <div class=\"alert alert-info\">\r\n {{'User successfully created' | translate}}\r\n </div>\r\n <lib-form-mission [organisationForMission]=\"addToOrganisation\" [userForMissionID]=\"createdUser.id\"\r\n [currentUserOrganisation]=\"currentOrg\" [isSP]=\"isSP\" (addedMissionInput)=\"onMissionInput($event)\">\r\n </lib-form-mission>\r\n </div>\r\n <ng-template #waitingForUser>\r\n <div class=\"action-button-container\">\r\n <button type=\"submit\" class=\"btn btn-outline-primary rounded-pill mr-3 action-button\"\r\n [disabled]=\"working || form.invalid\">{{'Create user' | translate}}</button>\r\n <button type=\"button\" (click)=\"onCancel()\" [disabled]=\"working\"\r\n class=\"btn btn-outline-primary rounded-pill action-button\">{{'Cancel' | translate}}</button>\r\n </div>\r\n <div style=\"margin-top: 1rem;\">\r\n <h4>{{ 'Mission details' | translate }}</h4>\r\n </div>\r\n <ngb-alert type=\"warning\" [dismissible]=\"false\">{{'Please create a user first' | translate}}.</ngb-alert>\r\n\r\n </ng-template>\r\n </form>\r\n</div>", styles: [".form-group{margin:1.5rem 0}.action-button-container{display:flex;justify-content:space-evenly}.action-button-container .action-button{width:145px}\n"] }]
95
+ }], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.BaseUserService }, { type: i3.TranslateService }]; }, propDecorators: { addToOrganisation: [{
96
+ type: Input
97
+ }], isSP: [{
98
+ type: Input
99
+ }], createForExistingUser: [{
100
+ type: Input
101
+ }], currentOrg: [{
102
+ type: Input
103
+ }], added: [{
104
+ type: Output
105
+ }] } });
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-mission-form.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-smarterplan-admin/src/lib/user/user-mission-form/user-mission-form.component.ts","../../../../../../projects/ngx-smarterplan-admin/src/lib/user/user-mission-form/user-mission-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { FormGroup, FormBuilder, Validators, AbstractControl } from '@angular/forms';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Organisation, Mission, Profile, BaseUserService } from 'ngx-smarterplan-core';\r\n\r\n@Component({\r\n  selector: 'lib-user-mission-form',\r\n  templateUrl: './user-mission-form.component.html',\r\n  styleUrls: ['./user-mission-form.component.scss']\r\n})\r\nexport class UserMissionFormComponent implements OnInit {\r\n    \r\n    @Input() addToOrganisation: Organisation;\r\n\r\n    @Input() isSP: boolean;\r\n\r\n    @Input() createForExistingUser = false;\r\n\r\n    form: FormGroup;\r\n\r\n    @Input() currentOrg: Organisation;\r\n\r\n    @Output() added = new EventEmitter<boolean>();\r\n\r\n    working = false;\r\n\r\n    missionInput: Mission;\r\n\r\n    createdUser: Profile;\r\n\r\n    constructor(\r\n        private fb: FormBuilder,\r\n        private userService: BaseUserService,\r\n        private translate: TranslateService,\r\n    ) {}\r\n\r\n    ngOnInit() {\r\n        this.onAddNewUserMissionToOrg();\r\n    }\r\n\r\n    async onAddNewUserMissionToOrg() {\r\n        this.form = this.fb.group({\r\n            email: [null, [Validators.required]],\r\n            lastName: [\"\"],\r\n            firstName: [\"\"],\r\n        });\r\n    }\r\n\r\n    onCancel() {\r\n        this.added.emit(false);\r\n    }\r\n\r\n    get email(): AbstractControl {\r\n        return this.form.get(\"email\");\r\n    }\r\n\r\n    async onSubmit() {\r\n        this.working = true;\r\n        let p: Profile;\r\n        try {\r\n            const formValue = this.form.value;\r\n            p = await this.userService.profileForMail(formValue.email);\r\n            if (p) {\r\n                alert(\"User with this email exists already!\");\r\n                this.working = false;\r\n                return;\r\n            }\r\n            try {\r\n                const profile = await this.userService.createUserAWSandProfile(\r\n                    formValue,\r\n                    true,\r\n                );\r\n                console.log(\"User created!\", profile.metadata);\r\n                this.createdUser = profile;\r\n            } catch (error) {\r\n                this.working = false;\r\n                alert(this.translate.instant(JSON.stringify(error)));\r\n                return;\r\n            }\r\n        } catch (error) {\r\n            console.error(error);\r\n        }\r\n        this.working = false;\r\n    }\r\n\r\n    // async updateAllMissionsFromTemplate(missionInput: UpdateMissionInput) {\r\n    //     // all missions of this organisation\r\n    //     const missionsFromTemplate =\r\n    //         await this.missionService.getMissionsByTemplate(\r\n    //             this.missionToEdit.id,\r\n    //         );\r\n    //     await Promise.all(\r\n    //         missionsFromTemplate.map(async (mission) => {\r\n    //             const missionTemplate = { ...missionInput };\r\n    //             if (this.sendUpdate) {\r\n    //                 missionTemplate.emailStatus = EmailStatus.UPDATE_TO_DELIVER;\r\n    //             }\r\n    //             missionTemplate.id = mission.id;\r\n    //             await this.missionService.update(missionTemplate);\r\n    //         }),\r\n    //     );\r\n    // }\r\n\r\n    async onMissionInput(mission: Mission) {\r\n        if (mission) {\r\n            this.missionInput = mission;\r\n            await this.userService.createOrUpdateMissionForOrgWithProperty(\r\n                this.missionInput as Mission,\r\n                this.missionInput.organisationID,\r\n            );\r\n            this.added.emit(true);\r\n        } else {\r\n            this.added.emit(false);\r\n        }\r\n    }\r\n}\r\n","<div *ngIf=\"form\">\r\n    <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\">\r\n        <div id=\"personalInfo\">\r\n            <div style=\"margin-top: 1rem;\">\r\n                <h4>{{ 'User Personal Information' | translate }}</h4>\r\n            </div>\r\n            <div class=\"form-group row\">\r\n                <label class=\"col-sm-4 col-form-label\">{{'Email' | translate}} *</label>\r\n                <div class=\"col-sm-8\">\r\n                    <input type=\"text\" class=\"form-control\" [class.is-invalid]=\"email.invalid && email.touched\" required\r\n                        formControlName=\"email\">\r\n                    <div class=\"invalid-feedback\">\r\n                        {{'An email is required' | translate}}.\r\n                    </div>\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"form-group row\">\r\n                <label class=\"col-sm-4 col-form-label\">{{'Last name' | translate}}</label>\r\n                <div class=\"col-sm-8\">\r\n                    <input type=\"text\" class=\"form-control\" formControlName=\"lastName\">\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"form-group row\">\r\n                <label class=\"col-sm-4 col-form-label\">{{'First name' | translate}}</label>\r\n                <div class=\"col-sm-8\">\r\n                    <input type=\"text\" class=\"form-control\" formControlName=\"firstName\">\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div class=\"d-flex justify-content-center\" *ngIf=\"working\">\r\n            <lib-loader></lib-loader>\r\n        </div>\r\n\r\n        <div *ngIf=\"createdUser; else waitingForUser\">\r\n            <div class=\"alert alert-info\">\r\n                {{'User successfully created' | translate}}\r\n            </div>\r\n            <lib-form-mission [organisationForMission]=\"addToOrganisation\" [userForMissionID]=\"createdUser.id\"\r\n                [currentUserOrganisation]=\"currentOrg\" [isSP]=\"isSP\" (addedMissionInput)=\"onMissionInput($event)\">\r\n            </lib-form-mission>\r\n        </div>\r\n        <ng-template #waitingForUser>\r\n            <div class=\"action-button-container\">\r\n                <button type=\"submit\" class=\"btn btn-outline-primary rounded-pill mr-3 action-button\"\r\n                    [disabled]=\"working || form.invalid\">{{'Create user' | translate}}</button>\r\n                <button type=\"button\" (click)=\"onCancel()\" [disabled]=\"working\"\r\n                    class=\"btn btn-outline-primary rounded-pill action-button\">{{'Cancel' | translate}}</button>\r\n            </div>\r\n            <div style=\"margin-top: 1rem;\">\r\n                <h4>{{ 'Mission details' | translate }}</h4>\r\n            </div>\r\n            <ngb-alert type=\"warning\" [dismissible]=\"false\">{{'Please create a user first' | translate}}.</ngb-alert>\r\n\r\n        </ng-template>\r\n    </form>\r\n</div>"]}
@@ -0,0 +1,325 @@
1
+ import { Component } from '@angular/core';
2
+ import { DomainType, filterUniqueArrayByID, ProfileEntity, } from 'ngx-smarterplan-core';
3
+ import { Subject, takeUntil } from 'rxjs';
4
+ import { GuestLinkComponent } from '../guest-link/guest-link.component';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "ngx-smarterplan-core";
7
+ import * as i2 from "@ng-bootstrap/ng-bootstrap";
8
+ import * as i3 from "@ngx-translate/core";
9
+ import * as i4 from "../chevron/chevron.component";
10
+ import * as i5 from "./user-mission-form/user-mission-form.component";
11
+ import * as i6 from "./form-mission/form-mission.component";
12
+ import * as i7 from "./form-organisation/form-organisation.component";
13
+ import * as i8 from "./detail-organisation/detail-organisation.component";
14
+ import * as i9 from "@angular/common";
15
+ export class UserComponent {
16
+ constructor(userService, missionService, domainService, organisationService, modalService, translate) {
17
+ this.userService = userService;
18
+ this.missionService = missionService;
19
+ this.domainService = domainService;
20
+ this.organisationService = organisationService;
21
+ this.modalService = modalService;
22
+ this.translate = translate;
23
+ this.detailsUser = '-1';
24
+ this.detailsOrg = '-1';
25
+ this.query = '';
26
+ this.create = false;
27
+ this.edit = false;
28
+ this.working = false;
29
+ this.createForExistingUser = false;
30
+ this.isAddingOrg = false;
31
+ this.isAddingToExistingOrg = false;
32
+ this.isManager = false;
33
+ this.hideList = false;
34
+ this.orgsUsersMissions = [];
35
+ this.isSP = false;
36
+ this.isGuide = false;
37
+ this.clientsSP = [];
38
+ this.prestataireClients = [];
39
+ this.loading = false;
40
+ this.destroy$ = new Subject();
41
+ this.userService.isChanged
42
+ .pipe(takeUntil(this.destroy$))
43
+ .subscribe((isConnected) => {
44
+ if (isConnected) {
45
+ this.initInfo();
46
+ }
47
+ });
48
+ }
49
+ // @todo list my org and sub orgs
50
+ /**
51
+ * resetList fetches a fresh user list from server
52
+ */
53
+ async resetList() {
54
+ this.orgsUsersMissions = [];
55
+ let allMissions = [];
56
+ this.loading = true;
57
+ if (this.isSP) {
58
+ this.orgsUsersMissions = await this.initListForSP();
59
+ this.filteredOrgsUsersMissions = this.orgsUsersMissions;
60
+ this.loading = false;
61
+ return;
62
+ }
63
+ allMissions = await this.missionService.getMissionsByOrderedOrganisation(this.currentOrg.id);
64
+ const currentOrgMissions = await this.missionService.getMissionsByOrganisation(this.currentOrg.id);
65
+ allMissions = [...allMissions, ...currentOrgMissions];
66
+ allMissions = allMissions.filter((mission) => mission.user && !mission.user.deletedAt);
67
+ allMissions = filterUniqueArrayByID(allMissions);
68
+ if (allMissions) {
69
+ const orgs = allMissions.map((mis) => mis.organisation);
70
+ const profiles = allMissions.map((mis) => mis.user);
71
+ const uniqueOrg = filterUniqueArrayByID(orgs);
72
+ const uniqueUsers = filterUniqueArrayByID(profiles);
73
+ uniqueOrg.map((org) => {
74
+ const orgMissions = allMissions.filter((mis) => {
75
+ return mis.organisationID === org.id;
76
+ });
77
+ let users = this.getUsersForOrgMissions(uniqueUsers, orgMissions);
78
+ users = users.sort((user) => (user.user.email ? 0 : -1));
79
+ const object = {
80
+ org,
81
+ users,
82
+ };
83
+ this.orgsUsersMissions.push(object);
84
+ });
85
+ }
86
+ this.filteredOrgsUsersMissions = this.orgsUsersMissions;
87
+ this.loading = false;
88
+ }
89
+ async initInfo() {
90
+ const currentUser = this.userService.cu;
91
+ if (currentUser) {
92
+ this.me = currentUser;
93
+ this.currentOrg = this.userService.currentOrganisation();
94
+ this.isManager = this.userService.hasManagerRoleInAnyMission();
95
+ this.isSP = this.userService.isSPAdmin();
96
+ this.isGuide = this.userService.isGuide();
97
+ this.resetList();
98
+ this.setDomains();
99
+ }
100
+ }
101
+ async ngOnInit() {
102
+ this.initInfo();
103
+ }
104
+ ngOnDestroy() {
105
+ this.destroy$.next(true);
106
+ this.destroy$.complete();
107
+ }
108
+ async initListForSP() {
109
+ const results = [];
110
+ let allMissions = [];
111
+ let allOrgs = [];
112
+ allOrgs = await this.organisationService.listOrganisations();
113
+ await Promise.all(allOrgs.map(async (org) => {
114
+ const missions = await this.missionService.getMissionsByOrganisation(org.id);
115
+ allMissions = [...allMissions, ...missions];
116
+ }));
117
+ const profiles = allMissions
118
+ .map((mis) => mis.user)
119
+ .filter((user) => !user.deletedAt);
120
+ const uniqueUsers = filterUniqueArrayByID(profiles.filter((profile) => profile !== null));
121
+ allOrgs.map((org) => {
122
+ const orgMissions = allMissions.filter((mis) => {
123
+ return mis.organisationID === org.id;
124
+ });
125
+ if (orgMissions.length > 0) {
126
+ if (orgMissions.filter((m) => m.orderedOrganisationID === '6e28201f-4679-4c29-9d2d-8a325f57cee9').length > 0) {
127
+ this.clientsSP.push(org.id);
128
+ }
129
+ else {
130
+ this.prestataireClients.push({
131
+ orgOwner: orgMissions[0].orderedOrganisationID,
132
+ prestataire: org.id,
133
+ });
134
+ }
135
+ }
136
+ const users = this.getUsersForOrgMissions(uniqueUsers, orgMissions);
137
+ const object = {
138
+ org,
139
+ users,
140
+ };
141
+ results.push(object);
142
+ });
143
+ return results;
144
+ }
145
+ // eslint-disable-next-line class-methods-use-this
146
+ getUsersForOrgMissions(uniqueUsers, orgMissions) {
147
+ const users = uniqueUsers.map((user) => {
148
+ const userMissions = orgMissions.filter((m) => m.userID === user.id);
149
+ if (userMissions.length > 0) {
150
+ const userProfile = new ProfileEntity(user);
151
+ // once we got the user we check filter only active missions (not deleted)
152
+ const activeMissions = userMissions.filter((mis) => !mis.deletedAt);
153
+ return {
154
+ missions: activeMissions,
155
+ user: userProfile,
156
+ };
157
+ }
158
+ return null;
159
+ });
160
+ return users.filter((us) => us !== null);
161
+ }
162
+ async setDomains() {
163
+ const domains = await this.domainService.getDomainsForOrgExcludingTypes([DomainType.FEATURE, DomainType.BOOKING], this.currentOrg.id);
164
+ this.domains = domains;
165
+ }
166
+ /**
167
+ * onToggleDetail folds/unfolds details for a given organisation
168
+ * @param i index of the organisation to be toggled
169
+ */
170
+ onToggleDetailOrg(index, org) {
171
+ this.detailsOrg = index === this.detailsOrg ? '-1' : index;
172
+ this.orgSelectedDetails = this.detailsOrg === '-1' ? null : org;
173
+ }
174
+ onToggleDetailUser(index) {
175
+ this.detailsUser = index === this.detailsUser ? '-1' : index;
176
+ }
177
+ async onAdd(org) {
178
+ this.create = true;
179
+ this.hideList = true;
180
+ this.addToOrg = org;
181
+ }
182
+ async onEdit(m) {
183
+ this.edit = true;
184
+ this.hideList = true;
185
+ this.missionToEdit = m;
186
+ }
187
+ onCancel() {
188
+ this.working = false;
189
+ this.create = false;
190
+ this.missionToEdit = null;
191
+ this.createForExistingUser = false;
192
+ }
193
+ onAddForUser(org, user) {
194
+ this.hideList = true;
195
+ this.createForExistingUser = true;
196
+ this.userForAddingMission = user;
197
+ this.addToOrg = org;
198
+ }
199
+ onAddOrg() {
200
+ this.hideList = true;
201
+ this.isAddingOrg = true;
202
+ }
203
+ orgAdded(isAdded) {
204
+ this.hideList = false;
205
+ this.isAddingOrg = false;
206
+ this.isAddingToExistingOrg = false;
207
+ if (isAdded) {
208
+ this.resetList();
209
+ }
210
+ }
211
+ userAdded(isAdded) {
212
+ console.log(isAdded);
213
+ this.hideList = false;
214
+ this.create = false;
215
+ this.addToOrg = null;
216
+ this.createForExistingUser = false;
217
+ this.userForAddingMission = null;
218
+ if (isAdded) {
219
+ this.resetList();
220
+ }
221
+ }
222
+ async onMissionEdited(mission) {
223
+ this.edit = false;
224
+ this.missionToEdit = null;
225
+ if (mission) {
226
+ await this.userService.createOrUpdateMissionForOrgWithProperty(mission, mission.organisationID, false);
227
+ this.resetList();
228
+ }
229
+ this.hideList = false;
230
+ }
231
+ async onMissionCreated(mission) {
232
+ this.createForExistingUser = false;
233
+ this.userForAddingMission = null;
234
+ if (mission) {
235
+ await this.userService.createOrUpdateMissionForOrgWithProperty(mission, mission.organisationID);
236
+ this.resetList();
237
+ }
238
+ this.hideList = false;
239
+ }
240
+ getOrderedOrg(orgID) {
241
+ let name;
242
+ this.prestataireClients.map(async (presta) => {
243
+ if (presta.prestataire === orgID) {
244
+ const org = this.orgsUsersMissions.filter((object) => object.org.id === presta.orgOwner);
245
+ if (org.length > 0) {
246
+ name = org[0].org.name;
247
+ }
248
+ }
249
+ });
250
+ return name;
251
+ }
252
+ domainIdsToStringForMission(mission) {
253
+ let names = '';
254
+ for (const domainID of mission.domains) {
255
+ const domain = this.domains.find((dom) => dom.id === domainID);
256
+ if (domain) {
257
+ names = `${names} ${domain.name},`;
258
+ }
259
+ }
260
+ return names.slice(0, -1); // to remove last comma
261
+ }
262
+ async onDeleteMission(mission) {
263
+ const message = this.translate.instant('confirm.deleteMission');
264
+ if (window.confirm(message)) {
265
+ await this.missionService.softDeleteMission(mission.id);
266
+ this.resetList();
267
+ }
268
+ }
269
+ async onDeleteUser(user) {
270
+ const message = this.translate.instant('confirm.deleteUser');
271
+ if (window.confirm(message)) {
272
+ const userMissions = await this.missionService.getMissionsFromUserID(user.id);
273
+ if (userMissions.length > 0) {
274
+ const resultDelete = [];
275
+ await Promise.all(userMissions.map(async (mission) => {
276
+ if (mission.orderedOrganisationID === this.currentOrg.id ||
277
+ this.isSP) {
278
+ const deletedMission = await this.missionService.softDeleteMission(mission.id);
279
+ if (deletedMission) {
280
+ resultDelete.push(deletedMission);
281
+ }
282
+ }
283
+ }));
284
+ if (resultDelete.length > 0) {
285
+ await this.userService.softDeleteUser(user.id);
286
+ await this.resetList();
287
+ }
288
+ }
289
+ else {
290
+ await this.userService.softDeleteUser(user.id);
291
+ await this.resetList();
292
+ }
293
+ }
294
+ }
295
+ applyResultsSearchBar(results) {
296
+ this.orgSelectedDetails = null;
297
+ this.filteredOrgsUsersMissions = results || this.orgsUsersMissions;
298
+ }
299
+ onAddInExistingOrg() {
300
+ this.hideList = true;
301
+ this.isAddingToExistingOrg = true;
302
+ }
303
+ /**
304
+ * Creates encypted link and sets it for guestLink for Space.
305
+ * @param mis
306
+ */
307
+ onSetForShareableLink(user, mission) {
308
+ const modalReference = this.modalService.open(GuestLinkComponent);
309
+ modalReference.componentInstance.username = user.email;
310
+ modalReference.componentInstance.spaceID = mission.spaceID;
311
+ }
312
+ async onClearToken(user) {
313
+ await this.userService.clearUserToken(user.user.id);
314
+ const firstMessage = this.translate.instant('firstTokenMessage');
315
+ const secondMessage = this.translate.instant('secondTokenMessage');
316
+ alert(firstMessage + user.user.displayName + secondMessage);
317
+ }
318
+ }
319
+ UserComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: UserComponent, deps: [{ token: i1.BaseUserService }, { token: i1.MissionService }, { token: i1.DomainService }, { token: i1.OrganisationService }, { token: i2.NgbModal }, { token: i3.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
320
+ UserComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: UserComponent, selector: "lib-user", ngImport: i0, template: "<div class=\"dashboard-tab\">\r\n <div class=\"header-dashboard-tab\">\r\n <h3>{{'Users' | translate}}</h3>\r\n <!-- <app-search-bar *ngIf=\"!hideList\" [searchable]=\"orgsUsersMissions\" objectType=\"USER\"\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-6\">\r\n <div class=\"row ml-0 mb-2\" *ngIf=\"!hideList\">\r\n <button class=\"btn btn-outline-primary rounded-pill add-button\" *ngIf=\"isManager && !isGuide\" (click)=\"onAddOrg()\">\r\n {{'Add user to new organisation' | 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=\"!hideList\">\r\n <ul class=\"list-group list-group-flush\" *ngIf=\"filteredOrgsUsersMissions\">\r\n <li class=\"list-group-item list-group-item-action\" *ngFor=\"let o of filteredOrgsUsersMissions\">\r\n <div class=\"d-flex justify-content-between align-items-center font-weight-bold\"\r\n ngbTooltip=\"See details and users\" style=\"cursor: pointer;\" (click)=\"onToggleDetailOrg(o.org.id, o.org)\">\r\n {{o.org.name}} <small *ngIf=\"o.org.id == currentOrg.id\">({{'My organisation' | translate}})</small>\r\n <small *ngIf=\"isSP && clientsSP.includes(o.org.id)\">({{'Client of SmarterPlan' | translate}})</small>\r\n <small *ngIf=\"isSP && getOrderedOrg(o.org.id)\">({{'Client of ' | translate}}\r\n {{getOrderedOrg(o.org.id)}})</small>\r\n <lib-chevron [conditionShowing]=\"detailsOrg==o.org.id\"></lib-chevron>\r\n </div>\r\n <div class=\"missions\" *ngIf=\"detailsOrg==o.org.id\">\r\n <div class='d-flex'>\r\n <button class=\"btn btn-outline-primary rounded-pill mt-3 mb-3\" (click)=\"onAdd(o.org)\">{{'Add user' |\r\n translate}}</button>\r\n </div>\r\n\r\n <ul class=\"list-group list-group-flush\">\r\n <li class=\"list-group-item list-group-item-action\" *ngFor=\"let a of o.users\"\r\n (click)=\"onToggleDetailUser(a.user.id)\">\r\n <div class=\"d-flex justify-content-between align-items-center\">\r\n {{a.user.displayName}}\r\n <lib-chevron [conditionShowing]=\"detailsUser==a.user.id\"></lib-chevron>\r\n </div>\r\n\r\n <div *ngIf=\"detailsUser==a.user.id\">\r\n <div class=\"ml-3\">\r\n <div class=\"d-flex justify-content-between align-items-center mt-3\">\r\n {{'Email' | translate}}: {{a.user.email }}\r\n </div>\r\n <div class=\"d-flex justify-content-between align-items-center mt-3\">\r\n <button type=\"button\" class=\"btn btn-primary rounded-pill\"\r\n (click)=\"onAddForUser(o.org, a.user)\">{{'Add new mission' | translate}}</button>\r\n <button type=\"button\" class=\"btn btn-primary rounded-pill\" (click)=\"onClearToken(a)\">\r\n {{'Clear Token' | translate}}</button>\r\n <button type=\"button\" class=\"btn btn-primary rounded-pill\"\r\n (click)=\"onDeleteUser(a.user)\">{{'Delete user' | translate}}</button>\r\n </div>\r\n <div class=\"d-flex justify-content-between align-items-center mt-3\">\r\n {{ a.missions.length > 0 ? ('Current Missions' | translate) : ('No missions' | translate)}}\r\n </div>\r\n </div>\r\n <ul class=\"list-group list-group-flush\">\r\n <li class=\"list-group-item\" *ngFor=\"let mis of a.missions\">\r\n <ul class=\"list-group list-group-flush\">\r\n <li class=\"list-group-item bg-transparent\" *ngIf=\"mis.description\">\r\n {{'Description' | translate}}: {{mis.description}}</li>\r\n <li class=\"list-group-item bg-transparent\" *ngIf=\"mis.templateMissionID\">\r\n {{'Attendee of tour' | translate}}: {{mis.templateMission.title}}</li>\r\n\r\n <li class=\"list-group-item bg-transparent\">{{'Role' | translate}}: {{ mis.role }}</li>\r\n <li class=\"list-group-item bg-transparent\" *ngIf=\"mis.hashtags && mis.hashtags.length> 0\">\r\n {{'Hashtags' | translate}}: <ul class=\"keywordsDisplay no-border\">\r\n <div class=\"keywordsdisplayContainer\">\r\n <li class=\"keywordsItem\" *ngFor=\"let hashtag of mis.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\">{{'Language' | translate }}: {{\r\n mis.locale ? mis.locale : ('Not applicable' | translate)}}</li>\r\n <li class=\"list-group-item bg-transparent\">{{'Access level' | translate }}: {{\r\n mis.level}}</li>\r\n <li class=\"list-group-item bg-transparent\">{{'Ordered by' | translate }}: {{\r\n mis.orderedOrganisation.name}}</li>\r\n <li class=\"list-group-item bg-transparent\" *ngIf=\"mis.domains\">{{'Domains' | translate }}:\r\n {{mis.domains ?\r\n domainIdsToStringForMission(mis) : (\"No data\" | translate) }}</li>\r\n <li class=\"list-group-item bg-transparent\">{{'Authorized location' | translate }}:\r\n {{ mis.space ? mis.space.name : \"No location\" | translate}}</li>\r\n <li class=\"list-group-item bg-transparent\">{{'Authorized zone' | translate }}:\r\n {{ mis.zone ? mis.zone.name : \"All zones allowed\" | translate}}</li>\r\n <li class=\"list-group-item bg-transparent\">{{'Starts' | translate }}:\r\n {{ mis.startDateTime ? (mis.startDateTime | timeDateString: \"day_time_zone\" | async) :\r\n \"No data\" | translate}}, {{'Ends' | translate}}: {{ mis.endDateTime\r\n ? (mis.endDateTime | timeDateString: \"day_time_zone\" | async)\r\n : \"No data\" | translate}}.\r\n </li>\r\n </ul>\r\n <div class=\"action-button-container\">\r\n <button type=\"button\" class=\"btn btn-outline-primary rounded-pill mr-2 action-button\"\r\n (click)=\"onEdit(mis)\">{{'Edit' |\r\n translate}}</button>\r\n <button type=\"button\" *ngIf=\"mis.role === 'VISITOR' || mis.role === 'VISITOR_MUSEUM'\"\r\n class=\"btn btn-outline-primary rounded-pill mr-2 action-button share-visitor-button\"\r\n (click)=\"onSetForShareableLink(a.user, mis)\">{{'Generate Shareable Link' |\r\n translate}}</button>\r\n <button type=\"button\" class=\"btn btn-outline-primary rounded-pill action-button\"\r\n (click)=\"onDeleteMission(mis)\">{{'Delete' | translate}}</button>\r\n </div>\r\n </li>\r\n </ul>\r\n </div>\r\n </li>\r\n </ul>\r\n </div>\r\n </li>\r\n </ul>\r\n </div>\r\n\r\n <div *ngIf=\"create\">\r\n <lib-user-mission-form [addToOrganisation]=\"addToOrg\" [currentOrg]=\"currentOrg\" [isSP]=\"isSP\"\r\n (added)=\"userAdded($event)\">\r\n </lib-user-mission-form>\r\n </div>\r\n <div *ngIf=\"edit\">\r\n <lib-form-mission [missionToEdit]=\"missionToEdit\" [currentUserOrganisation]=\"currentOrg\" [isSP]=\"isSP\"\r\n (addedMissionInput)=\"onMissionEdited($event)\"></lib-form-mission>\r\n </div>\r\n <div *ngIf=\"createForExistingUser\">\r\n <lib-form-mission [organisationForMission]=\"addToOrg\" [currentUserOrganisation]=\"currentOrg\" [isSP]=\"isSP\"\r\n [userForMissionID]=\"userForAddingMission.id\" (addedMissionInput)=\"onMissionCreated($event)\">\r\n </lib-form-mission>\r\n </div>\r\n <div *ngIf=\"isAddingOrg || isAddingToExistingOrg\">\r\n <lib-form-organisation [currentOrg]=\"currentOrg\" [currentUser]=\"me\" [existing]=\"isAddingToExistingOrg\"\r\n (added)=\"orgAdded($event)\"></lib-form-organisation>\r\n </div>\r\n </div>\r\n\r\n <div class=\"col-md-4 col-lg-6\" *ngIf=\"orgSelectedDetails && !isGuide\">\r\n <lib-detail-organisation [org]=\"orgSelectedDetails\" [currentOrg]=\"currentOrg\" [isSP]=\"isSP\"\r\n (orgChanged)='orgAdded($event)'></lib-detail-organisation>\r\n </div>\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}.action-button-container .share-visitor-button{width:-moz-fit-content;width:fit-content}\n"], components: [{ type: i1.LoaderComponent, selector: "lib-loader" }, { type: i4.ChevronComponent, selector: "lib-chevron", inputs: ["conditionShowing"] }, { type: i5.UserMissionFormComponent, selector: "lib-user-mission-form", inputs: ["addToOrganisation", "isSP", "createForExistingUser", "currentOrg"], outputs: ["added"] }, { type: i6.FormMissionComponent, selector: "lib-form-mission", inputs: ["missionToEdit", "organisationForMission", "isSP", "userForMissionID", "currentUserOrganisation"], outputs: ["addedMissionInput"] }, { type: i7.FormOrganisationComponent, selector: "lib-form-organisation", inputs: ["currentOrg", "currentUser", "existing"], outputs: ["added"] }, { type: i8.DetailOrganisationComponent, selector: "lib-detail-organisation", inputs: ["org", "currentOrg", "isSP"], outputs: ["orgChanged"] }], directives: [{ type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "triggers", "container", "disableTooltip", "tooltipClass", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }], pipes: { "translate": i3.TranslatePipe, "async": i9.AsyncPipe, "hashtagFromID": i1.HashtagFromIdPipe, "timeDateString": i1.TimeDateToLocalStringPipe } });
321
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: UserComponent, decorators: [{
322
+ type: Component,
323
+ args: [{ selector: 'lib-user', template: "<div class=\"dashboard-tab\">\r\n <div class=\"header-dashboard-tab\">\r\n <h3>{{'Users' | translate}}</h3>\r\n <!-- <app-search-bar *ngIf=\"!hideList\" [searchable]=\"orgsUsersMissions\" objectType=\"USER\"\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-6\">\r\n <div class=\"row ml-0 mb-2\" *ngIf=\"!hideList\">\r\n <button class=\"btn btn-outline-primary rounded-pill add-button\" *ngIf=\"isManager && !isGuide\" (click)=\"onAddOrg()\">\r\n {{'Add user to new organisation' | 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=\"!hideList\">\r\n <ul class=\"list-group list-group-flush\" *ngIf=\"filteredOrgsUsersMissions\">\r\n <li class=\"list-group-item list-group-item-action\" *ngFor=\"let o of filteredOrgsUsersMissions\">\r\n <div class=\"d-flex justify-content-between align-items-center font-weight-bold\"\r\n ngbTooltip=\"See details and users\" style=\"cursor: pointer;\" (click)=\"onToggleDetailOrg(o.org.id, o.org)\">\r\n {{o.org.name}} <small *ngIf=\"o.org.id == currentOrg.id\">({{'My organisation' | translate}})</small>\r\n <small *ngIf=\"isSP && clientsSP.includes(o.org.id)\">({{'Client of SmarterPlan' | translate}})</small>\r\n <small *ngIf=\"isSP && getOrderedOrg(o.org.id)\">({{'Client of ' | translate}}\r\n {{getOrderedOrg(o.org.id)}})</small>\r\n <lib-chevron [conditionShowing]=\"detailsOrg==o.org.id\"></lib-chevron>\r\n </div>\r\n <div class=\"missions\" *ngIf=\"detailsOrg==o.org.id\">\r\n <div class='d-flex'>\r\n <button class=\"btn btn-outline-primary rounded-pill mt-3 mb-3\" (click)=\"onAdd(o.org)\">{{'Add user' |\r\n translate}}</button>\r\n </div>\r\n\r\n <ul class=\"list-group list-group-flush\">\r\n <li class=\"list-group-item list-group-item-action\" *ngFor=\"let a of o.users\"\r\n (click)=\"onToggleDetailUser(a.user.id)\">\r\n <div class=\"d-flex justify-content-between align-items-center\">\r\n {{a.user.displayName}}\r\n <lib-chevron [conditionShowing]=\"detailsUser==a.user.id\"></lib-chevron>\r\n </div>\r\n\r\n <div *ngIf=\"detailsUser==a.user.id\">\r\n <div class=\"ml-3\">\r\n <div class=\"d-flex justify-content-between align-items-center mt-3\">\r\n {{'Email' | translate}}: {{a.user.email }}\r\n </div>\r\n <div class=\"d-flex justify-content-between align-items-center mt-3\">\r\n <button type=\"button\" class=\"btn btn-primary rounded-pill\"\r\n (click)=\"onAddForUser(o.org, a.user)\">{{'Add new mission' | translate}}</button>\r\n <button type=\"button\" class=\"btn btn-primary rounded-pill\" (click)=\"onClearToken(a)\">\r\n {{'Clear Token' | translate}}</button>\r\n <button type=\"button\" class=\"btn btn-primary rounded-pill\"\r\n (click)=\"onDeleteUser(a.user)\">{{'Delete user' | translate}}</button>\r\n </div>\r\n <div class=\"d-flex justify-content-between align-items-center mt-3\">\r\n {{ a.missions.length > 0 ? ('Current Missions' | translate) : ('No missions' | translate)}}\r\n </div>\r\n </div>\r\n <ul class=\"list-group list-group-flush\">\r\n <li class=\"list-group-item\" *ngFor=\"let mis of a.missions\">\r\n <ul class=\"list-group list-group-flush\">\r\n <li class=\"list-group-item bg-transparent\" *ngIf=\"mis.description\">\r\n {{'Description' | translate}}: {{mis.description}}</li>\r\n <li class=\"list-group-item bg-transparent\" *ngIf=\"mis.templateMissionID\">\r\n {{'Attendee of tour' | translate}}: {{mis.templateMission.title}}</li>\r\n\r\n <li class=\"list-group-item bg-transparent\">{{'Role' | translate}}: {{ mis.role }}</li>\r\n <li class=\"list-group-item bg-transparent\" *ngIf=\"mis.hashtags && mis.hashtags.length> 0\">\r\n {{'Hashtags' | translate}}: <ul class=\"keywordsDisplay no-border\">\r\n <div class=\"keywordsdisplayContainer\">\r\n <li class=\"keywordsItem\" *ngFor=\"let hashtag of mis.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\">{{'Language' | translate }}: {{\r\n mis.locale ? mis.locale : ('Not applicable' | translate)}}</li>\r\n <li class=\"list-group-item bg-transparent\">{{'Access level' | translate }}: {{\r\n mis.level}}</li>\r\n <li class=\"list-group-item bg-transparent\">{{'Ordered by' | translate }}: {{\r\n mis.orderedOrganisation.name}}</li>\r\n <li class=\"list-group-item bg-transparent\" *ngIf=\"mis.domains\">{{'Domains' | translate }}:\r\n {{mis.domains ?\r\n domainIdsToStringForMission(mis) : (\"No data\" | translate) }}</li>\r\n <li class=\"list-group-item bg-transparent\">{{'Authorized location' | translate }}:\r\n {{ mis.space ? mis.space.name : \"No location\" | translate}}</li>\r\n <li class=\"list-group-item bg-transparent\">{{'Authorized zone' | translate }}:\r\n {{ mis.zone ? mis.zone.name : \"All zones allowed\" | translate}}</li>\r\n <li class=\"list-group-item bg-transparent\">{{'Starts' | translate }}:\r\n {{ mis.startDateTime ? (mis.startDateTime | timeDateString: \"day_time_zone\" | async) :\r\n \"No data\" | translate}}, {{'Ends' | translate}}: {{ mis.endDateTime\r\n ? (mis.endDateTime | timeDateString: \"day_time_zone\" | async)\r\n : \"No data\" | translate}}.\r\n </li>\r\n </ul>\r\n <div class=\"action-button-container\">\r\n <button type=\"button\" class=\"btn btn-outline-primary rounded-pill mr-2 action-button\"\r\n (click)=\"onEdit(mis)\">{{'Edit' |\r\n translate}}</button>\r\n <button type=\"button\" *ngIf=\"mis.role === 'VISITOR' || mis.role === 'VISITOR_MUSEUM'\"\r\n class=\"btn btn-outline-primary rounded-pill mr-2 action-button share-visitor-button\"\r\n (click)=\"onSetForShareableLink(a.user, mis)\">{{'Generate Shareable Link' |\r\n translate}}</button>\r\n <button type=\"button\" class=\"btn btn-outline-primary rounded-pill action-button\"\r\n (click)=\"onDeleteMission(mis)\">{{'Delete' | translate}}</button>\r\n </div>\r\n </li>\r\n </ul>\r\n </div>\r\n </li>\r\n </ul>\r\n </div>\r\n </li>\r\n </ul>\r\n </div>\r\n\r\n <div *ngIf=\"create\">\r\n <lib-user-mission-form [addToOrganisation]=\"addToOrg\" [currentOrg]=\"currentOrg\" [isSP]=\"isSP\"\r\n (added)=\"userAdded($event)\">\r\n </lib-user-mission-form>\r\n </div>\r\n <div *ngIf=\"edit\">\r\n <lib-form-mission [missionToEdit]=\"missionToEdit\" [currentUserOrganisation]=\"currentOrg\" [isSP]=\"isSP\"\r\n (addedMissionInput)=\"onMissionEdited($event)\"></lib-form-mission>\r\n </div>\r\n <div *ngIf=\"createForExistingUser\">\r\n <lib-form-mission [organisationForMission]=\"addToOrg\" [currentUserOrganisation]=\"currentOrg\" [isSP]=\"isSP\"\r\n [userForMissionID]=\"userForAddingMission.id\" (addedMissionInput)=\"onMissionCreated($event)\">\r\n </lib-form-mission>\r\n </div>\r\n <div *ngIf=\"isAddingOrg || isAddingToExistingOrg\">\r\n <lib-form-organisation [currentOrg]=\"currentOrg\" [currentUser]=\"me\" [existing]=\"isAddingToExistingOrg\"\r\n (added)=\"orgAdded($event)\"></lib-form-organisation>\r\n </div>\r\n </div>\r\n\r\n <div class=\"col-md-4 col-lg-6\" *ngIf=\"orgSelectedDetails && !isGuide\">\r\n <lib-detail-organisation [org]=\"orgSelectedDetails\" [currentOrg]=\"currentOrg\" [isSP]=\"isSP\"\r\n (orgChanged)='orgAdded($event)'></lib-detail-organisation>\r\n </div>\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}.action-button-container .share-visitor-button{width:-moz-fit-content;width:fit-content}\n"] }]
324
+ }], ctorParameters: function () { return [{ type: i1.BaseUserService }, { type: i1.MissionService }, { type: i1.DomainService }, { type: i1.OrganisationService }, { type: i2.NgbModal }, { type: i3.TranslateService }]; } });
325
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-smarterplan-admin/src/lib/user/user.component.ts","../../../../../projects/ngx-smarterplan-admin/src/lib/user/user.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport {\r\n  BaseUserService,\r\n  Domain,\r\n  DomainService,\r\n  DomainType,\r\n  filterUniqueArrayByID,\r\n  Mission,\r\n  MissionService,\r\n  Organisation,\r\n  OrganisationService,\r\n  Profile,\r\n  ProfileEntity,\r\n} from 'ngx-smarterplan-core';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { GuestLinkComponent } from '../guest-link/guest-link.component';\r\nimport { NgbModal } from '@ng-bootstrap/ng-bootstrap';\r\n\r\n@Component({\r\n  selector: 'lib-user',\r\n  templateUrl: './user.component.html',\r\n  styleUrls: ['./user.component.scss'],\r\n})\r\nexport class UserComponent implements OnInit {\r\n  users: Array<Mission & { name: string }>;\r\n\r\n  detailsUser = '-1';\r\n\r\n  detailsOrg = '-1';\r\n\r\n  query = '';\r\n\r\n  create = false;\r\n\r\n  edit = false;\r\n\r\n  working = false;\r\n\r\n  createForExistingUser = false;\r\n\r\n  isAddingOrg = false;\r\n\r\n  isAddingToExistingOrg = false;\r\n\r\n  userForAddingMission: ProfileEntity;\r\n\r\n  currentOrg: Organisation;\r\n\r\n  me: ProfileEntity;\r\n\r\n  isManager = false;\r\n\r\n  hideList = false;\r\n\r\n  orgsUsersMissions: Array<{\r\n    org: Organisation;\r\n    users: Array<{\r\n      missions: Mission[];\r\n      user: ProfileEntity;\r\n    }>;\r\n  }> = [];\r\n\r\n  missionToEdit: Mission;\r\n\r\n  isSP = false;\r\n\r\n  isGuide = false;\r\n\r\n  clientsSP: string[] = [];\r\n\r\n  prestataireClients: Array<{ orgOwner: string; prestataire: string }> = [];\r\n\r\n  domains: Domain[];\r\n\r\n  addToOrg: Organisation;\r\n\r\n  orgSelectedDetails: Organisation;\r\n\r\n  filteredOrgsUsersMissions: Array<{\r\n    org: Organisation;\r\n    users: Array<{\r\n      missions: Mission[];\r\n      user: ProfileEntity;\r\n    }>;\r\n  }>;\r\n\r\n  loading = false;\r\n\r\n  private destroy$ = new Subject();\r\n\r\n  constructor(\r\n    private userService: BaseUserService,\r\n    private missionService: MissionService,\r\n    private domainService: DomainService,\r\n    private organisationService: OrganisationService,\r\n    private modalService: NgbModal,\r\n    private translate: TranslateService\r\n  ) {\r\n    this.userService.isChanged\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((isConnected) => {\r\n        if (isConnected) {\r\n          this.initInfo();\r\n        }\r\n      });\r\n  }\r\n\r\n  // @todo list my org and sub orgs\r\n\r\n  /**\r\n   * resetList fetches a fresh user list from server\r\n   */\r\n  async resetList() {\r\n    this.orgsUsersMissions = [];\r\n    let allMissions = [];\r\n    this.loading = true;\r\n    if (this.isSP) {\r\n      this.orgsUsersMissions = await this.initListForSP();\r\n      this.filteredOrgsUsersMissions = this.orgsUsersMissions;\r\n      this.loading = false;\r\n      return;\r\n    }\r\n    allMissions = await this.missionService.getMissionsByOrderedOrganisation(\r\n      this.currentOrg.id\r\n    );\r\n    const currentOrgMissions =\r\n      await this.missionService.getMissionsByOrganisation(this.currentOrg.id);\r\n    allMissions = [...allMissions, ...currentOrgMissions];\r\n    allMissions = allMissions.filter((mission) => mission.user && !mission.user.deletedAt);\r\n    allMissions = filterUniqueArrayByID(allMissions);\r\n\r\n    if (allMissions) {\r\n      const orgs = allMissions.map((mis) => mis.organisation);\r\n      const profiles = allMissions.map((mis) => mis.user);\r\n      const uniqueOrg = filterUniqueArrayByID(orgs);\r\n      const uniqueUsers = filterUniqueArrayByID(profiles);\r\n      uniqueOrg.map((org) => {\r\n        const orgMissions = allMissions.filter((mis) => {\r\n          return mis.organisationID === org.id;\r\n        });\r\n        let users = this.getUsersForOrgMissions(uniqueUsers, orgMissions);\r\n        users = users.sort((user) => (user.user.email ? 0 : -1));\r\n        const object = {\r\n          org,\r\n          users,\r\n        };\r\n        this.orgsUsersMissions.push(object);\r\n      });\r\n    }\r\n    this.filteredOrgsUsersMissions = this.orgsUsersMissions;\r\n    this.loading = false;\r\n  }\r\n\r\n  async initInfo() {\r\n    const currentUser = this.userService.cu;\r\n    if (currentUser) {\r\n      this.me = currentUser;\r\n      this.currentOrg = this.userService.currentOrganisation();\r\n      this.isManager = this.userService.hasManagerRoleInAnyMission();\r\n      this.isSP = this.userService.isSPAdmin();\r\n      this.isGuide = this.userService.isGuide();\r\n      this.resetList();\r\n      this.setDomains();\r\n    }\r\n  }\r\n\r\n  async ngOnInit(): Promise<void> {\r\n    this.initInfo();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next(true);\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  async initListForSP(): Promise<any[]> {\r\n    const results = [];\r\n    let allMissions = [];\r\n    let allOrgs = [];\r\n    allOrgs = await this.organisationService.listOrganisations();\r\n    await Promise.all(\r\n      allOrgs.map(async (org) => {\r\n        const missions = await this.missionService.getMissionsByOrganisation(\r\n          org.id\r\n        );\r\n        allMissions = [...allMissions, ...missions];\r\n      })\r\n    );\r\n\r\n    const profiles = allMissions\r\n      .map((mis) => mis.user)\r\n      .filter((user) => !user.deletedAt);\r\n    const uniqueUsers = filterUniqueArrayByID(\r\n      profiles.filter((profile) => profile !== null)\r\n    );\r\n    allOrgs.map((org) => {\r\n      const orgMissions = allMissions.filter((mis) => {\r\n        return mis.organisationID === org.id;\r\n      });\r\n\r\n      if (orgMissions.length > 0) {\r\n        if (\r\n          orgMissions.filter(\r\n            (m) =>\r\n              m.orderedOrganisationID === '6e28201f-4679-4c29-9d2d-8a325f57cee9'\r\n          ).length > 0\r\n        ) {\r\n          this.clientsSP.push(org.id);\r\n        } else {\r\n          this.prestataireClients.push({\r\n            orgOwner: orgMissions[0].orderedOrganisationID,\r\n            prestataire: org.id,\r\n          });\r\n        }\r\n      }\r\n      const users = this.getUsersForOrgMissions(uniqueUsers, orgMissions);\r\n      const object = {\r\n        org,\r\n        users,\r\n      };\r\n      results.push(object);\r\n    });\r\n    return results;\r\n  }\r\n\r\n  // eslint-disable-next-line class-methods-use-this\r\n  getUsersForOrgMissions(\r\n    uniqueUsers: Profile[],\r\n    orgMissions: Mission[]\r\n  ): Array<{\r\n    missions: Mission[];\r\n    user: ProfileEntity;\r\n  }> {\r\n    const users = uniqueUsers.map((user) => {\r\n      const userMissions = orgMissions.filter((m) => m.userID === user.id);\r\n      if (userMissions.length > 0) {\r\n        const userProfile = new ProfileEntity(user);\r\n        // once we got the user we check filter only active missions (not deleted)\r\n        const activeMissions = userMissions.filter((mis) => !mis.deletedAt);\r\n        return {\r\n          missions: activeMissions,\r\n          user: userProfile,\r\n        };\r\n      }\r\n      return null;\r\n    });\r\n    return users.filter((us) => us !== null);\r\n  }\r\n\r\n  async setDomains() {\r\n    const domains = await this.domainService.getDomainsForOrgExcludingTypes(\r\n      [DomainType.FEATURE, DomainType.BOOKING],\r\n      this.currentOrg.id\r\n    );\r\n    this.domains = domains;\r\n  }\r\n\r\n  /**\r\n   * onToggleDetail folds/unfolds details for a given organisation\r\n   * @param i index of the organisation to be toggled\r\n   */\r\n  onToggleDetailOrg(index, org) {\r\n    this.detailsOrg = index === this.detailsOrg ? '-1' : index;\r\n    this.orgSelectedDetails = this.detailsOrg === '-1' ? null : org;\r\n  }\r\n\r\n  onToggleDetailUser(index) {\r\n    this.detailsUser = index === this.detailsUser ? '-1' : index;\r\n  }\r\n\r\n  async onAdd(org: Organisation) {\r\n    this.create = true;\r\n    this.hideList = true;\r\n    this.addToOrg = org;\r\n  }\r\n\r\n  async onEdit(m: Mission) {\r\n    this.edit = true;\r\n    this.hideList = true;\r\n    this.missionToEdit = m;\r\n  }\r\n\r\n  onCancel() {\r\n    this.working = false;\r\n    this.create = false;\r\n    this.missionToEdit = null;\r\n    this.createForExistingUser = false;\r\n  }\r\n\r\n  onAddForUser(org: Organisation, user: ProfileEntity) {\r\n    this.hideList = true;\r\n    this.createForExistingUser = true;\r\n    this.userForAddingMission = user;\r\n    this.addToOrg = org;\r\n  }\r\n\r\n  onAddOrg() {\r\n    this.hideList = true;\r\n    this.isAddingOrg = true;\r\n  }\r\n\r\n  orgAdded(isAdded: boolean) {\r\n    this.hideList = false;\r\n    this.isAddingOrg = false;\r\n    this.isAddingToExistingOrg = false;\r\n    if (isAdded) {\r\n      this.resetList();\r\n    }\r\n  }\r\n\r\n  userAdded(isAdded: boolean) {\r\n    console.log(isAdded);\r\n    this.hideList = false;\r\n    this.create = false;\r\n    this.addToOrg = null;\r\n    this.createForExistingUser = false;\r\n    this.userForAddingMission = null;\r\n    if (isAdded) {\r\n      this.resetList();\r\n    }\r\n  }\r\n\r\n  async onMissionEdited(mission: Mission) {\r\n    this.edit = false;\r\n    this.missionToEdit = null;\r\n    if (mission) {\r\n      await this.userService.createOrUpdateMissionForOrgWithProperty(\r\n        mission,\r\n        mission.organisationID,\r\n        false\r\n      );\r\n      this.resetList();\r\n    }\r\n    this.hideList = false;\r\n  }\r\n\r\n  async onMissionCreated(mission: Mission) {\r\n    this.createForExistingUser = false;\r\n    this.userForAddingMission = null;\r\n    if (mission) {\r\n      await this.userService.createOrUpdateMissionForOrgWithProperty(\r\n        mission,\r\n        mission.organisationID\r\n      );\r\n      this.resetList();\r\n    }\r\n    this.hideList = false;\r\n  }\r\n\r\n  getOrderedOrg(orgID: string): string | null {\r\n    let name;\r\n    this.prestataireClients.map(async (presta) => {\r\n      if (presta.prestataire === orgID) {\r\n        const org = this.orgsUsersMissions.filter(\r\n          (object) => object.org.id === presta.orgOwner\r\n        );\r\n        if (org.length > 0) {\r\n          name = org[0].org.name;\r\n        }\r\n      }\r\n    });\r\n    return name;\r\n  }\r\n\r\n  domainIdsToStringForMission(mission: Mission): string {\r\n    let names = '';\r\n    for (const domainID of mission.domains) {\r\n      const domain = this.domains.find((dom) => dom.id === domainID);\r\n      if (domain) {\r\n        names = `${names} ${domain.name},`;\r\n      }\r\n    }\r\n    return names.slice(0, -1); // to remove last comma\r\n  }\r\n\r\n  async onDeleteMission(mission: Mission) {\r\n    const message = this.translate.instant('confirm.deleteMission');\r\n    if (window.confirm(message)) {\r\n      await this.missionService.softDeleteMission(mission.id);\r\n      this.resetList();\r\n    }\r\n  }\r\n\r\n  async onDeleteUser(user) {\r\n    const message = this.translate.instant('confirm.deleteUser');\r\n    if (window.confirm(message)) {\r\n      const userMissions = await this.missionService.getMissionsFromUserID(\r\n        user.id\r\n      );\r\n      if (userMissions.length > 0) {\r\n        const resultDelete = [];\r\n        await Promise.all(\r\n          userMissions.map(async (mission) => {\r\n            if (\r\n              mission.orderedOrganisationID === this.currentOrg.id ||\r\n              this.isSP\r\n            ) {\r\n              const deletedMission =\r\n                await this.missionService.softDeleteMission(mission.id);\r\n              if (deletedMission) {\r\n                resultDelete.push(deletedMission);\r\n              }\r\n            }\r\n          })\r\n        );\r\n        if (resultDelete.length > 0) {\r\n          await this.userService.softDeleteUser(user.id);\r\n          await this.resetList();\r\n        }\r\n      } else {\r\n        await this.userService.softDeleteUser(user.id);\r\n        await this.resetList();\r\n      }\r\n    }\r\n  }\r\n\r\n  applyResultsSearchBar(results) {\r\n    this.orgSelectedDetails = null;\r\n    this.filteredOrgsUsersMissions = results || this.orgsUsersMissions;\r\n  }\r\n\r\n  onAddInExistingOrg() {\r\n    this.hideList = true;\r\n    this.isAddingToExistingOrg = true;\r\n  }\r\n\r\n  /**\r\n   * Creates encypted link and sets it for guestLink for Space.\r\n   * @param mis\r\n   */\r\n  onSetForShareableLink(user: ProfileEntity, mission: Mission) {\r\n    const modalReference = this.modalService.open(GuestLinkComponent);\r\n    modalReference.componentInstance.username = user.email;\r\n    modalReference.componentInstance.spaceID = mission.spaceID;\r\n  }\r\n\r\n  async onClearToken(user) {\r\n    await this.userService.clearUserToken(user.user.id);\r\n    const firstMessage = this.translate.instant('firstTokenMessage');\r\n    const secondMessage = this.translate.instant('secondTokenMessage');\r\n    alert(firstMessage + user.user.displayName + secondMessage);\r\n  }\r\n}\r\n","<div class=\"dashboard-tab\">\r\n  <div class=\"header-dashboard-tab\">\r\n    <h3>{{'Users' | translate}}</h3>\r\n    <!-- <app-search-bar *ngIf=\"!hideList\" [searchable]=\"orgsUsersMissions\" objectType=\"USER\"\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-6\">\r\n      <div class=\"row ml-0 mb-2\" *ngIf=\"!hideList\">\r\n        <button class=\"btn btn-outline-primary rounded-pill add-button\" *ngIf=\"isManager && !isGuide\" (click)=\"onAddOrg()\">\r\n          {{'Add user to new organisation' | 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=\"!hideList\">\r\n        <ul class=\"list-group list-group-flush\" *ngIf=\"filteredOrgsUsersMissions\">\r\n          <li class=\"list-group-item list-group-item-action\" *ngFor=\"let o of filteredOrgsUsersMissions\">\r\n            <div class=\"d-flex justify-content-between align-items-center font-weight-bold\"\r\n              ngbTooltip=\"See details and users\" style=\"cursor: pointer;\" (click)=\"onToggleDetailOrg(o.org.id, o.org)\">\r\n              {{o.org.name}} <small *ngIf=\"o.org.id == currentOrg.id\">({{'My organisation' | translate}})</small>\r\n              <small *ngIf=\"isSP && clientsSP.includes(o.org.id)\">({{'Client of SmarterPlan' | translate}})</small>\r\n              <small *ngIf=\"isSP && getOrderedOrg(o.org.id)\">({{'Client of ' | translate}}\r\n                {{getOrderedOrg(o.org.id)}})</small>\r\n              <lib-chevron [conditionShowing]=\"detailsOrg==o.org.id\"></lib-chevron>\r\n            </div>\r\n            <div class=\"missions\" *ngIf=\"detailsOrg==o.org.id\">\r\n              <div class='d-flex'>\r\n                <button class=\"btn btn-outline-primary rounded-pill mt-3 mb-3\" (click)=\"onAdd(o.org)\">{{'Add user' |\r\n                  translate}}</button>\r\n              </div>\r\n\r\n              <ul class=\"list-group list-group-flush\">\r\n                <li class=\"list-group-item list-group-item-action\" *ngFor=\"let a of o.users\"\r\n                  (click)=\"onToggleDetailUser(a.user.id)\">\r\n                  <div class=\"d-flex justify-content-between align-items-center\">\r\n                    {{a.user.displayName}}\r\n                    <lib-chevron [conditionShowing]=\"detailsUser==a.user.id\"></lib-chevron>\r\n                  </div>\r\n\r\n                  <div *ngIf=\"detailsUser==a.user.id\">\r\n                    <div class=\"ml-3\">\r\n                      <div class=\"d-flex justify-content-between align-items-center mt-3\">\r\n                        {{'Email' | translate}}: {{a.user.email }}\r\n                      </div>\r\n                      <div class=\"d-flex justify-content-between align-items-center mt-3\">\r\n                        <button type=\"button\" class=\"btn btn-primary rounded-pill\"\r\n                          (click)=\"onAddForUser(o.org, a.user)\">{{'Add new mission' | translate}}</button>\r\n                        <button type=\"button\" class=\"btn btn-primary rounded-pill\" (click)=\"onClearToken(a)\">\r\n                          {{'Clear Token' | translate}}</button>\r\n                        <button type=\"button\" class=\"btn btn-primary rounded-pill\"\r\n                          (click)=\"onDeleteUser(a.user)\">{{'Delete user' | translate}}</button>\r\n                      </div>\r\n                      <div class=\"d-flex justify-content-between align-items-center mt-3\">\r\n                        {{ a.missions.length > 0 ? ('Current Missions' | translate) : ('No missions' | translate)}}\r\n                      </div>\r\n                    </div>\r\n                    <ul class=\"list-group list-group-flush\">\r\n                      <li class=\"list-group-item\" *ngFor=\"let mis of a.missions\">\r\n                        <ul class=\"list-group list-group-flush\">\r\n                          <li class=\"list-group-item bg-transparent\" *ngIf=\"mis.description\">\r\n                            {{'Description' | translate}}: {{mis.description}}</li>\r\n                          <li class=\"list-group-item bg-transparent\" *ngIf=\"mis.templateMissionID\">\r\n                            {{'Attendee of tour' | translate}}: {{mis.templateMission.title}}</li>\r\n\r\n                          <li class=\"list-group-item bg-transparent\">{{'Role' | translate}}: {{ mis.role }}</li>\r\n                          <li class=\"list-group-item bg-transparent\" *ngIf=\"mis.hashtags && mis.hashtags.length> 0\">\r\n                            {{'Hashtags' | translate}}: <ul class=\"keywordsDisplay no-border\">\r\n                              <div class=\"keywordsdisplayContainer\">\r\n                                <li class=\"keywordsItem\" *ngFor=\"let hashtag of mis.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\">{{'Language' | translate }}: {{\r\n                            mis.locale ? mis.locale : ('Not applicable' | translate)}}</li>\r\n                          <li class=\"list-group-item bg-transparent\">{{'Access level' | translate }}: {{\r\n                            mis.level}}</li>\r\n                          <li class=\"list-group-item bg-transparent\">{{'Ordered by' | translate }}: {{\r\n                            mis.orderedOrganisation.name}}</li>\r\n                          <li class=\"list-group-item bg-transparent\" *ngIf=\"mis.domains\">{{'Domains' | translate }}:\r\n                            {{mis.domains ?\r\n                            domainIdsToStringForMission(mis) : (\"No data\" | translate) }}</li>\r\n                          <li class=\"list-group-item bg-transparent\">{{'Authorized location' | translate }}:\r\n                            {{ mis.space ? mis.space.name : \"No location\" | translate}}</li>\r\n                          <li class=\"list-group-item bg-transparent\">{{'Authorized zone' | translate }}:\r\n                            {{ mis.zone ? mis.zone.name : \"All zones allowed\" | translate}}</li>\r\n                          <li class=\"list-group-item bg-transparent\">{{'Starts' | translate }}:\r\n                            {{ mis.startDateTime ? (mis.startDateTime | timeDateString: \"day_time_zone\" | async) :\r\n                            \"No data\" | translate}}, {{'Ends' | translate}}: {{ mis.endDateTime\r\n                            ? (mis.endDateTime | timeDateString: \"day_time_zone\" | async)\r\n                            : \"No data\" | translate}}.\r\n                          </li>\r\n                        </ul>\r\n                        <div class=\"action-button-container\">\r\n                          <button type=\"button\" class=\"btn btn-outline-primary rounded-pill mr-2 action-button\"\r\n                            (click)=\"onEdit(mis)\">{{'Edit' |\r\n                            translate}}</button>\r\n                          <button type=\"button\" *ngIf=\"mis.role === 'VISITOR' || mis.role === 'VISITOR_MUSEUM'\"\r\n                            class=\"btn btn-outline-primary rounded-pill mr-2 action-button share-visitor-button\"\r\n                            (click)=\"onSetForShareableLink(a.user, mis)\">{{'Generate Shareable Link' |\r\n                            translate}}</button>\r\n                          <button type=\"button\" class=\"btn btn-outline-primary rounded-pill action-button\"\r\n                            (click)=\"onDeleteMission(mis)\">{{'Delete' | translate}}</button>\r\n                        </div>\r\n                      </li>\r\n                    </ul>\r\n                  </div>\r\n                </li>\r\n              </ul>\r\n            </div>\r\n          </li>\r\n        </ul>\r\n      </div>\r\n\r\n      <div *ngIf=\"create\">\r\n        <lib-user-mission-form [addToOrganisation]=\"addToOrg\" [currentOrg]=\"currentOrg\" [isSP]=\"isSP\"\r\n          (added)=\"userAdded($event)\">\r\n        </lib-user-mission-form>\r\n      </div>\r\n      <div *ngIf=\"edit\">\r\n        <lib-form-mission [missionToEdit]=\"missionToEdit\" [currentUserOrganisation]=\"currentOrg\" [isSP]=\"isSP\"\r\n          (addedMissionInput)=\"onMissionEdited($event)\"></lib-form-mission>\r\n      </div>\r\n      <div *ngIf=\"createForExistingUser\">\r\n        <lib-form-mission [organisationForMission]=\"addToOrg\" [currentUserOrganisation]=\"currentOrg\" [isSP]=\"isSP\"\r\n          [userForMissionID]=\"userForAddingMission.id\" (addedMissionInput)=\"onMissionCreated($event)\">\r\n        </lib-form-mission>\r\n      </div>\r\n      <div *ngIf=\"isAddingOrg || isAddingToExistingOrg\">\r\n        <lib-form-organisation [currentOrg]=\"currentOrg\" [currentUser]=\"me\" [existing]=\"isAddingToExistingOrg\"\r\n          (added)=\"orgAdded($event)\"></lib-form-organisation>\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"col-md-4 col-lg-6\" *ngIf=\"orgSelectedDetails && !isGuide\">\r\n      <lib-detail-organisation [org]=\"orgSelectedDetails\" [currentOrg]=\"currentOrg\" [isSP]=\"isSP\"\r\n        (orgChanged)='orgAdded($event)'></lib-detail-organisation>\r\n    </div>\r\n  </div>\r\n</div>"]}