@smarterplan/ngx-smarterplan-admin 0.1.38 → 0.1.40

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.
@@ -65,8 +65,8 @@ export class FormMissionComponent {
65
65
  return this.missionForm.get("role");
66
66
  }
67
67
  async initFormForEdit() {
68
- let startDate = '';
69
- let endDate = '';
68
+ let startDate = null;
69
+ let endDate = null;
70
70
  const m = this.missionToEdit;
71
71
  if (m.startDateTime) {
72
72
  const date = DateTime.fromISO(m.startDateTime);
@@ -124,8 +124,8 @@ export class FormMissionComponent {
124
124
  description: ["", [textValidator(), noEmptyValidator()]],
125
125
  domains: [null],
126
126
  locale: [this.currentLocale],
127
- startDate: ['', [floatValidator()]],
128
- endDate: ['', [floatValidator()]],
127
+ startDate: [null, [floatValidator()]],
128
+ endDate: [null, [floatValidator()]],
129
129
  });
130
130
  }
131
131
  onHashtagClick(hashtag) {
@@ -210,4 +210,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImpor
210
210
  }], addedMissionInput: [{
211
211
  type: Output
212
212
  }] } });
213
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-mission.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-smarterplan-admin/src/lib/user/form-mission/form-mission.component.ts","../../../../../../projects/ngx-smarterplan-admin/src/lib/user/form-mission/form-mission.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { FormGroup, FormBuilder, AbstractControl } from '@angular/forms';\r\nimport {\r\n    Zone, Mission, Organisation, Space, RoleStatus,\r\n    LevelStatus, Domain, Locale, BaseUserService, DomainService,\r\n    OrganisationService, ZoneService, enumToArray, EmailStatus,\r\n    Hashtag, SpaceService, LocaleService, HashtagService, stringLocaleToEnum\r\n} from '@smarterplan/ngx-smarterplan-core';\r\nimport { DateTime } from \"luxon\";\r\nimport { Validators } from '@angular/forms';\r\nimport { ValidatorsService, textValidator, noEmptyValidator, floatValidator } from \"@smarterplan/ngx-smarterplan-core\";\r\n\r\n\r\n@Component({\r\n    selector: 'lib-form-mission',\r\n    templateUrl: './form-mission.component.html',\r\n    styleUrls: ['./form-mission.component.scss']\r\n})\r\nexport class FormMissionComponent implements OnInit {\r\n\r\n    @Input() missionToEdit: Mission;\r\n\r\n    @Input() organisationForMission: Organisation;\r\n\r\n    @Input() isSP: boolean;\r\n\r\n    @Input() userForMissionID: string;\r\n\r\n    @Input() currentUserOrganisation: Organisation;\r\n\r\n    missionForm: FormGroup;\r\n\r\n    availableSpaces: Space[];\r\n\r\n    @Output() addedMissionInput = new EventEmitter<Mission>();\r\n\r\n    availableRoles: RoleStatus[];\r\n\r\n    availableLevels: LevelStatus[];\r\n\r\n    availableHashtags: Hashtag[] = [];\r\n\r\n    domains: Domain[];\r\n\r\n    allOrgs: Organisation[];\r\n\r\n    isGuide = false;\r\n\r\n    zonesForSpace: Zone[];\r\n\r\n    defaultZone: Zone;\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    addedHashtags: Hashtag[] = [];\r\n\r\n    currentLocale: Locale;\r\n\r\n    locales: string[];\r\n\r\n    constructor(\r\n        private fb: FormBuilder,\r\n        private spaceService: SpaceService,\r\n        private userService: BaseUserService,\r\n        private domainService: DomainService,\r\n        private organisationService: OrganisationService,\r\n        private zoneService: ZoneService,\r\n        private hashtagService: HashtagService,\r\n        private localeService: LocaleService,\r\n        public validatorsService: ValidatorsService\r\n    ) { }\r\n\r\n    async ngOnInit() {\r\n        this.updateUserInfo();\r\n        await this.setDomains();\r\n        if (this.isSP) {\r\n            this.allOrgs = await this.organisationService.listOrganisations();\r\n        }\r\n        this.currentLocale = stringLocaleToEnum(this.localeService.getLocale()); // to match enum Locale\r\n        this.locales = enumToArray(Locale);\r\n        if (this.missionToEdit) {\r\n            this.initFormForEdit();\r\n        } else {\r\n            this.initEmptyForm();\r\n        }\r\n    }\r\n\r\n    updateUserInfo() {\r\n        this.availableRoles =\r\n            this.userService.getAvailableRolesForCurrentUser();\r\n        this.availableLevels =\r\n            this.userService.getAvalableLevelsForCurrentUser();\r\n        this.isGuide = this.userService.isGuide();\r\n    }\r\n\r\n    async setDomains() {\r\n        if (!this.isGuide) {\r\n            const domains =\r\n                await this.domainService.getDomainsForMissionsForOrg(\r\n                    this.currentUserOrganisation.id,\r\n                );\r\n            this.domains = domains;\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    get spaceID(): AbstractControl {\r\n        return this.missionForm.get(\"space\");\r\n    }\r\n\r\n    get role(): AbstractControl {\r\n        return this.missionForm.get(\"role\");\r\n    }\r\n\r\n    async initFormForEdit() {\r\n        let startDate: any = '';\r\n        let endDate: any = '';\r\n\r\n        const m = this.missionToEdit;\r\n\r\n        if (m.startDateTime) {\r\n            const date = DateTime.fromISO(m.startDateTime);\r\n            this.missionTimeStart = (date.hour * 60 + date.minute) * 60 * 1000;\r\n            startDate = date.toMillis() - this.missionTimeStart;\r\n        }\r\n        if (m.endDateTime) {\r\n            const date = DateTime.fromISO(m.endDateTime);\r\n            this.missionTimeEnd = (date.hour * 60 + date.minute) * 60 * 1000;\r\n            endDate = date.toMillis() - this.missionTimeEnd;\r\n        }\r\n\r\n        this.userForMissionID = m.userID;\r\n        this.availableSpaces = await this.spaceService.getAllowedSpacesForOrg(\r\n            this.missionToEdit.organisationID,\r\n            this.currentUserOrganisation.id,\r\n        );\r\n        await this.setHashtags(m.spaceID);\r\n        this.missionForm = this.fb.group({\r\n            id: m.id,\r\n            organisation: [{ value: m.organisation.name, disabled: true }],\r\n            organisationID: m.organisationID,\r\n            orderedOrganisationID: m.orderedOrganisationID,\r\n            role: [m.role, Validators.required],\r\n            level: [m.level],\r\n            space: [m.spaceID, Validators.required],\r\n            description: [m.description,[textValidator(), noEmptyValidator()] ],\r\n            domains: [m.domains],\r\n            zone: [m.zoneID],\r\n            locale: [m.locale],\r\n            startDate: [startDate, [floatValidator()]],\r\n            endDate: [endDate, [floatValidator()]],\r\n        });\r\n        if (m.hashtags && m.hashtags.length > 0) {\r\n            this.addedHashtags = this.availableHashtags.filter((hashtag) =>\r\n                m.hashtags.includes(hashtag.id),\r\n            );\r\n        }\r\n\r\n        this.onSpaceClick();\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        this.defaultZone = zones.find((zone) => !zone.parentID);\r\n        const indexOfDefaultZone = zones.indexOf(this.defaultZone);\r\n        zones.splice(indexOfDefaultZone, 1);\r\n        this.zonesForSpace = zones;\r\n        await this.setHashtags(this.spaceID.value);\r\n    }\r\n\r\n    async initEmptyForm() {\r\n        this.availableSpaces = await this.spaceService.getAllowedSpacesForOrg(\r\n            this.organisationForMission.id,\r\n            this.currentUserOrganisation.id,\r\n        );\r\n        this.missionForm = this.fb.group({\r\n            role: ['', Validators.required],\r\n            level: [LevelStatus.MINIMUM],\r\n            organisation: [\r\n                { value: this.organisationForMission.name, disabled: true },\r\n            ],\r\n            organisationID: this.organisationForMission.id,\r\n            orderedOrganisationID: this.currentUserOrganisation.id,\r\n            space: ['', Validators.required],\r\n            zone: [''],\r\n            description: [\"\", [textValidator(), noEmptyValidator()]],\r\n            domains: [null],\r\n            locale: [this.currentLocale],\r\n            startDate: ['', [floatValidator()]],\r\n            endDate: ['', [floatValidator()]],\r\n        });\r\n    }\r\n\r\n    onHashtagClick(hashtag: Hashtag) {\r\n        if (!this.hashtagAdded(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    hashtagAdded(hashtag: Hashtag): boolean {\r\n        return (\r\n            this.addedHashtags.find(\r\n                (_hashtag) => _hashtag.id === hashtag.id,\r\n            ) !== undefined\r\n        );\r\n    }\r\n\r\n    removeHashtag(hashtag: Hashtag) {\r\n        this.addedHashtags.splice(this.addedHashtags.indexOf(hashtag), 1);\r\n    }\r\n\r\n    onSubmit() {\r\n        const formValue = this.missionForm.value;\r\n        if (!this.missionForm.valid) {\r\n            // this shows errors in the form\r\n            this.missionForm.markAllAsTouched();\r\n            return;\r\n        }\r\n        let startDateString: string;\r\n        let endDateString: string;\r\n        if (formValue.startDate) {\r\n            const dateHourStartNumber = formValue.startDate + this.missionTimeStart;\r\n            const startDate = DateTime.fromMillis(dateHourStartNumber);\r\n            startDateString = startDate.toISO();\r\n        }\r\n        if (formValue.endDate) {\r\n            const dateHourEndNumber = formValue.endDate + this.missionTimeEnd;\r\n            const endDate = DateTime.fromMillis(dateHourEndNumber);\r\n            endDateString = endDate.toISO();\r\n        }\r\n        const missionInput: Mission = {\r\n            organisationID: formValue.organisationID,\r\n            orderedOrganisationID: formValue.orderedOrganisationID,\r\n            level: formValue.level,\r\n            role: formValue.role,\r\n            description: formValue.description,\r\n            startDateTime: startDateString,\r\n            endDateTime: endDateString,\r\n            domains: formValue.domains,\r\n            userID: this.userForMissionID,\r\n            emailStatus: this.missionToEdit\r\n                ? this.missionToEdit.emailStatus\r\n                : EmailStatus.CREATION_TO_DELIVER,\r\n            locale: formValue.locale,\r\n        };\r\n        missionInput.hashtags = this.addedHashtags.map((h) => h.id);\r\n        if (formValue.space) {\r\n            missionInput.spaceID = formValue.space;\r\n        }\r\n        if (formValue.zone) {\r\n            missionInput.zoneID = formValue.zone;\r\n        }\r\n        if (this.missionToEdit) {\r\n            missionInput.id = this.missionToEdit.id;\r\n        }\r\n        this.addedMissionInput.emit(missionInput);\r\n    }\r\n\r\n    onCancel() {\r\n        this.addedMissionInput.emit(null);\r\n    }\r\n\r\n}\r\n","<div class=\"form-containter\" *ngIf=\"missionForm\">\r\n    <div style=\"margin-top: 1rem;\">\r\n        <h4>{{ 'Mission details' | translate }}</h4>\r\n    </div>\r\n    <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"missionForm\">\r\n        <div class=\"form-group row\">\r\n            <label class=\"col-sm-4 col-form-label\">{{'Organisation' | translate}}</label>\r\n            <div class=\"col-sm-8\">\r\n                <input type=\"text\"  data-testid=\"form-mission-organisation\" class=\"form-control\" formControlName=\"organisation\">\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"form-group row\" *ngIf=\"isSP\">\r\n            <label class=\"col-sm-4 col-form-label\">{{ 'Ordered by' | translate }}</label>\r\n            <div class=\"col-sm-8\">\r\n                <select class=\"form-control\" required formControlName=\"orderedOrganisationID\">\r\n                    <option *ngFor=\"let org of allOrgs\" [ngValue]=\"org.id\">\r\n                        {{ org.name }}\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\">{{'Description' | translate}}</label>\r\n            <div class=\"col-sm-8\">\r\n                <textarea class=\"form-control\" formControlName=\"description\" rows=\"10\"\r\n                    [class.is-invalid]=\"validatorsService.isControlError(missionForm.controls['description'])\"\r\n                    data-testid=\"form-mission-description\"></textarea>\r\n                <div class=\"invalid-feedback\">\r\n                    <span data-testid=\"form-mission-description-invalid\"\r\n                        [translate]=\"validatorsService.getError(missionForm.controls['description'])\"\r\n                        *ngIf=\" validatorsService.isControlError(missionForm.controls['description'])\"></span>\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\">{{'Role' | translate}}*</label>\r\n            <div class=\"col-sm-8\">\r\n                <select class=\"form-control\" required formControlName=\"role\" data-testid=\"form-mission-role\"\r\n                    [class.is-invalid]=\"validatorsService.isControlError(missionForm.controls['role'])\">\r\n                    <option *ngFor=\"let r of availableRoles\" [ngValue]=\"r\">\r\n                        {{ r }}\r\n                    </option>\r\n                </select>\r\n                <div class=\"invalid-feedback\">\r\n                    <span data-testid=\"form-mission-role-invalid\"\r\n                        [translate]=\"validatorsService.getError(missionForm.controls['role'])\"\r\n                        *ngIf=\" validatorsService.isControlError(missionForm.controls['role'])\"></span>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"form-group row\"\r\n            *ngIf=\"missionForm.get('role').value !== 'VISITOR_MUSEUM' && missionForm.get('role').value !== 'GUIDE_MUSEUM'\">\r\n            <label class=\"col-sm-4 col-form-label\">{{'Domains' | translate}}</label>\r\n            <div class=\"col-sm-8\" *ngIf=\"domains\">\r\n                <select class=\"form-control\" multiple formControlName=\"domains\">\r\n                    <option *ngFor=\"let domain of domains\" [ngValue]=\"domain.id\">\r\n                        {{ domain.name }}\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\">{{'Access level' | translate}}</label>\r\n            <div class=\"col-sm-8\">\r\n                <select class=\"form-control\" required formControlName=\"level\" data-testid=\"form-mission-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\">\r\n                <select class=\"form-control\" required formControlName=\"space\" (change)=\"onSpaceClick()\"\r\n                    data-testid=\"form-mission-space\"\r\n                    [class.is-invalid]=\"validatorsService.isControlError(missionForm.controls['space'])\">\r\n                    <option *ngFor=\"let space of availableSpaces\" [ngValue]=\"space.id\">\r\n                        {{ space.name }}\r\n                    </option>\r\n                </select>\r\n                <div class=\"invalid-feedback\">\r\n                    <span data-testid=\"form-mission-space-invalid\"\r\n                        [translate]=\"validatorsService.getError(missionForm.controls['space'])\"\r\n                        *ngIf=\" validatorsService.isControlError(missionForm.controls['space'])\"></span>\r\n                </div>\r\n            </div>\r\n            <div class=\"col-sm-8\" *ngIf=\"!availableSpaces\">\r\n                {{ 'No locations available' | translate}}\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; else noSpace\">\r\n                <select class=\"form-control\" formControlName=\"zone\" data-testid=\"form-mission-zone\">\r\n                    <option [ngValue]=\"defaultZone.id\">\r\n                        {{ 'All zones' | translate }}\r\n                    </option>\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            <ng-template #noSpace>\r\n                <div class=\"col-sm-8 hint-container\">\r\n                    <p class=\"hint keywordsRules\">{{'You need to choose the location first' | translate}} </p>\r\n                </div>\r\n            </ng-template>\r\n        </div>\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        <!-- Hashtags are available after Space is set -->\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}} </p>\r\n                <p class=\"keywordsRules\" *ngIf=\"availableHashtags.length === 0\">\r\n                    {{'No hashtags created for this 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 *ngFor=\"let hashtag of availableHashtags\"\r\n                                [class]=\"hashtagAdded(hashtag) ? 'keywordsItem added' : 'keywordsItem'\"\r\n                                (click)=\"onHashtagClick(hashtag)\" style=\"cursor: pointer;\"\r\n                                ngbTooltip=\"{{hashtagAdded(hashtag) ? ('Remove'|translate) : ('Add'|translate) }}\">\r\n                                {{hashtag.name}}\r\n                            </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 }}\r\n                                <a type=\"button\" class=\"closeButton\" (click)=\"removeHashtag(hashtag)\">\r\n                                    <span class=\"crossItem\"></span>\r\n                                </a>\r\n                            </li>\r\n                        </div>\r\n                    </ul>\r\n                </div>\r\n            </div>\r\n            <div class=\"col-sm-8 hint-container\" *ngIf=\"!spaceID.value\">\r\n                <p class=\"hint 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\">{{'Mission Start Date' | translate}}</label>\r\n            <div class=\"input-group col-sm-8\">\r\n                <input class=\"form-control\" placeholder=\"dd/mm/yyyy\" formControlName=\"startDate\" ngbDatepicker\r\n                    #d1=\"ngbDatepicker\" data-testid=\"form-mission-startDate\"\r\n                    [class.is-invalid]=\"validatorsService.isControlError(missionForm.controls['startDate'])\">\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 class=\"invalid-feedback\">\r\n                    <span data-testid=\"form-mission-startDate-invalid\"\r\n                        [translate]=\"validatorsService.getError(missionForm.controls['startDate'])\"\r\n                        *ngIf=\" validatorsService.isControlError(missionForm.controls['startDate'])\"></span>\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\">{{'Mission Start Time' | translate}}</label>\r\n            <div class=\"input-group col-sm-8 timeZoneContainer\">\r\n                <ngb-timepicker [(ngModel)]=\"missionTimeStart\" [ngModelOptions]=\"{standalone: true}\"></ngb-timepicker>\r\n            </div>\r\n        </div>\r\n\r\n\r\n        <div class=\"form-group row\">\r\n            <label class=\"col-sm-4 col-form-label\">{{'Mission End Date' | translate}}</label>\r\n            <div class=\"input-group col-sm-8\">\r\n                <input class=\"form-control\" placeholder=\"dd/mm/yyyy\" ngbDatepicker #d2=\"ngbDatepicker\"\r\n                    formControlName=\"endDate\" data-testid=\"form-mission-endDate\"\r\n                    [class.is-invalid]=\"validatorsService.isControlError(missionForm.controls['endDate'])\">\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 class=\"invalid-feedback\">\r\n                    <span data-testid=\"form-mission-endDate-invalid\"\r\n                        [translate]=\"validatorsService.getError(missionForm.controls['endDate'])\"\r\n                        *ngIf=\" validatorsService.isControlError(missionForm.controls['endDate'])\"></span>\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\">{{'Mission End Time' | translate}}</label>\r\n            <div class=\"input-group col-sm-8 timeZoneContainer\">\r\n                <ngb-timepicker [(ngModel)]=\"missionTimeEnd\" [ngModelOptions]=\"{standalone: true}\"></ngb-timepicker>\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"btn-control-div action-button-container\">\r\n            <button type=\"submit\" [disabled]=\"missionForm.invalid\"\r\n                class=\"btn btn-outline-primary rounded-pill mr-3 action-button\"\r\n                data-testid=\"form-mission-submit-btn\">{{'Save' |\r\n                translate}}</button>\r\n            <button type=\"button\" (click)=\"onCancel()\" data-testid=\"form-mission-cancel-btn\"\r\n                class=\"btn btn-outline-primary rounded-pill action-button\">{{'Cancel' |\r\n                translate}}</button>\r\n        </div>\r\n    </form>\r\n</div>"]}
213
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-mission.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-smarterplan-admin/src/lib/user/form-mission/form-mission.component.ts","../../../../../../projects/ngx-smarterplan-admin/src/lib/user/form-mission/form-mission.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { FormGroup, FormBuilder, AbstractControl } from '@angular/forms';\r\nimport {\r\n    Zone, Mission, Organisation, Space, RoleStatus,\r\n    LevelStatus, Domain, Locale, BaseUserService, DomainService,\r\n    OrganisationService, ZoneService, enumToArray, EmailStatus,\r\n    Hashtag, SpaceService, LocaleService, HashtagService, stringLocaleToEnum\r\n} from '@smarterplan/ngx-smarterplan-core';\r\nimport { DateTime } from \"luxon\";\r\nimport { Validators } from '@angular/forms';\r\nimport { ValidatorsService, textValidator, noEmptyValidator, floatValidator } from \"@smarterplan/ngx-smarterplan-core\";\r\n\r\n\r\n@Component({\r\n    selector: 'lib-form-mission',\r\n    templateUrl: './form-mission.component.html',\r\n    styleUrls: ['./form-mission.component.scss']\r\n})\r\nexport class FormMissionComponent implements OnInit {\r\n\r\n    @Input() missionToEdit: Mission;\r\n\r\n    @Input() organisationForMission: Organisation;\r\n\r\n    @Input() isSP: boolean;\r\n\r\n    @Input() userForMissionID: string;\r\n\r\n    @Input() currentUserOrganisation: Organisation;\r\n\r\n    missionForm: FormGroup;\r\n\r\n    availableSpaces: Space[];\r\n\r\n    @Output() addedMissionInput = new EventEmitter<Mission>();\r\n\r\n    availableRoles: RoleStatus[];\r\n\r\n    availableLevels: LevelStatus[];\r\n\r\n    availableHashtags: Hashtag[] = [];\r\n\r\n    domains: Domain[];\r\n\r\n    allOrgs: Organisation[];\r\n\r\n    isGuide = false;\r\n\r\n    zonesForSpace: Zone[];\r\n\r\n    defaultZone: Zone;\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    addedHashtags: Hashtag[] = [];\r\n\r\n    currentLocale: Locale;\r\n\r\n    locales: string[];\r\n\r\n    constructor(\r\n        private fb: FormBuilder,\r\n        private spaceService: SpaceService,\r\n        private userService: BaseUserService,\r\n        private domainService: DomainService,\r\n        private organisationService: OrganisationService,\r\n        private zoneService: ZoneService,\r\n        private hashtagService: HashtagService,\r\n        private localeService: LocaleService,\r\n        public validatorsService: ValidatorsService\r\n    ) { }\r\n\r\n    async ngOnInit() {\r\n        this.updateUserInfo();\r\n        await this.setDomains();\r\n        if (this.isSP) {\r\n            this.allOrgs = await this.organisationService.listOrganisations();\r\n        }\r\n        this.currentLocale = stringLocaleToEnum(this.localeService.getLocale()); // to match enum Locale\r\n        this.locales = enumToArray(Locale);\r\n        if (this.missionToEdit) {\r\n            this.initFormForEdit();\r\n        } else {\r\n            this.initEmptyForm();\r\n        }\r\n    }\r\n\r\n    updateUserInfo() {\r\n        this.availableRoles =\r\n            this.userService.getAvailableRolesForCurrentUser();\r\n        this.availableLevels =\r\n            this.userService.getAvalableLevelsForCurrentUser();\r\n        this.isGuide = this.userService.isGuide();\r\n    }\r\n\r\n    async setDomains() {\r\n        if (!this.isGuide) {\r\n            const domains =\r\n                await this.domainService.getDomainsForMissionsForOrg(\r\n                    this.currentUserOrganisation.id,\r\n                );\r\n            this.domains = domains;\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    get spaceID(): AbstractControl {\r\n        return this.missionForm.get(\"space\");\r\n    }\r\n\r\n    get role(): AbstractControl {\r\n        return this.missionForm.get(\"role\");\r\n    }\r\n\r\n    async initFormForEdit() {\r\n        let startDate: any = null;\r\n        let endDate: any = null;\r\n\r\n        const m = this.missionToEdit;\r\n\r\n        if (m.startDateTime) {\r\n            const date = DateTime.fromISO(m.startDateTime);\r\n            this.missionTimeStart = (date.hour * 60 + date.minute) * 60 * 1000;\r\n            startDate = date.toMillis() - this.missionTimeStart;\r\n        }\r\n        if (m.endDateTime) {\r\n            const date = DateTime.fromISO(m.endDateTime);\r\n            this.missionTimeEnd = (date.hour * 60 + date.minute) * 60 * 1000;\r\n            endDate = date.toMillis() - this.missionTimeEnd;\r\n        }\r\n\r\n        this.userForMissionID = m.userID;\r\n        this.availableSpaces = await this.spaceService.getAllowedSpacesForOrg(\r\n            this.missionToEdit.organisationID,\r\n            this.currentUserOrganisation.id,\r\n        );\r\n        await this.setHashtags(m.spaceID);\r\n        this.missionForm = this.fb.group({\r\n            id: m.id,\r\n            organisation: [{ value: m.organisation.name, disabled: true }],\r\n            organisationID: m.organisationID,\r\n            orderedOrganisationID: m.orderedOrganisationID,\r\n            role: [m.role, Validators.required],\r\n            level: [m.level],\r\n            space: [m.spaceID, Validators.required],\r\n            description: [m.description,[textValidator(), noEmptyValidator()] ],\r\n            domains: [m.domains],\r\n            zone: [m.zoneID],\r\n            locale: [m.locale],\r\n            startDate: [startDate, [floatValidator()]],\r\n            endDate: [endDate, [floatValidator()]],\r\n        });\r\n        if (m.hashtags && m.hashtags.length > 0) {\r\n            this.addedHashtags = this.availableHashtags.filter((hashtag) =>\r\n                m.hashtags.includes(hashtag.id),\r\n            );\r\n        }\r\n\r\n        this.onSpaceClick();\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        this.defaultZone = zones.find((zone) => !zone.parentID);\r\n        const indexOfDefaultZone = zones.indexOf(this.defaultZone);\r\n        zones.splice(indexOfDefaultZone, 1);\r\n        this.zonesForSpace = zones;\r\n        await this.setHashtags(this.spaceID.value);\r\n    }\r\n\r\n    async initEmptyForm() {\r\n        this.availableSpaces = await this.spaceService.getAllowedSpacesForOrg(\r\n            this.organisationForMission.id,\r\n            this.currentUserOrganisation.id,\r\n        );\r\n        this.missionForm = this.fb.group({\r\n            role: ['', Validators.required],\r\n            level: [LevelStatus.MINIMUM],\r\n            organisation: [\r\n                { value: this.organisationForMission.name, disabled: true },\r\n            ],\r\n            organisationID: this.organisationForMission.id,\r\n            orderedOrganisationID: this.currentUserOrganisation.id,\r\n            space: ['', Validators.required],\r\n            zone: [''],\r\n            description: [\"\", [textValidator(), noEmptyValidator()]],\r\n            domains: [null],\r\n            locale: [this.currentLocale],\r\n            startDate: [null, [floatValidator()]],\r\n            endDate: [null, [floatValidator()]],\r\n        });\r\n    }\r\n\r\n    onHashtagClick(hashtag: Hashtag) {\r\n        if (!this.hashtagAdded(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    hashtagAdded(hashtag: Hashtag): boolean {\r\n        return (\r\n            this.addedHashtags.find(\r\n                (_hashtag) => _hashtag.id === hashtag.id,\r\n            ) !== undefined\r\n        );\r\n    }\r\n\r\n    removeHashtag(hashtag: Hashtag) {\r\n        this.addedHashtags.splice(this.addedHashtags.indexOf(hashtag), 1);\r\n    }\r\n\r\n    onSubmit() {\r\n        const formValue = this.missionForm.value;\r\n        if (!this.missionForm.valid) {\r\n            // this shows errors in the form\r\n            this.missionForm.markAllAsTouched();\r\n            return;\r\n        }\r\n        let startDateString: string;\r\n        let endDateString: string;\r\n        if (formValue.startDate) {\r\n            const dateHourStartNumber = formValue.startDate + this.missionTimeStart;\r\n            const startDate = DateTime.fromMillis(dateHourStartNumber);\r\n            startDateString = startDate.toISO();\r\n        }\r\n        if (formValue.endDate) {\r\n            const dateHourEndNumber = formValue.endDate + this.missionTimeEnd;\r\n            const endDate = DateTime.fromMillis(dateHourEndNumber);\r\n            endDateString = endDate.toISO();\r\n        }\r\n        const missionInput: Mission = {\r\n            organisationID: formValue.organisationID,\r\n            orderedOrganisationID: formValue.orderedOrganisationID,\r\n            level: formValue.level,\r\n            role: formValue.role,\r\n            description: formValue.description,\r\n            startDateTime: startDateString,\r\n            endDateTime: endDateString,\r\n            domains: formValue.domains,\r\n            userID: this.userForMissionID,\r\n            emailStatus: this.missionToEdit\r\n                ? this.missionToEdit.emailStatus\r\n                : EmailStatus.CREATION_TO_DELIVER,\r\n            locale: formValue.locale,\r\n        };\r\n        missionInput.hashtags = this.addedHashtags.map((h) => h.id);\r\n        if (formValue.space) {\r\n            missionInput.spaceID = formValue.space;\r\n        }\r\n        if (formValue.zone) {\r\n            missionInput.zoneID = formValue.zone;\r\n        }\r\n        if (this.missionToEdit) {\r\n            missionInput.id = this.missionToEdit.id;\r\n        }\r\n        this.addedMissionInput.emit(missionInput);\r\n    }\r\n\r\n    onCancel() {\r\n        this.addedMissionInput.emit(null);\r\n    }\r\n\r\n}\r\n","<div class=\"form-containter\" *ngIf=\"missionForm\">\r\n    <div style=\"margin-top: 1rem;\">\r\n        <h4>{{ 'Mission details' | translate }}</h4>\r\n    </div>\r\n    <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"missionForm\">\r\n        <div class=\"form-group row\">\r\n            <label class=\"col-sm-4 col-form-label\">{{'Organisation' | translate}}</label>\r\n            <div class=\"col-sm-8\">\r\n                <input type=\"text\"  data-testid=\"form-mission-organisation\" class=\"form-control\" formControlName=\"organisation\">\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"form-group row\" *ngIf=\"isSP\">\r\n            <label class=\"col-sm-4 col-form-label\">{{ 'Ordered by' | translate }}</label>\r\n            <div class=\"col-sm-8\">\r\n                <select class=\"form-control\" required formControlName=\"orderedOrganisationID\">\r\n                    <option *ngFor=\"let org of allOrgs\" [ngValue]=\"org.id\">\r\n                        {{ org.name }}\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\">{{'Description' | translate}}</label>\r\n            <div class=\"col-sm-8\">\r\n                <textarea class=\"form-control\" formControlName=\"description\" rows=\"10\"\r\n                    [class.is-invalid]=\"validatorsService.isControlError(missionForm.controls['description'])\"\r\n                    data-testid=\"form-mission-description\"></textarea>\r\n                <div class=\"invalid-feedback\">\r\n                    <span data-testid=\"form-mission-description-invalid\"\r\n                        [translate]=\"validatorsService.getError(missionForm.controls['description'])\"\r\n                        *ngIf=\" validatorsService.isControlError(missionForm.controls['description'])\"></span>\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\">{{'Role' | translate}}*</label>\r\n            <div class=\"col-sm-8\">\r\n                <select class=\"form-control\" required formControlName=\"role\" data-testid=\"form-mission-role\"\r\n                    [class.is-invalid]=\"validatorsService.isControlError(missionForm.controls['role'])\">\r\n                    <option *ngFor=\"let r of availableRoles\" [ngValue]=\"r\">\r\n                        {{ r }}\r\n                    </option>\r\n                </select>\r\n                <div class=\"invalid-feedback\">\r\n                    <span data-testid=\"form-mission-role-invalid\"\r\n                        [translate]=\"validatorsService.getError(missionForm.controls['role'])\"\r\n                        *ngIf=\" validatorsService.isControlError(missionForm.controls['role'])\"></span>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"form-group row\"\r\n            *ngIf=\"missionForm.get('role').value !== 'VISITOR_MUSEUM' && missionForm.get('role').value !== 'GUIDE_MUSEUM'\">\r\n            <label class=\"col-sm-4 col-form-label\">{{'Domains' | translate}}</label>\r\n            <div class=\"col-sm-8\" *ngIf=\"domains\">\r\n                <select class=\"form-control\" multiple formControlName=\"domains\">\r\n                    <option *ngFor=\"let domain of domains\" [ngValue]=\"domain.id\">\r\n                        {{ domain.name }}\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\">{{'Access level' | translate}}</label>\r\n            <div class=\"col-sm-8\">\r\n                <select class=\"form-control\" required formControlName=\"level\" data-testid=\"form-mission-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\">\r\n                <select class=\"form-control\" required formControlName=\"space\" (change)=\"onSpaceClick()\"\r\n                    data-testid=\"form-mission-space\"\r\n                    [class.is-invalid]=\"validatorsService.isControlError(missionForm.controls['space'])\">\r\n                    <option *ngFor=\"let space of availableSpaces\" [ngValue]=\"space.id\">\r\n                        {{ space.name }}\r\n                    </option>\r\n                </select>\r\n                <div class=\"invalid-feedback\">\r\n                    <span data-testid=\"form-mission-space-invalid\"\r\n                        [translate]=\"validatorsService.getError(missionForm.controls['space'])\"\r\n                        *ngIf=\" validatorsService.isControlError(missionForm.controls['space'])\"></span>\r\n                </div>\r\n            </div>\r\n            <div class=\"col-sm-8\" *ngIf=\"!availableSpaces\">\r\n                {{ 'No locations available' | translate}}\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; else noSpace\">\r\n                <select class=\"form-control\" formControlName=\"zone\" data-testid=\"form-mission-zone\">\r\n                    <option [ngValue]=\"defaultZone.id\">\r\n                        {{ 'All zones' | translate }}\r\n                    </option>\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            <ng-template #noSpace>\r\n                <div class=\"col-sm-8 hint-container\">\r\n                    <p class=\"hint keywordsRules\">{{'You need to choose the location first' | translate}} </p>\r\n                </div>\r\n            </ng-template>\r\n        </div>\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        <!-- Hashtags are available after Space is set -->\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}} </p>\r\n                <p class=\"keywordsRules\" *ngIf=\"availableHashtags.length === 0\">\r\n                    {{'No hashtags created for this 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 *ngFor=\"let hashtag of availableHashtags\"\r\n                                [class]=\"hashtagAdded(hashtag) ? 'keywordsItem added' : 'keywordsItem'\"\r\n                                (click)=\"onHashtagClick(hashtag)\" style=\"cursor: pointer;\"\r\n                                ngbTooltip=\"{{hashtagAdded(hashtag) ? ('Remove'|translate) : ('Add'|translate) }}\">\r\n                                {{hashtag.name}}\r\n                            </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 }}\r\n                                <a type=\"button\" class=\"closeButton\" (click)=\"removeHashtag(hashtag)\">\r\n                                    <span class=\"crossItem\"></span>\r\n                                </a>\r\n                            </li>\r\n                        </div>\r\n                    </ul>\r\n                </div>\r\n            </div>\r\n            <div class=\"col-sm-8 hint-container\" *ngIf=\"!spaceID.value\">\r\n                <p class=\"hint 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\">{{'Mission Start Date' | translate}}</label>\r\n            <div class=\"input-group col-sm-8\">\r\n                <input class=\"form-control\" placeholder=\"dd/mm/yyyy\" formControlName=\"startDate\" ngbDatepicker\r\n                    #d1=\"ngbDatepicker\" data-testid=\"form-mission-startDate\"\r\n                    [class.is-invalid]=\"validatorsService.isControlError(missionForm.controls['startDate'])\">\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 class=\"invalid-feedback\">\r\n                    <span data-testid=\"form-mission-startDate-invalid\"\r\n                        [translate]=\"validatorsService.getError(missionForm.controls['startDate'])\"\r\n                        *ngIf=\" validatorsService.isControlError(missionForm.controls['startDate'])\"></span>\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\">{{'Mission Start Time' | translate}}</label>\r\n            <div class=\"input-group col-sm-8 timeZoneContainer\">\r\n                <ngb-timepicker [(ngModel)]=\"missionTimeStart\" [ngModelOptions]=\"{standalone: true}\"></ngb-timepicker>\r\n            </div>\r\n        </div>\r\n\r\n\r\n        <div class=\"form-group row\">\r\n            <label class=\"col-sm-4 col-form-label\">{{'Mission End Date' | translate}}</label>\r\n            <div class=\"input-group col-sm-8\">\r\n                <input class=\"form-control\" placeholder=\"dd/mm/yyyy\" ngbDatepicker #d2=\"ngbDatepicker\"\r\n                    formControlName=\"endDate\" data-testid=\"form-mission-endDate\"\r\n                    [class.is-invalid]=\"validatorsService.isControlError(missionForm.controls['endDate'])\">\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 class=\"invalid-feedback\">\r\n                    <span data-testid=\"form-mission-endDate-invalid\"\r\n                        [translate]=\"validatorsService.getError(missionForm.controls['endDate'])\"\r\n                        *ngIf=\" validatorsService.isControlError(missionForm.controls['endDate'])\"></span>\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\">{{'Mission End Time' | translate}}</label>\r\n            <div class=\"input-group col-sm-8 timeZoneContainer\">\r\n                <ngb-timepicker [(ngModel)]=\"missionTimeEnd\" [ngModelOptions]=\"{standalone: true}\"></ngb-timepicker>\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"btn-control-div action-button-container\">\r\n            <button type=\"submit\" [disabled]=\"missionForm.invalid\"\r\n                class=\"btn btn-outline-primary rounded-pill mr-3 action-button\"\r\n                data-testid=\"form-mission-submit-btn\">{{'Save' |\r\n                translate}}</button>\r\n            <button type=\"button\" (click)=\"onCancel()\" data-testid=\"form-mission-cancel-btn\"\r\n                class=\"btn btn-outline-primary rounded-pill action-button\">{{'Cancel' |\r\n                translate}}</button>\r\n        </div>\r\n    </form>\r\n</div>"]}