@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,108 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { validEmail, RoleStatus } from 'ngx-smarterplan-core';
3
+ import * as Papa from 'papaparse';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "ngx-smarterplan-core";
6
+ import * as i2 from "@ngx-translate/core";
7
+ import * as i3 from "@angular/common";
8
+ export class CreateBatchComponent {
9
+ constructor(missionService, userService, translate) {
10
+ this.missionService = missionService;
11
+ this.userService = userService;
12
+ this.translate = translate;
13
+ this.createdMissions = new EventEmitter();
14
+ this.addedEmails = [];
15
+ this.working = false;
16
+ }
17
+ ngOnInit() { }
18
+ onAddEmail(value) {
19
+ if (value) {
20
+ if (validEmail(value)) {
21
+ this.addedEmails.push(value);
22
+ }
23
+ else {
24
+ alert("Please, enter a valid email address");
25
+ }
26
+ }
27
+ }
28
+ onDelete(index) {
29
+ this.addedEmails.splice(index, 1);
30
+ }
31
+ onCancel() {
32
+ this.createdMissions.emit(null);
33
+ }
34
+ async onCreateMissions() {
35
+ const createdMissions = [];
36
+ let user;
37
+ this.working = true;
38
+ await Promise.all(this.addedEmails.map(async (mail) => {
39
+ user = await this.userService.profileForMail(mail);
40
+ if (!user) {
41
+ try {
42
+ const profile = await this.userService.createUserAWSandProfile({
43
+ email: mail,
44
+ lastName: mail,
45
+ firstName: "",
46
+ phone: "",
47
+ }, true);
48
+ user = profile;
49
+ }
50
+ catch (error) {
51
+ alert(`Error creating users: ${this.translate.instant(error)}`);
52
+ this.working = false;
53
+ return;
54
+ }
55
+ }
56
+ if (user) {
57
+ const missionInput = {
58
+ organisationID: this.template.organisationID,
59
+ orderedOrganisationID: this.template.organisationID,
60
+ level: this.template.level,
61
+ role: RoleStatus.VISITOR_MUSEUM,
62
+ description: "Generated from template",
63
+ userID: user.id,
64
+ startDateTime: this.template.startDateTime,
65
+ endDateTime: this.template.endDateTime,
66
+ spaceID: this.template.spaceID,
67
+ zoneID: this.template.zoneID,
68
+ templateMissionID: this.template.id,
69
+ hashtags: this.template.hashtags,
70
+ };
71
+ const mission = await this.missionService.create(missionInput);
72
+ createdMissions.push(mission);
73
+ }
74
+ }));
75
+ this.working = false;
76
+ this.createdMissions.emit(createdMissions);
77
+ this.addedEmails = [];
78
+ }
79
+ async handleFileInput(eventTarget) {
80
+ const files = eventTarget.files;
81
+ const uploaded = files.item(0);
82
+ if (uploaded.name.includes(".csv")) {
83
+ Papa.parse(uploaded, {
84
+ complete: function onComplete(results) {
85
+ for (const mail of results.data) {
86
+ this.addedEmails.push(mail[0]);
87
+ }
88
+ console.log(this.addedEmails);
89
+ // eslint-disable-next-line no-extra-bind
90
+ }.bind(this),
91
+ });
92
+ }
93
+ else {
94
+ alert("Not a csv file");
95
+ }
96
+ }
97
+ }
98
+ CreateBatchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: CreateBatchComponent, deps: [{ token: i1.MissionService }, { token: i1.BaseUserService }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
99
+ CreateBatchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: CreateBatchComponent, selector: "lib-create-batch", inputs: { template: "template" }, outputs: { createdMissions: "createdMissions" }, ngImport: i0, template: "<div>\r\n <h4>{{'Add email address' | translate}}</h4>\r\n <div class=\"row\">\r\n <input class=\"form-control custom-form\" #box (keyup.enter)=\"onAddEmail(box.value); box.value=''\"\r\n placeholder=\"me@example.com\">\r\n <div class=\"outer_circle\" style='margin-left: 1.1em;'>\r\n <button id='btn-icon' (click)=\"onAddEmail(box.value); box.value=''\"></button>\r\n </div>\r\n </div>\r\n\r\n <div class=\"row mt-3\">\r\n <label for=\"file\" class=\"btn btn-label-file rounded-pill\">\r\n <input type=\"file\" id=\"file\" (change)=\"handleFileInput($event.target)\" />\r\n {{'Upload from csv' | translate}}</label>\r\n </div>\r\n\r\n <ul *ngIf=\"addedEmails.length > 0\">\r\n <li class=\"list_item\" *ngFor=\"let mail of addedEmails; index as index\">{{mail}}\r\n <div class=\"icon-container\" (click)=\"onDelete(index)\">\r\n <span class=\"iconify\" data-icon=\"mdi:trash-can-outline\"></span>\r\n </div>\r\n </li>\r\n </ul>\r\n <div class=\"d-flex justify-content-center\" *ngIf=\"working\">\r\n <lib-loader></lib-loader>\r\n </div>\r\n <div class=\"row action-button-container\">\r\n <button class=\"btn btn-outline-primary rounded-pill mr-2 mt-3 action-button\" (click)=\"onCreateMissions()\">\r\n {{'Create users' | translate}}</button>\r\n <button class=\"btn btn-outline-primary rounded-pill mr-2 mt-3 action-button\" (click)=\"onCancel()\">\r\n {{'Cancel' | translate}}</button>\r\n </div>\r\n\r\n</div>", styles: ["#btn-icon{width:30px;height:30px;background:url(../../../../assets/icons/plus.svg);border:none;vertical-align:middle}#btn-icon:hover{background:url(../../../../assets/icons/plus-over.svg)}#btn-icon[disabled]:hover{background:url(../../../../assets/icons/plus.svg)}.outer_circle{background-color:#ebebeb;border-radius:50%;width:32px;height:32px;padding:1px;margin-left:5px}.custom-form{width:80%}h4{color:var(--smarterplan-primary)}.pointer{cursor:pointer}.list_item{display:flex;font-size:1.1em}.icon-container{cursor:pointer;margin-left:5px}input[type=file]{display:none}.form-group{margin:1.5rem 0}label.col-sm-4.col-form-label{width:200px;min-width:200px}.action-button-container{display:flex;justify-content:space-evenly}.action-button-container .action-button{width:145px}\n"], components: [{ type: i1.LoaderComponent, selector: "lib-loader" }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i2.TranslatePipe } });
100
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: CreateBatchComponent, decorators: [{
101
+ type: Component,
102
+ args: [{ selector: 'lib-create-batch', template: "<div>\r\n <h4>{{'Add email address' | translate}}</h4>\r\n <div class=\"row\">\r\n <input class=\"form-control custom-form\" #box (keyup.enter)=\"onAddEmail(box.value); box.value=''\"\r\n placeholder=\"me@example.com\">\r\n <div class=\"outer_circle\" style='margin-left: 1.1em;'>\r\n <button id='btn-icon' (click)=\"onAddEmail(box.value); box.value=''\"></button>\r\n </div>\r\n </div>\r\n\r\n <div class=\"row mt-3\">\r\n <label for=\"file\" class=\"btn btn-label-file rounded-pill\">\r\n <input type=\"file\" id=\"file\" (change)=\"handleFileInput($event.target)\" />\r\n {{'Upload from csv' | translate}}</label>\r\n </div>\r\n\r\n <ul *ngIf=\"addedEmails.length > 0\">\r\n <li class=\"list_item\" *ngFor=\"let mail of addedEmails; index as index\">{{mail}}\r\n <div class=\"icon-container\" (click)=\"onDelete(index)\">\r\n <span class=\"iconify\" data-icon=\"mdi:trash-can-outline\"></span>\r\n </div>\r\n </li>\r\n </ul>\r\n <div class=\"d-flex justify-content-center\" *ngIf=\"working\">\r\n <lib-loader></lib-loader>\r\n </div>\r\n <div class=\"row action-button-container\">\r\n <button class=\"btn btn-outline-primary rounded-pill mr-2 mt-3 action-button\" (click)=\"onCreateMissions()\">\r\n {{'Create users' | translate}}</button>\r\n <button class=\"btn btn-outline-primary rounded-pill mr-2 mt-3 action-button\" (click)=\"onCancel()\">\r\n {{'Cancel' | translate}}</button>\r\n </div>\r\n\r\n</div>", styles: ["#btn-icon{width:30px;height:30px;background:url(../../../../assets/icons/plus.svg);border:none;vertical-align:middle}#btn-icon:hover{background:url(../../../../assets/icons/plus-over.svg)}#btn-icon[disabled]:hover{background:url(../../../../assets/icons/plus.svg)}.outer_circle{background-color:#ebebeb;border-radius:50%;width:32px;height:32px;padding:1px;margin-left:5px}.custom-form{width:80%}h4{color:var(--smarterplan-primary)}.pointer{cursor:pointer}.list_item{display:flex;font-size:1.1em}.icon-container{cursor:pointer;margin-left:5px}input[type=file]{display:none}.form-group{margin:1.5rem 0}label.col-sm-4.col-form-label{width:200px;min-width:200px}.action-button-container{display:flex;justify-content:space-evenly}.action-button-container .action-button{width:145px}\n"] }]
103
+ }], ctorParameters: function () { return [{ type: i1.MissionService }, { type: i1.BaseUserService }, { type: i2.TranslateService }]; }, propDecorators: { template: [{
104
+ type: Input
105
+ }], createdMissions: [{
106
+ type: Output
107
+ }] } });
108
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-batch.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-smarterplan-admin/src/lib/visitor/create-batch/create-batch.component.ts","../../../../../../projects/ngx-smarterplan-admin/src/lib/visitor/create-batch/create-batch.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Mission, MissionService, BaseUserService, Profile, validEmail, VisitTemplate, RoleStatus } from 'ngx-smarterplan-core';\r\nimport * as Papa from 'papaparse';\r\n\r\n@Component({\r\n  selector: 'lib-create-batch',\r\n  templateUrl: './create-batch.component.html',\r\n  styleUrls: ['./create-batch.component.scss']\r\n})\r\nexport class CreateBatchComponent implements OnInit {\r\n    @Input() template: VisitTemplate;\r\n\r\n    @Output() createdMissions = new EventEmitter<Mission[]>();\r\n\r\n    addedEmails: string[] = [];\r\n\r\n    csvFile: File;\r\n\r\n    working = false;\r\n\r\n    constructor(\r\n        private missionService: MissionService,\r\n        private userService: BaseUserService,\r\n        private translate: TranslateService,\r\n    ) {}\r\n\r\n    ngOnInit(): void {}\r\n\r\n    onAddEmail(value: string) {\r\n        if (value) {\r\n            if (validEmail(value)) {\r\n                this.addedEmails.push(value);\r\n            } else {\r\n                alert(\"Please, enter a valid email address\");\r\n            }\r\n        }\r\n    }\r\n\r\n    onDelete(index) {\r\n        this.addedEmails.splice(index, 1);\r\n    }\r\n\r\n    onCancel() {\r\n        this.createdMissions.emit(null);\r\n    }\r\n\r\n    async onCreateMissions() {\r\n        const createdMissions = [];\r\n        let user: Profile;\r\n        this.working = true;\r\n        await Promise.all(\r\n            this.addedEmails.map(async (mail) => {\r\n                user = await this.userService.profileForMail(mail);\r\n                if (!user) {\r\n                    try {\r\n                        const profile =\r\n                            await this.userService.createUserAWSandProfile(\r\n                                {\r\n                                    email: mail,\r\n                                    lastName: mail,\r\n                                    firstName: \"\",\r\n                                    phone: \"\",\r\n                                },\r\n                                true,\r\n                            );\r\n                        user = profile;\r\n                    } catch (error) {\r\n                        alert(\r\n                            `Error creating users: ${this.translate.instant(\r\n                                error as string,\r\n                            )}`,\r\n                        );\r\n                        this.working = false;\r\n                        return;\r\n                    }\r\n                }\r\n                if (user) {\r\n                    const missionInput: Mission = {\r\n                        organisationID: this.template.organisationID,\r\n                        orderedOrganisationID: this.template.organisationID,\r\n                        level: this.template.level,\r\n                        role: RoleStatus.VISITOR_MUSEUM,\r\n                        description: \"Generated from template\",\r\n                        userID: user.id,\r\n                        startDateTime: this.template.startDateTime,\r\n                        endDateTime: this.template.endDateTime,\r\n                        spaceID: this.template.spaceID,\r\n                        zoneID: this.template.zoneID,\r\n                        templateMissionID: this.template.id,\r\n                        hashtags: this.template.hashtags,\r\n                    };\r\n                    const mission = await this.missionService.create(\r\n                        missionInput,\r\n                    );\r\n                    createdMissions.push(mission);\r\n                }\r\n            }),\r\n        );\r\n        this.working = false;\r\n        this.createdMissions.emit(createdMissions);\r\n        this.addedEmails = [];\r\n    }\r\n\r\n    async handleFileInput(eventTarget: any) {\r\n        const files= eventTarget.files;\r\n        const uploaded = files.item(0);\r\n        if (uploaded.name.includes(\".csv\")) {\r\n            Papa.parse(uploaded, {\r\n                complete: function onComplete(results) {\r\n                    for (const mail of results.data) {\r\n                        this.addedEmails.push(mail[0]);\r\n                    }\r\n                    console.log(this.addedEmails);\r\n                    // eslint-disable-next-line no-extra-bind\r\n                }.bind(this),\r\n            });\r\n        } else {\r\n            alert(\"Not a csv file\");\r\n        }\r\n    }\r\n\r\n}\r\n","<div>\r\n    <h4>{{'Add email address' | translate}}</h4>\r\n    <div class=\"row\">\r\n        <input class=\"form-control custom-form\" #box (keyup.enter)=\"onAddEmail(box.value); box.value=''\"\r\n            placeholder=\"me@example.com\">\r\n        <div class=\"outer_circle\" style='margin-left: 1.1em;'>\r\n            <button id='btn-icon' (click)=\"onAddEmail(box.value); box.value=''\"></button>\r\n        </div>\r\n    </div>\r\n\r\n    <div class=\"row mt-3\">\r\n        <label for=\"file\" class=\"btn btn-label-file rounded-pill\">\r\n            <input type=\"file\" id=\"file\" (change)=\"handleFileInput($event.target)\" />\r\n            {{'Upload from csv' | translate}}</label>\r\n    </div>\r\n\r\n    <ul *ngIf=\"addedEmails.length > 0\">\r\n        <li class=\"list_item\" *ngFor=\"let mail of addedEmails; index as index\">{{mail}}\r\n            <div class=\"icon-container\" (click)=\"onDelete(index)\">\r\n                <span class=\"iconify\" data-icon=\"mdi:trash-can-outline\"></span>\r\n            </div>\r\n        </li>\r\n    </ul>\r\n    <div class=\"d-flex justify-content-center\" *ngIf=\"working\">\r\n        <lib-loader></lib-loader>\r\n    </div>\r\n    <div class=\"row action-button-container\">\r\n        <button class=\"btn btn-outline-primary rounded-pill mr-2 mt-3 action-button\" (click)=\"onCreateMissions()\">\r\n            {{'Create users' | translate}}</button>\r\n        <button class=\"btn btn-outline-primary rounded-pill mr-2 mt-3 action-button\" (click)=\"onCancel()\">\r\n            {{'Cancel' | translate}}</button>\r\n    </div>\r\n\r\n</div>"]}
@@ -0,0 +1,219 @@
1
+ import { Component } from '@angular/core';
2
+ import { Validators } from '@angular/forms';
3
+ import { LevelStatus, Locale, stringLocaleToEnum, enumToArray, sortAlphabeticallyOnName } from 'ngx-smarterplan-core';
4
+ import { DateTime } from "luxon";
5
+ import { Input } from '@angular/core';
6
+ import { Output } from '@angular/core';
7
+ import { EventEmitter } from '@angular/core';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@angular/router";
10
+ import * as i2 from "@angular/forms";
11
+ import * as i3 from "ngx-smarterplan-core";
12
+ import * as i4 from "@angular/common";
13
+ import * as i5 from "@ngx-translate/core";
14
+ import * as i6 from "@ng-bootstrap/ng-bootstrap";
15
+ export class TemplateComponent {
16
+ constructor(route, fb, userService, spaceService, zoneService, location, hashtagService, translate, templateService) {
17
+ this.route = route;
18
+ this.fb = fb;
19
+ this.userService = userService;
20
+ this.spaceService = spaceService;
21
+ this.zoneService = zoneService;
22
+ this.location = location;
23
+ this.hashtagService = hashtagService;
24
+ this.translate = translate;
25
+ this.templateService = templateService;
26
+ this.updatedTemplate = new EventEmitter();
27
+ this.createdTemplate = new EventEmitter();
28
+ this.working = false;
29
+ this.missionTimeStart = 12 * 60 * 60000; // midday in milliseconds
30
+ this.missionTimeEnd = 12 * 60 * 60000;
31
+ this.availableHashtags = [];
32
+ this.addedHashtags = [];
33
+ this.userService.isChanged.subscribe(() => {
34
+ this.updateUserInfo();
35
+ });
36
+ }
37
+ ngOnInit() {
38
+ this.setup();
39
+ const lang = this.translate.currentLang
40
+ ? this.translate.currentLang
41
+ : this.translate.defaultLang;
42
+ /** Transforme '_fr' to 'fr' */
43
+ this.currentLocale = stringLocaleToEnum(lang.slice(1)); // to match enum Locale
44
+ this.locales = enumToArray(Locale);
45
+ }
46
+ async setup() {
47
+ this.initForm();
48
+ if (this.zoneID) {
49
+ this.inputZone = await this.zoneService.getZone(this.zoneID);
50
+ await this.setHashtags(this.inputZone.spaceID);
51
+ }
52
+ if (this.editTemplate) {
53
+ // we are editing a template
54
+ this.onSpaceClick();
55
+ }
56
+ await this.updateUserInfo();
57
+ }
58
+ async updateUserInfo() {
59
+ if (this.userService.cu) {
60
+ this.availableLevels =
61
+ this.userService.getAvalableLevelsForCurrentUser();
62
+ this.currentOrg = this.userService.currentOrganisation();
63
+ this.availableSpaces = await this.spaceService.getSpacesForOrg(this.currentOrg.id);
64
+ }
65
+ }
66
+ initForm() {
67
+ if (this.editTemplate) {
68
+ this.form = this.fb.group({
69
+ title: [this.editTemplate.title],
70
+ level: [this.editTemplate.level],
71
+ organisationID: [this.editTemplate.organisationID],
72
+ space: [this.editTemplate.spaceID],
73
+ description: [this.editTemplate.description],
74
+ zone: [
75
+ this.editTemplate.zoneID,
76
+ Validators.required,
77
+ ],
78
+ locale: [this.editTemplate.locale],
79
+ });
80
+ if (this.editTemplate.startDateTime) {
81
+ const date = DateTime.fromISO(this.editTemplate.startDateTime);
82
+ this.missionTimeStart = (date.hour * 60 + date.minute) * 60 * 1000;
83
+ this.startDate = date.toMillis() - this.missionTimeStart;
84
+ }
85
+ if (this.editTemplate.endDateTime) {
86
+ const date = DateTime.fromISO(this.editTemplate.endDateTime);
87
+ this.missionTimeEnd = (date.hour * 60 + date.minute) * 60 * 1000;
88
+ this.endDate = date.toMillis() - this.missionTimeEnd;
89
+ }
90
+ }
91
+ else {
92
+ this.form = this.fb.group({
93
+ title: [""],
94
+ level: [LevelStatus.MINIMUM],
95
+ organisationID: this.currentOrg.id,
96
+ space: this.inputZone ? this.inputZone.spaceID : [null],
97
+ description: [null],
98
+ zone: [
99
+ this.inputZone ? this.inputZone.id : null,
100
+ Validators.required,
101
+ ],
102
+ locale: [this.currentLocale],
103
+ });
104
+ }
105
+ }
106
+ async onSubmit() {
107
+ this.working = true;
108
+ const formValue = this.form.getRawValue();
109
+ let startDateString;
110
+ let endDateString;
111
+ if (this.startDate) {
112
+ const dateHourStartNumber = this.startDate + this.missionTimeStart;
113
+ const startDate = DateTime.fromMillis(dateHourStartNumber);
114
+ startDateString = startDate.toISO();
115
+ }
116
+ if (this.endDate) {
117
+ const dateHourEndNumber = this.endDate + this.missionTimeEnd;
118
+ const endDate = DateTime.fromMillis(dateHourEndNumber);
119
+ endDateString = endDate.toISO();
120
+ }
121
+ try {
122
+ if (this.editTemplate) {
123
+ // update
124
+ const template = {
125
+ id: this.editTemplate.id,
126
+ title: formValue.title,
127
+ level: formValue.level,
128
+ description: formValue.description,
129
+ organisationID: formValue.organisationID,
130
+ startDateTime: startDateString,
131
+ endDateTime: endDateString,
132
+ hashtags: this.addedHashtags.map((hashtag) => hashtag.id),
133
+ locale: formValue.locale,
134
+ };
135
+ if (formValue.space) {
136
+ template.spaceID = formValue.space;
137
+ }
138
+ if (formValue.zone) {
139
+ template.zoneID = formValue.zone;
140
+ }
141
+ this.updatedTemplate.emit(template);
142
+ }
143
+ else {
144
+ //create
145
+ if (this.currentOrg) {
146
+ const template = {
147
+ title: formValue.title,
148
+ organisationID: this.currentOrg.id,
149
+ level: formValue.level,
150
+ description: formValue.description,
151
+ startDateTime: startDateString,
152
+ endDateTime: endDateString,
153
+ hashtags: this.addedHashtags.map((hashtag) => hashtag.id),
154
+ locale: formValue.locale,
155
+ };
156
+ if (formValue.space) {
157
+ template.spaceID = formValue.space;
158
+ }
159
+ if (formValue.zone) {
160
+ template.zoneID = formValue.zone;
161
+ }
162
+ this.createdTemplate.emit(template);
163
+ }
164
+ }
165
+ }
166
+ catch (error) {
167
+ console.error(error);
168
+ }
169
+ }
170
+ onCancel() {
171
+ this.form = null;
172
+ if (this.editTemplate) {
173
+ this.updatedTemplate.emit(null);
174
+ }
175
+ else {
176
+ this.createdTemplate.emit(null);
177
+ }
178
+ }
179
+ get title() {
180
+ return this.form.get("title");
181
+ }
182
+ get spaceID() {
183
+ return this.form.get("space");
184
+ }
185
+ async onSpaceClick() {
186
+ const zones = await this.zoneService.getZonesBySpace(this.spaceID.value);
187
+ const museumZones = zones.filter((zone) => zone.isMuseumVisitZone);
188
+ this.zonesForSpace = sortAlphabeticallyOnName(museumZones);
189
+ await this.setHashtags(this.spaceID.value);
190
+ }
191
+ onHashtagClick(hashtag) {
192
+ if (!this.addedHashtags.includes(hashtag)) {
193
+ this.addedHashtags.push(hashtag);
194
+ }
195
+ else {
196
+ this.addedHashtags.splice(this.addedHashtags.indexOf(hashtag), 1);
197
+ }
198
+ }
199
+ async setHashtags(spaceID) {
200
+ this.availableHashtags = await this.hashtagService.getHashtagsForSpace(spaceID);
201
+ }
202
+ }
203
+ TemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: TemplateComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.FormBuilder }, { token: i3.BaseUserService }, { token: i3.SpaceService }, { token: i3.ZoneService }, { token: i4.Location }, { token: i3.HashtagService }, { token: i5.TranslateService }, { token: i3.TemplateService }], target: i0.ɵɵFactoryTarget.Component });
204
+ TemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: TemplateComponent, selector: "lib-template", inputs: { currentOrg: "currentOrg", editTemplate: "editTemplate", zoneID: "zoneID" }, outputs: { updatedTemplate: "updatedTemplate", createdTemplate: "createdTemplate" }, ngImport: i0, template: "<div class=\"form-container\" *ngIf=\"form\">\r\n <div>\r\n <h4>{{ 'Visit Template' | translate }}</h4>\r\n </div>\r\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\">\r\n <div>\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-4 col-form-label\">{{'Visit Title' | translate}} *</label>\r\n <div class=\"col-sm-8\">\r\n <input type=\"text\" class=\"form-control\"\r\n placeholder=\"Edvard Munch - \u00AB Un po\u00E8me d\u2019amour, de vie et de mort \u00BB\"\r\n [class.is-invalid]=\"title.invalid && title.touched\" required\r\n formControlName=\"title\">\r\n </div>\r\n </div>\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-4 col-form-label\">{{'Description' | translate}}</label>\r\n <div class=\"col-sm-8\">\r\n <textarea class=\"form-control\" formControlName=\"description\" style=\"height:200px\"\r\n placeholder=\"Cette visite d\u20191h30 vous pr\u00E9sentera les \u0153uvres embl\u00E9matiques du c\u00E9l\u00E8bre peintre norv\u00E9gien Edvard Munch (1863-1944)...\"></textarea>\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\">{{'Language' | translate}}</label>\r\n <div class=\"col-sm-8\">\r\n <select class=\"form-control\" formControlName=\"locale\">\r\n <option [ngValue]=\"null\">{{'Not applicable' | translate}}</option>\r\n <option *ngFor=\"let locale of locales\" [ngValue]=\"locale\">\r\n {{ locale }}\r\n </option>\r\n </select>\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\">{{'Level' | translate}}</label>\r\n <div class=\"col-sm-8\">\r\n <select class=\"form-control\" required formControlName=\"level\">\r\n <option *ngFor=\"let level of availableLevels\" [ngValue]=\"level\">\r\n {{ level }}\r\n </option>\r\n </select>\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\">{{ 'Authorized location' | translate }}*</label>\r\n <div class=\"col-sm-8\" *ngIf=\"availableSpaces && !inputZone\">\r\n <select class=\"form-control\" required formControlName=\"space\" (change)=\"onSpaceClick()\">\r\n <option *ngFor=\"let space of availableSpaces\" [ngValue]=\"space.id\">\r\n {{ space.name }}\r\n </option>\r\n </select>\r\n </div>\r\n <div class=\"col-sm-8\" *ngIf=\"!availableSpaces\">\r\n {{ 'No locations available' | translate}}\r\n </div>\r\n <div class=\"col-sm-8\" *ngIf=\"inputZone\">\r\n <input type=\"text\" class=\"form-control\" [value]=\"inputZone.space.name\" disabled>\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\">{{ 'Authorized zone' | translate }}*</label>\r\n <div class=\"col-sm-8\" *ngIf=\"zonesForSpace && zonesForSpace.length > 0 && !inputZone\">\r\n <select class=\"form-control\" required formControlName=\"zone\">\r\n <option *ngFor=\"let zone of zonesForSpace\" [ngValue]=\"zone.id\">\r\n {{ zone.name }}\r\n </option>\r\n </select>\r\n </div>\r\n <div class=\"col-sm-8\" *ngIf=\"zonesForSpace && zonesForSpace.length === 0 && !inputZone\">\r\n <p class=\"warning col-form-label\">{{\"No Museum Zones found for this location\"| translate}}</p>\r\n </div>\r\n <div class=\"col-sm-8\" *ngIf=\"inputZone\">\r\n <input type=\"text\" class=\"form-control\" [value]=\"inputZone.name\" disabled>\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\">{{'Hashtags' | translate}}</label>\r\n <div class=\"col-sm-8\" *ngIf=\"spaceID.value\">\r\n <p class=\"keywordsRules\" *ngIf=\"availableHashtags.length > 0\">{{'Available hashtags' | translate}}\r\n </p>\r\n <p class=\"keywordsRules\" *ngIf=\"availableHashtags.length === 0\">{{'No hashtags created for this\r\n location' | translate}} </p>\r\n <div *ngIf=\"availableHashtags.length > 0\">\r\n <ul class=\"keywordsDisplay no-border\">\r\n <div class=\"keywordsdisplayContainer\">\r\n <li [class]=\"addedHashtags.includes(hashtag) ? 'keywordsItem added' : 'keywordsItem'\"\r\n *ngFor=\"let hashtag of availableHashtags\" (click)=\"onHashtagClick(hashtag)\"\r\n style=\"cursor: pointer;\"\r\n ngbTooltip=\"{{addedHashtags.includes(hashtag) ? ('Remove'|translate) : ('Add'|translate) }}\">\r\n {{hashtag.name}}</li>\r\n </div>\r\n </ul>\r\n <p class=\"keywordsRules\">{{'Added hashtags' | translate}} </p>\r\n <ul class=\"keywordsDisplay\">\r\n <div class=\"keywordsdisplayContainer\" *ngIf=\"addedHashtags.length> 0\">\r\n <li class=\"keywordsItem\" *ngFor=\"let hashtag of addedHashtags\">{{ hashtag.name }}</li>\r\n </div>\r\n </ul>\r\n </div>\r\n </div>\r\n <div class=\"col-sm-8\" *ngIf=\"!spaceID.value\">\r\n <p class=\"keywordsRules\">{{'You need to choose the location first' | translate}} </p>\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\">{{'Start Date' | translate}}</label>\r\n <div class=\"input-group col-sm-8\">\r\n <input class=\"form-control\" placeholder=\"dd/mm/yyyy\" [(ngModel)]=\"startDate\" ngbDatepicker\r\n #d1=\"ngbDatepicker\" [ngModelOptions]=\"{standalone: true}\">\r\n <div class=\"input-group-append\">\r\n <button class=\"btn btn-outline-secondary calendar\" (click)=\"d1.toggle()\" type=\"button\"></button>\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\">{{'Start Time' | translate}}</label>\r\n <div class=\"input-group col-sm-8\">\r\n <ngb-timepicker [(ngModel)]=\"missionTimeStart\" [ngModelOptions]=\"{standalone: true}\">\r\n </ngb-timepicker>\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\">{{'End Date' | translate}}</label>\r\n <div class=\"input-group col-sm-8\">\r\n <input class=\"form-control\" placeholder=\"dd/mm/yyyy\" [(ngModel)]=\"endDate\" ngbDatepicker\r\n #d2=\"ngbDatepicker\" [ngModelOptions]=\"{standalone: true}\">\r\n <div class=\"input-group-append\">\r\n <button class=\"btn btn-outline-secondary calendar\" (click)=\"d2.toggle()\" type=\"button\"></button>\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\">{{'End Time' | translate}}</label>\r\n <div class=\"input-group col-sm-8\">\r\n <ngb-timepicker [(ngModel)]=\"missionTimeEnd\" [ngModelOptions]=\"{standalone: true}\"></ngb-timepicker>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n <div class=\"btn-control-div action-button-container\">\r\n <button type=\"submit\" class=\"btn btn-outline-primary rounded-pill action-button\"\r\n [disabled]=\"this.working || form.invalid\">{{'Save' | translate}}</button>\r\n <button type=\"button\" (click)=\"onCancel()\" [disabled]=\"this.working\"\r\n class=\"btn btn-outline-primary rounded-pill action-button\">{{'Cancel' | translate}}</button>\r\n </div>\r\n\r\n </form>\r\n</div>", styles: [".form-container{margin:2rem 0rem}.form-container .btn-control-div .btn{width:8rem}.warning{margin:0;color:red}.keywordsDisplay{min-height:40px}.keywordsRules{margin-bottom:2px}.form-group{margin:1.5rem 0}label.col-sm-4.col-form-label{width:200px;min-width:200px}.action-button-container{display:flex;justify-content:space-evenly}.action-button-container .action-button{width:145px!important}\n"], components: [{ type: i6.NgbTimepicker, selector: "ngb-timepicker", inputs: ["meridian", "spinners", "seconds", "hourStep", "minuteStep", "secondStep", "readonlyInputs", "size"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i2.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: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "triggers", "container", "disableTooltip", "tooltipClass", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { type: i6.NgbInputDatepicker, selector: "input[ngbDatepicker]", inputs: ["autoClose", "datepickerClass", "dayTemplate", "dayTemplateData", "displayMonths", "firstDayOfWeek", "footerTemplate", "markDisabled", "minDate", "maxDate", "navigation", "outsideDays", "placement", "restoreFocus", "showWeekNumbers", "startDate", "container", "positionTarget", "weekdays", "disabled"], outputs: ["dateSelect", "navigate", "closed"], exportAs: ["ngbDatepicker"] }, { type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "translate": i5.TranslatePipe } });
205
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: TemplateComponent, decorators: [{
206
+ type: Component,
207
+ args: [{ selector: 'lib-template', template: "<div class=\"form-container\" *ngIf=\"form\">\r\n <div>\r\n <h4>{{ 'Visit Template' | translate }}</h4>\r\n </div>\r\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\">\r\n <div>\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-4 col-form-label\">{{'Visit Title' | translate}} *</label>\r\n <div class=\"col-sm-8\">\r\n <input type=\"text\" class=\"form-control\"\r\n placeholder=\"Edvard Munch - \u00AB Un po\u00E8me d\u2019amour, de vie et de mort \u00BB\"\r\n [class.is-invalid]=\"title.invalid && title.touched\" required\r\n formControlName=\"title\">\r\n </div>\r\n </div>\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-4 col-form-label\">{{'Description' | translate}}</label>\r\n <div class=\"col-sm-8\">\r\n <textarea class=\"form-control\" formControlName=\"description\" style=\"height:200px\"\r\n placeholder=\"Cette visite d\u20191h30 vous pr\u00E9sentera les \u0153uvres embl\u00E9matiques du c\u00E9l\u00E8bre peintre norv\u00E9gien Edvard Munch (1863-1944)...\"></textarea>\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\">{{'Language' | translate}}</label>\r\n <div class=\"col-sm-8\">\r\n <select class=\"form-control\" formControlName=\"locale\">\r\n <option [ngValue]=\"null\">{{'Not applicable' | translate}}</option>\r\n <option *ngFor=\"let locale of locales\" [ngValue]=\"locale\">\r\n {{ locale }}\r\n </option>\r\n </select>\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\">{{'Level' | translate}}</label>\r\n <div class=\"col-sm-8\">\r\n <select class=\"form-control\" required formControlName=\"level\">\r\n <option *ngFor=\"let level of availableLevels\" [ngValue]=\"level\">\r\n {{ level }}\r\n </option>\r\n </select>\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\">{{ 'Authorized location' | translate }}*</label>\r\n <div class=\"col-sm-8\" *ngIf=\"availableSpaces && !inputZone\">\r\n <select class=\"form-control\" required formControlName=\"space\" (change)=\"onSpaceClick()\">\r\n <option *ngFor=\"let space of availableSpaces\" [ngValue]=\"space.id\">\r\n {{ space.name }}\r\n </option>\r\n </select>\r\n </div>\r\n <div class=\"col-sm-8\" *ngIf=\"!availableSpaces\">\r\n {{ 'No locations available' | translate}}\r\n </div>\r\n <div class=\"col-sm-8\" *ngIf=\"inputZone\">\r\n <input type=\"text\" class=\"form-control\" [value]=\"inputZone.space.name\" disabled>\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\">{{ 'Authorized zone' | translate }}*</label>\r\n <div class=\"col-sm-8\" *ngIf=\"zonesForSpace && zonesForSpace.length > 0 && !inputZone\">\r\n <select class=\"form-control\" required formControlName=\"zone\">\r\n <option *ngFor=\"let zone of zonesForSpace\" [ngValue]=\"zone.id\">\r\n {{ zone.name }}\r\n </option>\r\n </select>\r\n </div>\r\n <div class=\"col-sm-8\" *ngIf=\"zonesForSpace && zonesForSpace.length === 0 && !inputZone\">\r\n <p class=\"warning col-form-label\">{{\"No Museum Zones found for this location\"| translate}}</p>\r\n </div>\r\n <div class=\"col-sm-8\" *ngIf=\"inputZone\">\r\n <input type=\"text\" class=\"form-control\" [value]=\"inputZone.name\" disabled>\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\">{{'Hashtags' | translate}}</label>\r\n <div class=\"col-sm-8\" *ngIf=\"spaceID.value\">\r\n <p class=\"keywordsRules\" *ngIf=\"availableHashtags.length > 0\">{{'Available hashtags' | translate}}\r\n </p>\r\n <p class=\"keywordsRules\" *ngIf=\"availableHashtags.length === 0\">{{'No hashtags created for this\r\n location' | translate}} </p>\r\n <div *ngIf=\"availableHashtags.length > 0\">\r\n <ul class=\"keywordsDisplay no-border\">\r\n <div class=\"keywordsdisplayContainer\">\r\n <li [class]=\"addedHashtags.includes(hashtag) ? 'keywordsItem added' : 'keywordsItem'\"\r\n *ngFor=\"let hashtag of availableHashtags\" (click)=\"onHashtagClick(hashtag)\"\r\n style=\"cursor: pointer;\"\r\n ngbTooltip=\"{{addedHashtags.includes(hashtag) ? ('Remove'|translate) : ('Add'|translate) }}\">\r\n {{hashtag.name}}</li>\r\n </div>\r\n </ul>\r\n <p class=\"keywordsRules\">{{'Added hashtags' | translate}} </p>\r\n <ul class=\"keywordsDisplay\">\r\n <div class=\"keywordsdisplayContainer\" *ngIf=\"addedHashtags.length> 0\">\r\n <li class=\"keywordsItem\" *ngFor=\"let hashtag of addedHashtags\">{{ hashtag.name }}</li>\r\n </div>\r\n </ul>\r\n </div>\r\n </div>\r\n <div class=\"col-sm-8\" *ngIf=\"!spaceID.value\">\r\n <p class=\"keywordsRules\">{{'You need to choose the location first' | translate}} </p>\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\">{{'Start Date' | translate}}</label>\r\n <div class=\"input-group col-sm-8\">\r\n <input class=\"form-control\" placeholder=\"dd/mm/yyyy\" [(ngModel)]=\"startDate\" ngbDatepicker\r\n #d1=\"ngbDatepicker\" [ngModelOptions]=\"{standalone: true}\">\r\n <div class=\"input-group-append\">\r\n <button class=\"btn btn-outline-secondary calendar\" (click)=\"d1.toggle()\" type=\"button\"></button>\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\">{{'Start Time' | translate}}</label>\r\n <div class=\"input-group col-sm-8\">\r\n <ngb-timepicker [(ngModel)]=\"missionTimeStart\" [ngModelOptions]=\"{standalone: true}\">\r\n </ngb-timepicker>\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\">{{'End Date' | translate}}</label>\r\n <div class=\"input-group col-sm-8\">\r\n <input class=\"form-control\" placeholder=\"dd/mm/yyyy\" [(ngModel)]=\"endDate\" ngbDatepicker\r\n #d2=\"ngbDatepicker\" [ngModelOptions]=\"{standalone: true}\">\r\n <div class=\"input-group-append\">\r\n <button class=\"btn btn-outline-secondary calendar\" (click)=\"d2.toggle()\" type=\"button\"></button>\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\">{{'End Time' | translate}}</label>\r\n <div class=\"input-group col-sm-8\">\r\n <ngb-timepicker [(ngModel)]=\"missionTimeEnd\" [ngModelOptions]=\"{standalone: true}\"></ngb-timepicker>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n <div class=\"btn-control-div action-button-container\">\r\n <button type=\"submit\" class=\"btn btn-outline-primary rounded-pill action-button\"\r\n [disabled]=\"this.working || form.invalid\">{{'Save' | translate}}</button>\r\n <button type=\"button\" (click)=\"onCancel()\" [disabled]=\"this.working\"\r\n class=\"btn btn-outline-primary rounded-pill action-button\">{{'Cancel' | translate}}</button>\r\n </div>\r\n\r\n </form>\r\n</div>", styles: [".form-container{margin:2rem 0rem}.form-container .btn-control-div .btn{width:8rem}.warning{margin:0;color:red}.keywordsDisplay{min-height:40px}.keywordsRules{margin-bottom:2px}.form-group{margin:1.5rem 0}label.col-sm-4.col-form-label{width:200px;min-width:200px}.action-button-container{display:flex;justify-content:space-evenly}.action-button-container .action-button{width:145px!important}\n"] }]
208
+ }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.FormBuilder }, { type: i3.BaseUserService }, { type: i3.SpaceService }, { type: i3.ZoneService }, { type: i4.Location }, { type: i3.HashtagService }, { type: i5.TranslateService }, { type: i3.TemplateService }]; }, propDecorators: { currentOrg: [{
209
+ type: Input
210
+ }], editTemplate: [{
211
+ type: Input
212
+ }], zoneID: [{
213
+ type: Input
214
+ }], updatedTemplate: [{
215
+ type: Output
216
+ }], createdTemplate: [{
217
+ type: Output
218
+ }] } });
219
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"template.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-smarterplan-admin/src/lib/visitor/template/template.component.ts","../../../../../../projects/ngx-smarterplan-admin/src/lib/visitor/template/template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\r\nimport { FormGroup, FormBuilder, Validators, AbstractControl } from '@angular/forms';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Organisation, LevelStatus, Zone, Space, Hashtag, Locale, BaseUserService, SpaceService, ZoneService, stringLocaleToEnum, enumToArray, RoleStatus, sortAlphabeticallyOnName, HashtagService, Mission, VisitTemplate, TemplateService } from 'ngx-smarterplan-core';\r\nimport { DateTime } from \"luxon\";\r\nimport { Location } from '@angular/common';\r\nimport { Input } from '@angular/core';\r\nimport { Output } from '@angular/core';\r\nimport { EventEmitter } from '@angular/core';\r\n\r\n@Component({\r\n    selector: 'lib-template',\r\n    templateUrl: './template.component.html',\r\n    styleUrls: ['./template.component.scss']\r\n})\r\nexport class TemplateComponent implements OnInit {\r\n    @Input() currentOrg: Organisation;\r\n\r\n    @Input() editTemplate: VisitTemplate;\r\n\r\n    @Input() zoneID: string;\r\n\r\n    @Output() updatedTemplate = new EventEmitter<VisitTemplate>();\r\n\r\n    @Output() createdTemplate = new EventEmitter<VisitTemplate>();\r\n\r\n    form: FormGroup;\r\n\r\n    working = false;\r\n\r\n    startDate: number;\r\n\r\n    endDate: number;\r\n\r\n    zonesForSpace: Zone[];\r\n\r\n    availableLevels: LevelStatus[];\r\n\r\n    availableSpaces: Space[];\r\n\r\n    missionTimeStart: number = 12 * 60 * 60000; // midday in milliseconds\r\n\r\n    missionTimeEnd: number = 12 * 60 * 60000;\r\n\r\n    inputZone: Zone;\r\n\r\n    availableHashtags: Hashtag[] = [];\r\n\r\n    addedHashtags: Hashtag[] = [];\r\n\r\n    currentLocale: Locale;\r\n\r\n    locales: string[];\r\n\r\n\r\n    constructor(\r\n        private route: ActivatedRoute,\r\n        private fb: FormBuilder,\r\n        private userService: BaseUserService,\r\n        private spaceService: SpaceService,\r\n        private zoneService: ZoneService,\r\n        private location: Location,\r\n        private hashtagService: HashtagService,\r\n        private translate: TranslateService,\r\n        private templateService: TemplateService,\r\n    ) {\r\n        this.userService.isChanged.subscribe(() => {\r\n            this.updateUserInfo();\r\n        });\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this.setup();\r\n        const lang = this.translate.currentLang\r\n            ? this.translate.currentLang\r\n            : this.translate.defaultLang;\r\n\r\n        /** Transforme '_fr' to 'fr' */\r\n        this.currentLocale = stringLocaleToEnum(lang.slice(1)); // to match enum Locale\r\n        this.locales = enumToArray(Locale);\r\n    }\r\n\r\n    async setup() {\r\n        this.initForm();\r\n        if (this.zoneID) {\r\n            this.inputZone = await this.zoneService.getZone(this.zoneID);\r\n            await this.setHashtags(this.inputZone.spaceID);\r\n        }\r\n        if (this.editTemplate) {\r\n            // we are editing a template\r\n            this.onSpaceClick();\r\n        }\r\n        await this.updateUserInfo();\r\n\r\n    }\r\n\r\n    async updateUserInfo() {\r\n        if (this.userService.cu) {\r\n            this.availableLevels =\r\n                this.userService.getAvalableLevelsForCurrentUser();\r\n            this.currentOrg = this.userService.currentOrganisation();\r\n            this.availableSpaces = await this.spaceService.getSpacesForOrg(\r\n                this.currentOrg.id,\r\n            );\r\n        }\r\n    }\r\n\r\n    initForm() {\r\n        if (this.editTemplate) {\r\n            this.form = this.fb.group({\r\n                title: [this.editTemplate.title],\r\n                level: [this.editTemplate.level],\r\n                organisationID: [this.editTemplate.organisationID],\r\n                space: [this.editTemplate.spaceID],\r\n                description: [this.editTemplate.description],\r\n                zone: [\r\n                    this.editTemplate.zoneID,\r\n                    Validators.required,\r\n                ],\r\n                locale: [this.editTemplate.locale],\r\n            });\r\n            if (this.editTemplate.startDateTime) {\r\n                const date = DateTime.fromISO(this.editTemplate.startDateTime);\r\n                this.missionTimeStart = (date.hour * 60 + date.minute) * 60 * 1000;\r\n                this.startDate = date.toMillis() - this.missionTimeStart;\r\n            }\r\n            if (this.editTemplate.endDateTime) {\r\n                const date = DateTime.fromISO(this.editTemplate.endDateTime);\r\n                this.missionTimeEnd = (date.hour * 60 + date.minute) * 60 * 1000;\r\n                this.endDate = date.toMillis() - this.missionTimeEnd;\r\n            }\r\n        } else {\r\n            this.form = this.fb.group({\r\n                title: [\"\"],\r\n                level: [LevelStatus.MINIMUM],\r\n                organisationID: this.currentOrg.id,\r\n                space: this.inputZone ? this.inputZone.spaceID : [null],\r\n                description: [null],\r\n                zone: [\r\n                    this.inputZone ? this.inputZone.id : null,\r\n                    Validators.required,\r\n                ],\r\n                locale: [this.currentLocale],\r\n            });\r\n        }\r\n\r\n    }\r\n\r\n    async onSubmit() {\r\n        this.working = true;\r\n        const formValue = this.form.getRawValue();\r\n        let startDateString: string;\r\n        let endDateString: string;\r\n        if (this.startDate) {\r\n            const dateHourStartNumber = this.startDate + this.missionTimeStart;\r\n            const startDate = DateTime.fromMillis(dateHourStartNumber);\r\n            startDateString = startDate.toISO();\r\n        }\r\n        if (this.endDate) {\r\n            const dateHourEndNumber = this.endDate + this.missionTimeEnd;\r\n            const endDate = DateTime.fromMillis(dateHourEndNumber);\r\n            endDateString = endDate.toISO();\r\n        }\r\n        try {\r\n            if (this.editTemplate) {\r\n                // update\r\n                const template: VisitTemplate = {\r\n                    id: this.editTemplate.id,\r\n                    title: formValue.title,\r\n                    level: formValue.level,\r\n                    description: formValue.description,\r\n                    organisationID: formValue.organisationID,\r\n                    startDateTime: startDateString,\r\n                    endDateTime: endDateString,\r\n                    hashtags: this.addedHashtags.map((hashtag) => hashtag.id),\r\n                    locale: formValue.locale,\r\n                };\r\n                if (formValue.space) {\r\n                    template.spaceID = formValue.space;\r\n                }\r\n                if (formValue.zone) {\r\n                    template.zoneID = formValue.zone;\r\n                }\r\n                this.updatedTemplate.emit(template);\r\n            } else {\r\n                //create\r\n                if (this.currentOrg) {\r\n                    const template: VisitTemplate = {\r\n                        title: formValue.title,\r\n                        organisationID: this.currentOrg.id,\r\n                        level: formValue.level,\r\n                        description: formValue.description,\r\n                        startDateTime: startDateString,\r\n                        endDateTime: endDateString,\r\n                        hashtags: this.addedHashtags.map((hashtag) => hashtag.id),\r\n                        locale: formValue.locale,\r\n                    };\r\n                    if (formValue.space) {\r\n                        template.spaceID = formValue.space;\r\n                    }\r\n                    if (formValue.zone) {\r\n                        template.zoneID = formValue.zone;\r\n                    }\r\n                    this.createdTemplate.emit(template);\r\n                }\r\n            }\r\n        } catch (error) {\r\n            console.error(error);\r\n        }\r\n    }\r\n\r\n    onCancel() {\r\n        this.form = null;\r\n        if (this.editTemplate) {\r\n            this.updatedTemplate.emit(null);\r\n        } else {\r\n            this.createdTemplate.emit(null);\r\n        }\r\n    }\r\n\r\n    get title(): AbstractControl {\r\n        return this.form.get(\"title\");\r\n    }\r\n\r\n    get spaceID(): AbstractControl {\r\n        return this.form.get(\"space\");\r\n    }\r\n\r\n    async onSpaceClick() {\r\n        const zones = await this.zoneService.getZonesBySpace(\r\n            this.spaceID.value,\r\n        );\r\n        const museumZones = zones.filter((zone) => zone.isMuseumVisitZone);\r\n        this.zonesForSpace = sortAlphabeticallyOnName(museumZones);\r\n        await this.setHashtags(this.spaceID.value);\r\n    }\r\n\r\n    onHashtagClick(hashtag: Hashtag) {\r\n        if (!this.addedHashtags.includes(hashtag)) {\r\n            this.addedHashtags.push(hashtag);\r\n        } else {\r\n            this.addedHashtags.splice(this.addedHashtags.indexOf(hashtag), 1);\r\n        }\r\n    }\r\n\r\n    async setHashtags(spaceID: string) {\r\n        this.availableHashtags = await this.hashtagService.getHashtagsForSpace(\r\n            spaceID,\r\n        );\r\n    }\r\n}\r\n","<div class=\"form-container\" *ngIf=\"form\">\r\n    <div>\r\n        <h4>{{ 'Visit Template' | translate }}</h4>\r\n    </div>\r\n    <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\">\r\n        <div>\r\n            <div class=\"form-group row\">\r\n                <label class=\"col-sm-4 col-form-label\">{{'Visit Title' | translate}} *</label>\r\n                <div class=\"col-sm-8\">\r\n                    <input type=\"text\" class=\"form-control\"\r\n                        placeholder=\"Edvard Munch - « Un poème d’amour, de vie et de mort »\"\r\n                        [class.is-invalid]=\"title.invalid && title.touched\" required\r\n                        formControlName=\"title\">\r\n                </div>\r\n            </div>\r\n            <div class=\"form-group row\">\r\n                <label class=\"col-sm-4 col-form-label\">{{'Description' | translate}}</label>\r\n                <div class=\"col-sm-8\">\r\n                    <textarea class=\"form-control\" formControlName=\"description\" style=\"height:200px\"\r\n                        placeholder=\"Cette visite d’1h30 vous présentera les œuvres emblématiques du célèbre peintre norvégien Edvard Munch (1863-1944)...\"></textarea>\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\">{{'Language' | translate}}</label>\r\n                <div class=\"col-sm-8\">\r\n                    <select class=\"form-control\" formControlName=\"locale\">\r\n                        <option [ngValue]=\"null\">{{'Not applicable' | translate}}</option>\r\n                        <option *ngFor=\"let locale of locales\" [ngValue]=\"locale\">\r\n                            {{ locale }}\r\n                        </option>\r\n                    </select>\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\">{{'Level' | translate}}</label>\r\n                <div class=\"col-sm-8\">\r\n                    <select class=\"form-control\" required formControlName=\"level\">\r\n                        <option *ngFor=\"let level of availableLevels\" [ngValue]=\"level\">\r\n                            {{ level }}\r\n                        </option>\r\n                    </select>\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\">{{ 'Authorized location' | translate }}*</label>\r\n                <div class=\"col-sm-8\" *ngIf=\"availableSpaces && !inputZone\">\r\n                    <select class=\"form-control\" required formControlName=\"space\" (change)=\"onSpaceClick()\">\r\n                        <option *ngFor=\"let space of availableSpaces\" [ngValue]=\"space.id\">\r\n                            {{ space.name }}\r\n                        </option>\r\n                    </select>\r\n                </div>\r\n                <div class=\"col-sm-8\" *ngIf=\"!availableSpaces\">\r\n                    {{ 'No locations available' | translate}}\r\n                </div>\r\n                <div class=\"col-sm-8\" *ngIf=\"inputZone\">\r\n                    <input type=\"text\" class=\"form-control\" [value]=\"inputZone.space.name\" disabled>\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\">{{ 'Authorized zone' | translate }}*</label>\r\n                <div class=\"col-sm-8\" *ngIf=\"zonesForSpace && zonesForSpace.length > 0 && !inputZone\">\r\n                    <select class=\"form-control\" required formControlName=\"zone\">\r\n                        <option *ngFor=\"let zone of zonesForSpace\" [ngValue]=\"zone.id\">\r\n                            {{ zone.name }}\r\n                        </option>\r\n                    </select>\r\n                </div>\r\n                <div class=\"col-sm-8\" *ngIf=\"zonesForSpace && zonesForSpace.length === 0 && !inputZone\">\r\n                    <p class=\"warning col-form-label\">{{\"No Museum Zones found for this location\"| translate}}</p>\r\n                </div>\r\n                <div class=\"col-sm-8\" *ngIf=\"inputZone\">\r\n                    <input type=\"text\" class=\"form-control\" [value]=\"inputZone.name\" disabled>\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\">{{'Hashtags' | translate}}</label>\r\n                <div class=\"col-sm-8\" *ngIf=\"spaceID.value\">\r\n                    <p class=\"keywordsRules\" *ngIf=\"availableHashtags.length > 0\">{{'Available hashtags' | translate}}\r\n                    </p>\r\n                    <p class=\"keywordsRules\" *ngIf=\"availableHashtags.length === 0\">{{'No hashtags created for this\r\n                        location' | translate}} </p>\r\n                    <div *ngIf=\"availableHashtags.length > 0\">\r\n                        <ul class=\"keywordsDisplay no-border\">\r\n                            <div class=\"keywordsdisplayContainer\">\r\n                                <li [class]=\"addedHashtags.includes(hashtag) ? 'keywordsItem added' : 'keywordsItem'\"\r\n                                    *ngFor=\"let hashtag of availableHashtags\" (click)=\"onHashtagClick(hashtag)\"\r\n                                    style=\"cursor: pointer;\"\r\n                                    ngbTooltip=\"{{addedHashtags.includes(hashtag) ? ('Remove'|translate) : ('Add'|translate) }}\">\r\n                                    {{hashtag.name}}</li>\r\n                            </div>\r\n                        </ul>\r\n                        <p class=\"keywordsRules\">{{'Added hashtags' | translate}} </p>\r\n                        <ul class=\"keywordsDisplay\">\r\n                            <div class=\"keywordsdisplayContainer\" *ngIf=\"addedHashtags.length> 0\">\r\n                                <li class=\"keywordsItem\" *ngFor=\"let hashtag of addedHashtags\">{{ hashtag.name }}</li>\r\n                            </div>\r\n                        </ul>\r\n                    </div>\r\n                </div>\r\n                <div class=\"col-sm-8\" *ngIf=\"!spaceID.value\">\r\n                    <p class=\"keywordsRules\">{{'You need to choose the location first' | translate}} </p>\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\">{{'Start Date' | translate}}</label>\r\n                <div class=\"input-group col-sm-8\">\r\n                    <input class=\"form-control\" placeholder=\"dd/mm/yyyy\" [(ngModel)]=\"startDate\" ngbDatepicker\r\n                        #d1=\"ngbDatepicker\" [ngModelOptions]=\"{standalone: true}\">\r\n                    <div class=\"input-group-append\">\r\n                        <button class=\"btn btn-outline-secondary calendar\" (click)=\"d1.toggle()\" type=\"button\"></button>\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\">{{'Start Time' | translate}}</label>\r\n                <div class=\"input-group col-sm-8\">\r\n                    <ngb-timepicker [(ngModel)]=\"missionTimeStart\" [ngModelOptions]=\"{standalone: true}\">\r\n                    </ngb-timepicker>\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\">{{'End Date' | translate}}</label>\r\n                <div class=\"input-group col-sm-8\">\r\n                    <input class=\"form-control\" placeholder=\"dd/mm/yyyy\" [(ngModel)]=\"endDate\" ngbDatepicker\r\n                        #d2=\"ngbDatepicker\" [ngModelOptions]=\"{standalone: true}\">\r\n                    <div class=\"input-group-append\">\r\n                        <button class=\"btn btn-outline-secondary calendar\" (click)=\"d2.toggle()\" type=\"button\"></button>\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\">{{'End Time' | translate}}</label>\r\n                <div class=\"input-group col-sm-8\">\r\n                    <ngb-timepicker [(ngModel)]=\"missionTimeEnd\" [ngModelOptions]=\"{standalone: true}\"></ngb-timepicker>\r\n                </div>\r\n            </div>\r\n\r\n        </div>\r\n        <div class=\"btn-control-div action-button-container\">\r\n            <button type=\"submit\" class=\"btn btn-outline-primary rounded-pill action-button\"\r\n                [disabled]=\"this.working || form.invalid\">{{'Save' | translate}}</button>\r\n            <button type=\"button\" (click)=\"onCancel()\" [disabled]=\"this.working\"\r\n                class=\"btn btn-outline-primary rounded-pill action-button\">{{'Cancel' | translate}}</button>\r\n        </div>\r\n\r\n    </form>\r\n</div>"]}