@smarterplan/ngx-smarterplan-admin 0.1.61 → 0.1.63

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 (48) hide show
  1. package/README.md +24 -24
  2. package/esm2020/lib/admin/admin.component.mjs +5 -5
  3. package/esm2020/lib/chevron/chevron.component.mjs +5 -5
  4. package/esm2020/lib/guest-link/guest-link.component.mjs +5 -5
  5. package/esm2020/lib/guide.guard.mjs +4 -4
  6. package/esm2020/lib/helpers.mjs +1 -1
  7. package/esm2020/lib/name-from-id.pipe.mjs +4 -4
  8. package/esm2020/lib/ngx-smarterplan-admin-routing.module.mjs +5 -5
  9. package/esm2020/lib/ngx-smarterplan-admin.module.mjs +5 -5
  10. package/esm2020/lib/ngx-smarterplan-admin.service.mjs +4 -4
  11. package/esm2020/lib/organisation/organisation.component.mjs +5 -5
  12. package/esm2020/lib/sp-admin.guard.mjs +7 -12
  13. package/esm2020/lib/user/detail-organisation/detail-organisation.component.mjs +5 -5
  14. package/esm2020/lib/user/form-mission/form-mission.component.mjs +5 -5
  15. package/esm2020/lib/user/form-organisation/form-organisation.component.mjs +5 -5
  16. package/esm2020/lib/user/user-mission-form/user-mission-form.component.mjs +5 -5
  17. package/esm2020/lib/user/user.component.mjs +5 -5
  18. package/esm2020/lib/visitor/create-batch/create-batch.component.mjs +5 -5
  19. package/esm2020/lib/visitor/template/template.component.mjs +5 -5
  20. package/esm2020/lib/visitor/visitor.component.mjs +5 -5
  21. package/esm2020/public-api.mjs +1 -1
  22. package/fesm2015/smarterplan-ngx-smarterplan-admin.mjs +71 -76
  23. package/fesm2015/smarterplan-ngx-smarterplan-admin.mjs.map +1 -1
  24. package/fesm2020/smarterplan-ngx-smarterplan-admin.mjs +71 -76
  25. package/fesm2020/smarterplan-ngx-smarterplan-admin.mjs.map +1 -1
  26. package/lib/sp-admin.guard.d.ts +2 -3
  27. package/package.json +14 -13
  28. package/lib/admin/admin.component.d.ts.map +0 -1
  29. package/lib/chevron/chevron.component.d.ts.map +0 -1
  30. package/lib/guest-link/guest-link.component.d.ts.map +0 -1
  31. package/lib/guide.guard.d.ts.map +0 -1
  32. package/lib/helpers.d.ts.map +0 -1
  33. package/lib/name-from-id.pipe.d.ts.map +0 -1
  34. package/lib/ngx-smarterplan-admin-routing.module.d.ts.map +0 -1
  35. package/lib/ngx-smarterplan-admin.module.d.ts.map +0 -1
  36. package/lib/ngx-smarterplan-admin.service.d.ts.map +0 -1
  37. package/lib/organisation/organisation.component.d.ts.map +0 -1
  38. package/lib/sp-admin.guard.d.ts.map +0 -1
  39. package/lib/user/detail-organisation/detail-organisation.component.d.ts.map +0 -1
  40. package/lib/user/form-mission/form-mission.component.d.ts.map +0 -1
  41. package/lib/user/form-organisation/form-organisation.component.d.ts.map +0 -1
  42. package/lib/user/user-mission-form/user-mission-form.component.d.ts.map +0 -1
  43. package/lib/user/user.component.d.ts.map +0 -1
  44. package/lib/visitor/create-batch/create-batch.component.d.ts.map +0 -1
  45. package/lib/visitor/template/template.component.d.ts.map +0 -1
  46. package/lib/visitor/visitor.component.d.ts.map +0 -1
  47. package/public-api.d.ts.map +0 -1
  48. package/smarterplan-ngx-smarterplan-admin.d.ts.map +0 -1
@@ -108,11 +108,11 @@ export class FormOrganisationComponent {
108
108
  this.added.emit(added);
109
109
  }
110
110
  }
111
- FormOrganisationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: FormOrganisationComponent, deps: [{ token: i1.OrganisationService }, { token: i2.FormBuilder }, { token: i1.BaseUserService }], target: i0.ɵɵFactoryTarget.Component });
112
- FormOrganisationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: FormOrganisationComponent, selector: "lib-form-organisation", inputs: { currentOrg: "currentOrg", currentUser: "currentUser", existing: "existing" }, outputs: { added: "added" }, ngImport: i0, template: "<div *ngIf=\"form\">\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\">\n <div>\n <h4>{{ 'Organisation' | translate }}</h4>\n </div>\n <div class=\"form-group row\" *ngIf=\"existing\">\n <label class=\"col-sm-3 col-form-label\">{{'Organisation Token' | translate}}</label>\n <div class=\"col-sm-9\">\n <input type=\"text\" class=\"form-control\" id=\"tokenInput\" placeholder=\"Paste organisation token here\">\n </div>\n </div>\n <div class=\"form-group row\">\n <label class=\"col-sm-3 col-form-label\">{{'Name' | translate}} *</label>\n <div class=\"col-sm-9\">\n <input type=\"text\" class=\"form-control\" [class.is-invalid]=\"name.invalid && name.touched\" required\n formControlName=\"name\">\n <div class=\"invalid-feedback\">\n {{'Name is mandatory' | translate}}\n </div>\n </div>\n </div>\n\n <div class=\"form-group row\">\n <label class=\"col-sm-3 col-form-label\">{{'Address' | translate}}</label>\n <div class=\"col-sm-9\">\n <input type=\"text\" class=\"form-control\" formControlName=\"address\">\n </div>\n </div>\n\n <div class=\"form-group row\">\n <label class=\"col-sm-3 col-form-label\">{{'City' | translate}}</label>\n <div class=\"col-sm-9\">\n <input type=\"text\" class=\"form-control\" formControlName=\"city\">\n </div>\n </div>\n\n <div class=\"form-group row\">\n <label class=\"col-sm-3 col-form-label\">{{'Postal Code' | translate}}</label>\n <div class=\"col-sm-9\">\n <input type=\"text\" class=\"form-control\" formControlName=\"postal\">\n </div>\n </div>\n\n <div class=\"form-group row\">\n <label class=\"col-sm-3 col-form-label\">{{'SIRET' | translate}}</label>\n <div class=\"col-sm-9\">\n <input type=\"text\" class=\"form-control\" formControlName=\"siret\">\n </div>\n </div>\n\n\n <div *ngIf=\"createdOrg; else noOrg\">\n <div class=\"alert alert-info\">\n {{'Organisation successfully created' | translate}}\n </div>\n <lib-user-mission-form [addToOrganisation]=\"createdOrg\" [currentOrg]=\"currentOrg\" [isSP]=\"isSP\"\n (added)=\"userAndMissionAdded($event)\">\n </lib-user-mission-form>\n </div>\n <ng-template #noOrg>\n <div class=\"action-button-container\">\n <button type=\"submit\" class=\"btn btn-outline-primary rounded-pill mr-3 action-button\"\n [disabled]=\"this.working || form.invalid\">{{'Create organisation' | translate}}</button>\n <button type=\"button\" (click)=\"onCancel()\" [disabled]=\"this.working\"\n class=\"btn btn-outline-primary rounded-pill action-button\">{{'Cancel' | translate}}</button>\n </div>\n <div style='margin-top: 1rem'>\n <h4>{{ 'User Personal Information' | translate }}</h4>\n </div>\n <ngb-alert type=\"warning\" [dismissible]=\"false\">{{'Please create new organisation first' | translate}}\n </ngb-alert>\n\n </ng-template>\n\n\n </form>\n</div>", styles: [".form-group{margin:1.5rem 0}.action-button-container{display:flex;justify-content:space-evenly}.action-button-container .action-button{width:145px}\n"], components: [{ type: i3.UserMissionFormComponent, selector: "lib-user-mission-form", inputs: ["addToOrganisation", "isSP", "createForExistingUser", "currentOrg"], outputs: ["added"] }, { type: i4.NgbAlert, selector: "ngb-alert", inputs: ["animation", "dismissible", "type"], outputs: ["closed"], exportAs: ["ngbAlert"] }], directives: [{ type: i5.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"] }], pipes: { "translate": i6.TranslatePipe } });
113
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: FormOrganisationComponent, decorators: [{
111
+ FormOrganisationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: FormOrganisationComponent, deps: [{ token: i1.OrganisationService }, { token: i2.FormBuilder }, { token: i1.BaseUserService }], target: i0.ɵɵFactoryTarget.Component });
112
+ FormOrganisationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: FormOrganisationComponent, selector: "lib-form-organisation", inputs: { currentOrg: "currentOrg", currentUser: "currentUser", existing: "existing" }, outputs: { added: "added" }, ngImport: i0, template: "<div *ngIf=\"form\">\r\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\">\r\n <div>\r\n <h4>{{ 'Organisation' | translate }}</h4>\r\n </div>\r\n <div class=\"form-group row\" *ngIf=\"existing\">\r\n <label class=\"col-sm-3 col-form-label\">{{'Organisation Token' | translate}}</label>\r\n <div class=\"col-sm-9\">\r\n <input type=\"text\" class=\"form-control\" id=\"tokenInput\" placeholder=\"Paste organisation token here\">\r\n </div>\r\n </div>\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-3 col-form-label\">{{'Name' | translate}} *</label>\r\n <div class=\"col-sm-9\">\r\n <input type=\"text\" class=\"form-control\" [class.is-invalid]=\"name.invalid && name.touched\" required\r\n formControlName=\"name\">\r\n <div class=\"invalid-feedback\">\r\n {{'Name is mandatory' | translate}}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-3 col-form-label\">{{'Address' | translate}}</label>\r\n <div class=\"col-sm-9\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"address\">\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-3 col-form-label\">{{'City' | translate}}</label>\r\n <div class=\"col-sm-9\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"city\">\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-3 col-form-label\">{{'Postal Code' | translate}}</label>\r\n <div class=\"col-sm-9\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"postal\">\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-3 col-form-label\">{{'SIRET' | translate}}</label>\r\n <div class=\"col-sm-9\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"siret\">\r\n </div>\r\n </div>\r\n\r\n\r\n <div *ngIf=\"createdOrg; else noOrg\">\r\n <div class=\"alert alert-info\">\r\n {{'Organisation successfully created' | translate}}\r\n </div>\r\n <lib-user-mission-form [addToOrganisation]=\"createdOrg\" [currentOrg]=\"currentOrg\" [isSP]=\"isSP\"\r\n (added)=\"userAndMissionAdded($event)\">\r\n </lib-user-mission-form>\r\n </div>\r\n <ng-template #noOrg>\r\n <div class=\"action-button-container\">\r\n <button type=\"submit\" class=\"btn btn-outline-primary rounded-pill mr-3 action-button\"\r\n [disabled]=\"this.working || form.invalid\">{{'Create organisation' | 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 <div style='margin-top: 1rem'>\r\n <h4>{{ 'User Personal Information' | translate }}</h4>\r\n </div>\r\n <ngb-alert type=\"warning\" [dismissible]=\"false\">{{'Please create new organisation first' | translate}}\r\n </ngb-alert>\r\n\r\n </ng-template>\r\n\r\n\r\n </form>\r\n</div>", styles: [".form-group{margin:1.5rem 0}.action-button-container{display:flex;justify-content:space-evenly}.action-button-container .action-button{width:145px}\n"], components: [{ type: i3.UserMissionFormComponent, selector: "lib-user-mission-form", inputs: ["addToOrganisation", "isSP", "createForExistingUser", "currentOrg"], outputs: ["added"] }, { type: i4.NgbAlert, selector: "ngb-alert", inputs: ["animation", "dismissible", "type"], outputs: ["closed"], exportAs: ["ngbAlert"] }], directives: [{ type: i5.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"] }], pipes: { "translate": i6.TranslatePipe } });
113
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: FormOrganisationComponent, decorators: [{
114
114
  type: Component,
115
- args: [{ selector: 'lib-form-organisation', template: "<div *ngIf=\"form\">\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\">\n <div>\n <h4>{{ 'Organisation' | translate }}</h4>\n </div>\n <div class=\"form-group row\" *ngIf=\"existing\">\n <label class=\"col-sm-3 col-form-label\">{{'Organisation Token' | translate}}</label>\n <div class=\"col-sm-9\">\n <input type=\"text\" class=\"form-control\" id=\"tokenInput\" placeholder=\"Paste organisation token here\">\n </div>\n </div>\n <div class=\"form-group row\">\n <label class=\"col-sm-3 col-form-label\">{{'Name' | translate}} *</label>\n <div class=\"col-sm-9\">\n <input type=\"text\" class=\"form-control\" [class.is-invalid]=\"name.invalid && name.touched\" required\n formControlName=\"name\">\n <div class=\"invalid-feedback\">\n {{'Name is mandatory' | translate}}\n </div>\n </div>\n </div>\n\n <div class=\"form-group row\">\n <label class=\"col-sm-3 col-form-label\">{{'Address' | translate}}</label>\n <div class=\"col-sm-9\">\n <input type=\"text\" class=\"form-control\" formControlName=\"address\">\n </div>\n </div>\n\n <div class=\"form-group row\">\n <label class=\"col-sm-3 col-form-label\">{{'City' | translate}}</label>\n <div class=\"col-sm-9\">\n <input type=\"text\" class=\"form-control\" formControlName=\"city\">\n </div>\n </div>\n\n <div class=\"form-group row\">\n <label class=\"col-sm-3 col-form-label\">{{'Postal Code' | translate}}</label>\n <div class=\"col-sm-9\">\n <input type=\"text\" class=\"form-control\" formControlName=\"postal\">\n </div>\n </div>\n\n <div class=\"form-group row\">\n <label class=\"col-sm-3 col-form-label\">{{'SIRET' | translate}}</label>\n <div class=\"col-sm-9\">\n <input type=\"text\" class=\"form-control\" formControlName=\"siret\">\n </div>\n </div>\n\n\n <div *ngIf=\"createdOrg; else noOrg\">\n <div class=\"alert alert-info\">\n {{'Organisation successfully created' | translate}}\n </div>\n <lib-user-mission-form [addToOrganisation]=\"createdOrg\" [currentOrg]=\"currentOrg\" [isSP]=\"isSP\"\n (added)=\"userAndMissionAdded($event)\">\n </lib-user-mission-form>\n </div>\n <ng-template #noOrg>\n <div class=\"action-button-container\">\n <button type=\"submit\" class=\"btn btn-outline-primary rounded-pill mr-3 action-button\"\n [disabled]=\"this.working || form.invalid\">{{'Create organisation' | translate}}</button>\n <button type=\"button\" (click)=\"onCancel()\" [disabled]=\"this.working\"\n class=\"btn btn-outline-primary rounded-pill action-button\">{{'Cancel' | translate}}</button>\n </div>\n <div style='margin-top: 1rem'>\n <h4>{{ 'User Personal Information' | translate }}</h4>\n </div>\n <ngb-alert type=\"warning\" [dismissible]=\"false\">{{'Please create new organisation first' | translate}}\n </ngb-alert>\n\n </ng-template>\n\n\n </form>\n</div>", styles: [".form-group{margin:1.5rem 0}.action-button-container{display:flex;justify-content:space-evenly}.action-button-container .action-button{width:145px}\n"] }]
115
+ args: [{ selector: 'lib-form-organisation', template: "<div *ngIf=\"form\">\r\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\">\r\n <div>\r\n <h4>{{ 'Organisation' | translate }}</h4>\r\n </div>\r\n <div class=\"form-group row\" *ngIf=\"existing\">\r\n <label class=\"col-sm-3 col-form-label\">{{'Organisation Token' | translate}}</label>\r\n <div class=\"col-sm-9\">\r\n <input type=\"text\" class=\"form-control\" id=\"tokenInput\" placeholder=\"Paste organisation token here\">\r\n </div>\r\n </div>\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-3 col-form-label\">{{'Name' | translate}} *</label>\r\n <div class=\"col-sm-9\">\r\n <input type=\"text\" class=\"form-control\" [class.is-invalid]=\"name.invalid && name.touched\" required\r\n formControlName=\"name\">\r\n <div class=\"invalid-feedback\">\r\n {{'Name is mandatory' | translate}}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-3 col-form-label\">{{'Address' | translate}}</label>\r\n <div class=\"col-sm-9\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"address\">\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-3 col-form-label\">{{'City' | translate}}</label>\r\n <div class=\"col-sm-9\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"city\">\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-3 col-form-label\">{{'Postal Code' | translate}}</label>\r\n <div class=\"col-sm-9\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"postal\">\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-3 col-form-label\">{{'SIRET' | translate}}</label>\r\n <div class=\"col-sm-9\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"siret\">\r\n </div>\r\n </div>\r\n\r\n\r\n <div *ngIf=\"createdOrg; else noOrg\">\r\n <div class=\"alert alert-info\">\r\n {{'Organisation successfully created' | translate}}\r\n </div>\r\n <lib-user-mission-form [addToOrganisation]=\"createdOrg\" [currentOrg]=\"currentOrg\" [isSP]=\"isSP\"\r\n (added)=\"userAndMissionAdded($event)\">\r\n </lib-user-mission-form>\r\n </div>\r\n <ng-template #noOrg>\r\n <div class=\"action-button-container\">\r\n <button type=\"submit\" class=\"btn btn-outline-primary rounded-pill mr-3 action-button\"\r\n [disabled]=\"this.working || form.invalid\">{{'Create organisation' | 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 <div style='margin-top: 1rem'>\r\n <h4>{{ 'User Personal Information' | translate }}</h4>\r\n </div>\r\n <ngb-alert type=\"warning\" [dismissible]=\"false\">{{'Please create new organisation first' | translate}}\r\n </ngb-alert>\r\n\r\n </ng-template>\r\n\r\n\r\n </form>\r\n</div>", styles: [".form-group{margin:1.5rem 0}.action-button-container{display:flex;justify-content:space-evenly}.action-button-container .action-button{width:145px}\n"] }]
116
116
  }], ctorParameters: function () { return [{ type: i1.OrganisationService }, { type: i2.FormBuilder }, { type: i1.BaseUserService }]; }, propDecorators: { currentOrg: [{
117
117
  type: Input
118
118
  }], currentUser: [{
@@ -122,4 +122,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImpor
122
122
  }], added: [{
123
123
  type: Output
124
124
  }] } });
125
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-organisation.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-smarterplan-admin/src/lib/user/form-organisation/form-organisation.component.ts","../../../../../../projects/ngx-smarterplan-admin/src/lib/user/form-organisation/form-organisation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormGroup, FormBuilder, Validators, AbstractControl } from '@angular/forms';\nimport { Organisation, ProfileEntity, OrganisationService, BaseUserService, removeNullKeysFromObject, Mission } from '@smarterplan/ngx-smarterplan-core';\n\n@Component({\n    selector: 'lib-form-organisation',\n    templateUrl: './form-organisation.component.html',\n    styleUrls: ['./form-organisation.component.scss']\n})\nexport class FormOrganisationComponent implements OnInit {\n    form: FormGroup;\n\n    working = false;\n\n    startDate: number;\n\n    endDate: number;\n\n    @Input() currentOrg: Organisation;\n\n    @Input() currentUser: ProfileEntity;\n\n    @Input() existing: boolean;\n\n    @Output() added = new EventEmitter<boolean>();\n\n    isSP: boolean;\n\n    token: string;\n\n    existingOrgID: string;\n\n    createdOrg: Organisation;\n\n    constructor(\n        private orgService: OrganisationService,\n        private fb: FormBuilder,\n        private userService: BaseUserService,\n    ) { }\n\n    async ngOnInit(): Promise<void> {\n        this.isSP = this.userService.isSPAdmin();\n        this.initForm();\n    }\n\n    ngAfterViewInit() {\n        const handlePaste = function handlePaste(event) {\n            const pastedData = event.clipboardData.getData(\"Text\");\n            if (pastedData.length > 10) {\n                this.findOrgByToken(pastedData);\n            }\n        }.bind(this);\n        if (this.existing) {\n            setTimeout(() => {\n                const inputElement = document.querySelector(\n                    \"#tokenInput\",\n                ) as HTMLInputElement;\n                inputElement.addEventListener(\"paste\", handlePaste);\n                inputElement.addEventListener(\"keydown\", ({ key }) => {\n                    if (key === \"Backspace\" || key === \"Delete\") {\n                        this.initForm();\n                    }\n                });\n                inputElement.addEventListener(\"keydown\", ({ key }) => {\n                    if (key === \"Enter\") {\n                        const { value } = inputElement;\n                        this.findOrgByToken(value);\n                    }\n                });\n            }, 600);\n        }\n    }\n\n    initForm() {\n        this.form = this.fb.group({\n            name: [null, [Validators.required]],\n            address: [\"\"],\n            city: [\"\"],\n            postal: [null],\n            siret: [null],\n        });\n        if (this.existing) {\n            const orgControls = this.form as FormGroup;\n            for (const control of Object.keys(orgControls.controls)) {\n                orgControls.controls[control].disable();\n            }\n        }\n    }\n\n    onCancel() {\n        this.form = null;\n        this.added.emit(false);\n    }\n\n    get name(): AbstractControl {\n        return this.form.get(\"name\");\n    }\n\n    async onSubmit() {\n        this.working = true;\n        const formValue = this.form.value;\n        removeNullKeysFromObject(formValue);\n        try {\n            if (!this.existing) {\n                const organisation = await this.orgService.createOrganisation(\n                    formValue,\n                );\n                if (organisation) {\n                    this.createdOrg = organisation;\n                }\n            } else {\n                // orgID = this.existingOrgID;\n            }\n        } catch (error) {\n            console.error(error);\n            this.added.emit(false);\n        }\n        this.working = false;\n    }\n\n    async findOrgByToken(token: string) {\n        const org = await this.orgService.getOrganisationByToken(token);\n        if (org) {\n            this.form.setValue({\n                name: [org.name],\n                address: [org.address],\n                city: [org.city],\n                postal: [org.postal],\n                siret: [org.siret],\n            });\n            this.existingOrgID = org.id;\n        } else {\n            alert(\"No organisation found. Maybe token is expired?\");\n        }\n    }\n\n    userAndMissionAdded(added: boolean) {\n        this.added.emit(added);\n    }\n}\n","<div *ngIf=\"form\">\n    <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\">\n        <div>\n            <h4>{{ 'Organisation' | translate }}</h4>\n        </div>\n        <div class=\"form-group row\" *ngIf=\"existing\">\n            <label class=\"col-sm-3 col-form-label\">{{'Organisation Token' | translate}}</label>\n            <div class=\"col-sm-9\">\n                <input type=\"text\" class=\"form-control\" id=\"tokenInput\" placeholder=\"Paste organisation token here\">\n            </div>\n        </div>\n        <div class=\"form-group row\">\n            <label class=\"col-sm-3 col-form-label\">{{'Name' | translate}} *</label>\n            <div class=\"col-sm-9\">\n                <input type=\"text\" class=\"form-control\" [class.is-invalid]=\"name.invalid && name.touched\" required\n                    formControlName=\"name\">\n                <div class=\"invalid-feedback\">\n                    {{'Name is mandatory' | translate}}\n                </div>\n            </div>\n        </div>\n\n        <div class=\"form-group row\">\n            <label class=\"col-sm-3 col-form-label\">{{'Address' | translate}}</label>\n            <div class=\"col-sm-9\">\n                <input type=\"text\" class=\"form-control\" formControlName=\"address\">\n            </div>\n        </div>\n\n        <div class=\"form-group row\">\n            <label class=\"col-sm-3 col-form-label\">{{'City' | translate}}</label>\n            <div class=\"col-sm-9\">\n                <input type=\"text\" class=\"form-control\" formControlName=\"city\">\n            </div>\n        </div>\n\n        <div class=\"form-group row\">\n            <label class=\"col-sm-3 col-form-label\">{{'Postal Code' | translate}}</label>\n            <div class=\"col-sm-9\">\n                <input type=\"text\" class=\"form-control\" formControlName=\"postal\">\n            </div>\n        </div>\n\n        <div class=\"form-group row\">\n            <label class=\"col-sm-3 col-form-label\">{{'SIRET' | translate}}</label>\n            <div class=\"col-sm-9\">\n                <input type=\"text\" class=\"form-control\" formControlName=\"siret\">\n            </div>\n        </div>\n\n\n        <div *ngIf=\"createdOrg; else noOrg\">\n            <div class=\"alert alert-info\">\n                {{'Organisation successfully created' | translate}}\n            </div>\n            <lib-user-mission-form [addToOrganisation]=\"createdOrg\" [currentOrg]=\"currentOrg\" [isSP]=\"isSP\"\n                (added)=\"userAndMissionAdded($event)\">\n            </lib-user-mission-form>\n        </div>\n        <ng-template #noOrg>\n            <div class=\"action-button-container\">\n                <button type=\"submit\" class=\"btn btn-outline-primary rounded-pill mr-3 action-button\"\n                    [disabled]=\"this.working || form.invalid\">{{'Create organisation' | translate}}</button>\n                <button type=\"button\" (click)=\"onCancel()\" [disabled]=\"this.working\"\n                    class=\"btn btn-outline-primary rounded-pill action-button\">{{'Cancel' | translate}}</button>\n            </div>\n            <div style='margin-top: 1rem'>\n                <h4>{{ 'User Personal Information' | translate }}</h4>\n            </div>\n            <ngb-alert type=\"warning\" [dismissible]=\"false\">{{'Please create new organisation first' | translate}}\n            </ngb-alert>\n\n        </ng-template>\n\n\n    </form>\n</div>"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-organisation.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-smarterplan-admin/src/lib/user/form-organisation/form-organisation.component.ts","../../../../../../projects/ngx-smarterplan-admin/src/lib/user/form-organisation/form-organisation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { FormGroup, FormBuilder, Validators, AbstractControl } from '@angular/forms';\r\nimport { Organisation, ProfileEntity, OrganisationService, BaseUserService, removeNullKeysFromObject, Mission } from '@smarterplan/ngx-smarterplan-core';\r\n\r\n@Component({\r\n    selector: 'lib-form-organisation',\r\n    templateUrl: './form-organisation.component.html',\r\n    styleUrls: ['./form-organisation.component.scss']\r\n})\r\nexport class FormOrganisationComponent implements OnInit {\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    @Input() currentOrg: Organisation;\r\n\r\n    @Input() currentUser: ProfileEntity;\r\n\r\n    @Input() existing: boolean;\r\n\r\n    @Output() added = new EventEmitter<boolean>();\r\n\r\n    isSP: boolean;\r\n\r\n    token: string;\r\n\r\n    existingOrgID: string;\r\n\r\n    createdOrg: Organisation;\r\n\r\n    constructor(\r\n        private orgService: OrganisationService,\r\n        private fb: FormBuilder,\r\n        private userService: BaseUserService,\r\n    ) { }\r\n\r\n    async ngOnInit(): Promise<void> {\r\n        this.isSP = this.userService.isSPAdmin();\r\n        this.initForm();\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        const handlePaste = function handlePaste(event) {\r\n            const pastedData = event.clipboardData.getData(\"Text\");\r\n            if (pastedData.length > 10) {\r\n                this.findOrgByToken(pastedData);\r\n            }\r\n        }.bind(this);\r\n        if (this.existing) {\r\n            setTimeout(() => {\r\n                const inputElement = document.querySelector(\r\n                    \"#tokenInput\",\r\n                ) as HTMLInputElement;\r\n                inputElement.addEventListener(\"paste\", handlePaste);\r\n                inputElement.addEventListener(\"keydown\", ({ key }) => {\r\n                    if (key === \"Backspace\" || key === \"Delete\") {\r\n                        this.initForm();\r\n                    }\r\n                });\r\n                inputElement.addEventListener(\"keydown\", ({ key }) => {\r\n                    if (key === \"Enter\") {\r\n                        const { value } = inputElement;\r\n                        this.findOrgByToken(value);\r\n                    }\r\n                });\r\n            }, 600);\r\n        }\r\n    }\r\n\r\n    initForm() {\r\n        this.form = this.fb.group({\r\n            name: [null, [Validators.required]],\r\n            address: [\"\"],\r\n            city: [\"\"],\r\n            postal: [null],\r\n            siret: [null],\r\n        });\r\n        if (this.existing) {\r\n            const orgControls = this.form as FormGroup;\r\n            for (const control of Object.keys(orgControls.controls)) {\r\n                orgControls.controls[control].disable();\r\n            }\r\n        }\r\n    }\r\n\r\n    onCancel() {\r\n        this.form = null;\r\n        this.added.emit(false);\r\n    }\r\n\r\n    get name(): AbstractControl {\r\n        return this.form.get(\"name\");\r\n    }\r\n\r\n    async onSubmit() {\r\n        this.working = true;\r\n        const formValue = this.form.value;\r\n        removeNullKeysFromObject(formValue);\r\n        try {\r\n            if (!this.existing) {\r\n                const organisation = await this.orgService.createOrganisation(\r\n                    formValue,\r\n                );\r\n                if (organisation) {\r\n                    this.createdOrg = organisation;\r\n                }\r\n            } else {\r\n                // orgID = this.existingOrgID;\r\n            }\r\n        } catch (error) {\r\n            console.error(error);\r\n            this.added.emit(false);\r\n        }\r\n        this.working = false;\r\n    }\r\n\r\n    async findOrgByToken(token: string) {\r\n        const org = await this.orgService.getOrganisationByToken(token);\r\n        if (org) {\r\n            this.form.setValue({\r\n                name: [org.name],\r\n                address: [org.address],\r\n                city: [org.city],\r\n                postal: [org.postal],\r\n                siret: [org.siret],\r\n            });\r\n            this.existingOrgID = org.id;\r\n        } else {\r\n            alert(\"No organisation found. Maybe token is expired?\");\r\n        }\r\n    }\r\n\r\n    userAndMissionAdded(added: boolean) {\r\n        this.added.emit(added);\r\n    }\r\n}\r\n","<div *ngIf=\"form\">\r\n    <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\">\r\n        <div>\r\n            <h4>{{ 'Organisation' | translate }}</h4>\r\n        </div>\r\n        <div class=\"form-group row\" *ngIf=\"existing\">\r\n            <label class=\"col-sm-3 col-form-label\">{{'Organisation Token' | translate}}</label>\r\n            <div class=\"col-sm-9\">\r\n                <input type=\"text\" class=\"form-control\" id=\"tokenInput\" placeholder=\"Paste organisation token here\">\r\n            </div>\r\n        </div>\r\n        <div class=\"form-group row\">\r\n            <label class=\"col-sm-3 col-form-label\">{{'Name' | translate}} *</label>\r\n            <div class=\"col-sm-9\">\r\n                <input type=\"text\" class=\"form-control\" [class.is-invalid]=\"name.invalid && name.touched\" required\r\n                    formControlName=\"name\">\r\n                <div class=\"invalid-feedback\">\r\n                    {{'Name is mandatory' | translate}}\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"form-group row\">\r\n            <label class=\"col-sm-3 col-form-label\">{{'Address' | translate}}</label>\r\n            <div class=\"col-sm-9\">\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"address\">\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"form-group row\">\r\n            <label class=\"col-sm-3 col-form-label\">{{'City' | translate}}</label>\r\n            <div class=\"col-sm-9\">\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"city\">\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"form-group row\">\r\n            <label class=\"col-sm-3 col-form-label\">{{'Postal Code' | translate}}</label>\r\n            <div class=\"col-sm-9\">\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"postal\">\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"form-group row\">\r\n            <label class=\"col-sm-3 col-form-label\">{{'SIRET' | translate}}</label>\r\n            <div class=\"col-sm-9\">\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"siret\">\r\n            </div>\r\n        </div>\r\n\r\n\r\n        <div *ngIf=\"createdOrg; else noOrg\">\r\n            <div class=\"alert alert-info\">\r\n                {{'Organisation successfully created' | translate}}\r\n            </div>\r\n            <lib-user-mission-form [addToOrganisation]=\"createdOrg\" [currentOrg]=\"currentOrg\" [isSP]=\"isSP\"\r\n                (added)=\"userAndMissionAdded($event)\">\r\n            </lib-user-mission-form>\r\n        </div>\r\n        <ng-template #noOrg>\r\n            <div class=\"action-button-container\">\r\n                <button type=\"submit\" class=\"btn btn-outline-primary rounded-pill mr-3 action-button\"\r\n                    [disabled]=\"this.working || form.invalid\">{{'Create organisation' | 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            <div style='margin-top: 1rem'>\r\n                <h4>{{ 'User Personal Information' | translate }}</h4>\r\n            </div>\r\n            <ngb-alert type=\"warning\" [dismissible]=\"false\">{{'Please create new organisation first' | translate}}\r\n            </ngb-alert>\r\n\r\n        </ng-template>\r\n\r\n\r\n    </form>\r\n</div>"]}
@@ -102,11 +102,11 @@ export class UserMissionFormComponent {
102
102
  }
103
103
  }
104
104
  }
105
- UserMissionFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: UserMissionFormComponent, deps: [{ token: i1.FormBuilder }, { token: i2.BaseUserService }, { token: i3.TranslateService }, { token: i2.ValidatorsService }], target: i0.ɵɵFactoryTarget.Component });
106
- UserMissionFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: UserMissionFormComponent, selector: "lib-user-mission-form", inputs: { addToOrganisation: "addToOrganisation", isSP: "isSP", createForExistingUser: "createForExistingUser", currentOrg: "currentOrg" }, outputs: { added: "added" }, ngImport: i0, template: "<div *ngIf=\"form\">\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\">\n <div id=\"personalInfo\">\n <div style=\"margin-top: 1rem;\">\n <h4>{{ 'User Personal Information' | translate }}</h4>\n </div>\n <div class=\"form-group row\">\n <label class=\"col-sm-4 col-form-label\">{{'Email' | translate}} *</label>\n <div class=\"col-sm-8\">\n <input type=\"text\" class=\"form-control\" data-testid=\"new-user-email\"\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(form.controls['email'])|| isFormError(form.controls['email'])}\"\n required formControlName=\"email\">\n <div class=\"invalid-feedback\">\n <ngb-alert data-testid=\"new-user-email-invalid\" [dismissible]=\"false\" type=\"danger\" *ngIf=\"validatorsService.isControlError(form.controls['email']) \n || isFormError(form.controls['email'])\">\n {{validatorsService.getError(form.controls['email']) | translate}}\n </ngb-alert>\n\n </div>\n </div>\n </div>\n\n <div class=\"form-group row\">\n <label class=\"col-sm-4 col-form-label\">{{'Last name' | translate}}</label>\n <div class=\"col-sm-8\">\n <input type=\"text\" class=\"form-control\" formControlName=\"lastName\" data-testid=\"new-user-lastName\"\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(form.controls['lastName'])|| isFormError(form.controls['lastName'])}\">\n <div class=\"invalid-feedback\">\n <ngb-alert data-testid=\"new-user-lastName-invalid\" [dismissible]=\"false\" type=\"danger\" *ngIf=\"validatorsService.isControlError(form.controls['lastName']) \n || isFormError(form.controls['lastName'])\">\n {{validatorsService.getError(form.controls['lastName']) | translate}}\n </ngb-alert>\n\n </div>\n </div>\n </div>\n\n <div class=\"form-group row\">\n <label class=\"col-sm-4 col-form-label\">{{'First name' | translate}}</label>\n <div class=\"col-sm-8\">\n <input type=\"text\" class=\"form-control\" formControlName=\"firstName\" data-testid=\"new-user-firstName\"\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(form.controls['firstName'])|| isFormError(form.controls['firstName'])}\">\n <div class=\"invalid-feedback\">\n <ngb-alert data-testid=\"new-user-firstName-invalid\" [dismissible]=\"false\" type=\"danger\" *ngIf=\"validatorsService.isControlError(form.controls['firstName']) \n || isFormError(form.controls['firstName'])\">\n {{validatorsService.getError(form.controls['firstName']) | translate}}\n </ngb-alert>\n\n </div>\n </div>\n </div>\n </div>\n <div class=\"d-flex justify-content-center\" *ngIf=\"working\">\n <lib-loader></lib-loader>\n </div>\n\n <div *ngIf=\"createdUser; else waitingForUser\">\n <div class=\"alert alert-info\">\n {{'User successfully created' | translate}}\n </div>\n <lib-form-mission [organisationForMission]=\"addToOrganisation\" [userForMissionID]=\"createdUser.id\"\n [currentUserOrganisation]=\"currentOrg\" [isSP]=\"isSP\" (addedMissionInput)=\"onMissionInput($event)\">\n </lib-form-mission>\n </div>\n <ng-template #waitingForUser>\n <div class=\"action-button-container\">\n <button data-testid=\"new-user-submit-btn\" type=\"submit\" class=\"btn btn-outline-primary rounded-pill mr-3 action-button\"\n [disabled]=\"working\">{{'Create user' | translate}}</button>\n <button data-testid=\"new-user-cancel-btn\" type=\"button\" (click)=\"onCancel()\" [disabled]=\"working\"\n class=\"btn btn-outline-primary rounded-pill action-button\">{{'Cancel' | translate}}</button>\n </div>\n <div class=\"invalid-feedback\" *ngIf=\"errorForm\">\n <ngb-alert data-testid=\"new-user-form-invalid\" [dismissible]=\"false\" type=\"danger\">\n {{'errorForm.infoBtn' |translate}}\n </ngb-alert>\n </div>\n <div style=\"margin-top: 1rem;\">\n <h4>{{ 'Mission details' | translate }}</h4>\n </div>\n <ngb-alert type=\"warning\" [dismissible]=\"false\">{{'Please create a user first' | translate}}.</ngb-alert>\n\n </ng-template>\n </form>\n</div>", styles: [".form-group{margin:1.5rem 0}.action-button-container{display:flex;justify-content:space-evenly}.action-button-container .action-button{width:145px}\n"], components: [{ type: i4.NgbAlert, selector: "ngb-alert", inputs: ["animation", "dismissible", "type"], outputs: ["closed"], exportAs: ["ngbAlert"] }, { type: i2.LoaderComponent, selector: "lib-loader", inputs: ["useLogo", "color"] }, { type: i5.FormMissionComponent, selector: "lib-form-mission", inputs: ["missionToEdit", "organisationForMission", "isSP", "userForMissionID", "currentUserOrganisation"], outputs: ["addedMissionInput"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "translate": i3.TranslatePipe } });
107
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: UserMissionFormComponent, decorators: [{
105
+ UserMissionFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: UserMissionFormComponent, deps: [{ token: i1.FormBuilder }, { token: i2.BaseUserService }, { token: i3.TranslateService }, { token: i2.ValidatorsService }], target: i0.ɵɵFactoryTarget.Component });
106
+ UserMissionFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: UserMissionFormComponent, selector: "lib-user-mission-form", inputs: { addToOrganisation: "addToOrganisation", isSP: "isSP", createForExistingUser: "createForExistingUser", currentOrg: "currentOrg" }, outputs: { added: "added" }, ngImport: i0, template: "<div *ngIf=\"form\">\r\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\">\r\n <div id=\"personalInfo\">\r\n <div style=\"margin-top: 1rem;\">\r\n <h4>{{ 'User Personal Information' | translate }}</h4>\r\n </div>\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-4 col-form-label\">{{'Email' | translate}} *</label>\r\n <div class=\"col-sm-8\">\r\n <input type=\"text\" class=\"form-control\" data-testid=\"new-user-email\"\r\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(form.controls['email'])|| isFormError(form.controls['email'])}\"\r\n required formControlName=\"email\">\r\n <div class=\"invalid-feedback\">\r\n <ngb-alert data-testid=\"new-user-email-invalid\" [dismissible]=\"false\" type=\"danger\" *ngIf=\"validatorsService.isControlError(form.controls['email']) \r\n || isFormError(form.controls['email'])\">\r\n {{validatorsService.getError(form.controls['email']) | translate}}\r\n </ngb-alert>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-4 col-form-label\">{{'Last name' | translate}}</label>\r\n <div class=\"col-sm-8\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"lastName\" data-testid=\"new-user-lastName\"\r\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(form.controls['lastName'])|| isFormError(form.controls['lastName'])}\">\r\n <div class=\"invalid-feedback\">\r\n <ngb-alert data-testid=\"new-user-lastName-invalid\" [dismissible]=\"false\" type=\"danger\" *ngIf=\"validatorsService.isControlError(form.controls['lastName']) \r\n || isFormError(form.controls['lastName'])\">\r\n {{validatorsService.getError(form.controls['lastName']) | translate}}\r\n </ngb-alert>\r\n\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\">{{'First name' | translate}}</label>\r\n <div class=\"col-sm-8\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"firstName\" data-testid=\"new-user-firstName\"\r\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(form.controls['firstName'])|| isFormError(form.controls['firstName'])}\">\r\n <div class=\"invalid-feedback\">\r\n <ngb-alert data-testid=\"new-user-firstName-invalid\" [dismissible]=\"false\" type=\"danger\" *ngIf=\"validatorsService.isControlError(form.controls['firstName']) \r\n || isFormError(form.controls['firstName'])\">\r\n {{validatorsService.getError(form.controls['firstName']) | translate}}\r\n </ngb-alert>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"d-flex justify-content-center\" *ngIf=\"working\">\r\n <lib-loader></lib-loader>\r\n </div>\r\n\r\n <div *ngIf=\"createdUser; else waitingForUser\">\r\n <div class=\"alert alert-info\">\r\n {{'User successfully created' | translate}}\r\n </div>\r\n <lib-form-mission [organisationForMission]=\"addToOrganisation\" [userForMissionID]=\"createdUser.id\"\r\n [currentUserOrganisation]=\"currentOrg\" [isSP]=\"isSP\" (addedMissionInput)=\"onMissionInput($event)\">\r\n </lib-form-mission>\r\n </div>\r\n <ng-template #waitingForUser>\r\n <div class=\"action-button-container\">\r\n <button data-testid=\"new-user-submit-btn\" type=\"submit\" class=\"btn btn-outline-primary rounded-pill mr-3 action-button\"\r\n [disabled]=\"working\">{{'Create user' | translate}}</button>\r\n <button data-testid=\"new-user-cancel-btn\" type=\"button\" (click)=\"onCancel()\" [disabled]=\"working\"\r\n class=\"btn btn-outline-primary rounded-pill action-button\">{{'Cancel' | translate}}</button>\r\n </div>\r\n <div class=\"invalid-feedback\" *ngIf=\"errorForm\">\r\n <ngb-alert data-testid=\"new-user-form-invalid\" [dismissible]=\"false\" type=\"danger\">\r\n {{'errorForm.infoBtn' |translate}}\r\n </ngb-alert>\r\n </div>\r\n <div style=\"margin-top: 1rem;\">\r\n <h4>{{ 'Mission details' | translate }}</h4>\r\n </div>\r\n <ngb-alert type=\"warning\" [dismissible]=\"false\">{{'Please create a user first' | translate}}.</ngb-alert>\r\n\r\n </ng-template>\r\n </form>\r\n</div>", styles: [".form-group{margin:1.5rem 0}.action-button-container{display:flex;justify-content:space-evenly}.action-button-container .action-button{width:145px}\n"], components: [{ type: i4.NgbAlert, selector: "ngb-alert", inputs: ["animation", "dismissible", "type"], outputs: ["closed"], exportAs: ["ngbAlert"] }, { type: i2.LoaderComponent, selector: "lib-loader", inputs: ["useLogo", "color"] }, { type: i5.FormMissionComponent, selector: "lib-form-mission", inputs: ["missionToEdit", "organisationForMission", "isSP", "userForMissionID", "currentUserOrganisation"], outputs: ["addedMissionInput"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "translate": i3.TranslatePipe } });
107
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: UserMissionFormComponent, decorators: [{
108
108
  type: Component,
109
- args: [{ selector: 'lib-user-mission-form', template: "<div *ngIf=\"form\">\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\">\n <div id=\"personalInfo\">\n <div style=\"margin-top: 1rem;\">\n <h4>{{ 'User Personal Information' | translate }}</h4>\n </div>\n <div class=\"form-group row\">\n <label class=\"col-sm-4 col-form-label\">{{'Email' | translate}} *</label>\n <div class=\"col-sm-8\">\n <input type=\"text\" class=\"form-control\" data-testid=\"new-user-email\"\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(form.controls['email'])|| isFormError(form.controls['email'])}\"\n required formControlName=\"email\">\n <div class=\"invalid-feedback\">\n <ngb-alert data-testid=\"new-user-email-invalid\" [dismissible]=\"false\" type=\"danger\" *ngIf=\"validatorsService.isControlError(form.controls['email']) \n || isFormError(form.controls['email'])\">\n {{validatorsService.getError(form.controls['email']) | translate}}\n </ngb-alert>\n\n </div>\n </div>\n </div>\n\n <div class=\"form-group row\">\n <label class=\"col-sm-4 col-form-label\">{{'Last name' | translate}}</label>\n <div class=\"col-sm-8\">\n <input type=\"text\" class=\"form-control\" formControlName=\"lastName\" data-testid=\"new-user-lastName\"\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(form.controls['lastName'])|| isFormError(form.controls['lastName'])}\">\n <div class=\"invalid-feedback\">\n <ngb-alert data-testid=\"new-user-lastName-invalid\" [dismissible]=\"false\" type=\"danger\" *ngIf=\"validatorsService.isControlError(form.controls['lastName']) \n || isFormError(form.controls['lastName'])\">\n {{validatorsService.getError(form.controls['lastName']) | translate}}\n </ngb-alert>\n\n </div>\n </div>\n </div>\n\n <div class=\"form-group row\">\n <label class=\"col-sm-4 col-form-label\">{{'First name' | translate}}</label>\n <div class=\"col-sm-8\">\n <input type=\"text\" class=\"form-control\" formControlName=\"firstName\" data-testid=\"new-user-firstName\"\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(form.controls['firstName'])|| isFormError(form.controls['firstName'])}\">\n <div class=\"invalid-feedback\">\n <ngb-alert data-testid=\"new-user-firstName-invalid\" [dismissible]=\"false\" type=\"danger\" *ngIf=\"validatorsService.isControlError(form.controls['firstName']) \n || isFormError(form.controls['firstName'])\">\n {{validatorsService.getError(form.controls['firstName']) | translate}}\n </ngb-alert>\n\n </div>\n </div>\n </div>\n </div>\n <div class=\"d-flex justify-content-center\" *ngIf=\"working\">\n <lib-loader></lib-loader>\n </div>\n\n <div *ngIf=\"createdUser; else waitingForUser\">\n <div class=\"alert alert-info\">\n {{'User successfully created' | translate}}\n </div>\n <lib-form-mission [organisationForMission]=\"addToOrganisation\" [userForMissionID]=\"createdUser.id\"\n [currentUserOrganisation]=\"currentOrg\" [isSP]=\"isSP\" (addedMissionInput)=\"onMissionInput($event)\">\n </lib-form-mission>\n </div>\n <ng-template #waitingForUser>\n <div class=\"action-button-container\">\n <button data-testid=\"new-user-submit-btn\" type=\"submit\" class=\"btn btn-outline-primary rounded-pill mr-3 action-button\"\n [disabled]=\"working\">{{'Create user' | translate}}</button>\n <button data-testid=\"new-user-cancel-btn\" type=\"button\" (click)=\"onCancel()\" [disabled]=\"working\"\n class=\"btn btn-outline-primary rounded-pill action-button\">{{'Cancel' | translate}}</button>\n </div>\n <div class=\"invalid-feedback\" *ngIf=\"errorForm\">\n <ngb-alert data-testid=\"new-user-form-invalid\" [dismissible]=\"false\" type=\"danger\">\n {{'errorForm.infoBtn' |translate}}\n </ngb-alert>\n </div>\n <div style=\"margin-top: 1rem;\">\n <h4>{{ 'Mission details' | translate }}</h4>\n </div>\n <ngb-alert type=\"warning\" [dismissible]=\"false\">{{'Please create a user first' | translate}}.</ngb-alert>\n\n </ng-template>\n </form>\n</div>", styles: [".form-group{margin:1.5rem 0}.action-button-container{display:flex;justify-content:space-evenly}.action-button-container .action-button{width:145px}\n"] }]
109
+ args: [{ selector: 'lib-user-mission-form', template: "<div *ngIf=\"form\">\r\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\">\r\n <div id=\"personalInfo\">\r\n <div style=\"margin-top: 1rem;\">\r\n <h4>{{ 'User Personal Information' | translate }}</h4>\r\n </div>\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-4 col-form-label\">{{'Email' | translate}} *</label>\r\n <div class=\"col-sm-8\">\r\n <input type=\"text\" class=\"form-control\" data-testid=\"new-user-email\"\r\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(form.controls['email'])|| isFormError(form.controls['email'])}\"\r\n required formControlName=\"email\">\r\n <div class=\"invalid-feedback\">\r\n <ngb-alert data-testid=\"new-user-email-invalid\" [dismissible]=\"false\" type=\"danger\" *ngIf=\"validatorsService.isControlError(form.controls['email']) \r\n || isFormError(form.controls['email'])\">\r\n {{validatorsService.getError(form.controls['email']) | translate}}\r\n </ngb-alert>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group row\">\r\n <label class=\"col-sm-4 col-form-label\">{{'Last name' | translate}}</label>\r\n <div class=\"col-sm-8\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"lastName\" data-testid=\"new-user-lastName\"\r\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(form.controls['lastName'])|| isFormError(form.controls['lastName'])}\">\r\n <div class=\"invalid-feedback\">\r\n <ngb-alert data-testid=\"new-user-lastName-invalid\" [dismissible]=\"false\" type=\"danger\" *ngIf=\"validatorsService.isControlError(form.controls['lastName']) \r\n || isFormError(form.controls['lastName'])\">\r\n {{validatorsService.getError(form.controls['lastName']) | translate}}\r\n </ngb-alert>\r\n\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\">{{'First name' | translate}}</label>\r\n <div class=\"col-sm-8\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"firstName\" data-testid=\"new-user-firstName\"\r\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(form.controls['firstName'])|| isFormError(form.controls['firstName'])}\">\r\n <div class=\"invalid-feedback\">\r\n <ngb-alert data-testid=\"new-user-firstName-invalid\" [dismissible]=\"false\" type=\"danger\" *ngIf=\"validatorsService.isControlError(form.controls['firstName']) \r\n || isFormError(form.controls['firstName'])\">\r\n {{validatorsService.getError(form.controls['firstName']) | translate}}\r\n </ngb-alert>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"d-flex justify-content-center\" *ngIf=\"working\">\r\n <lib-loader></lib-loader>\r\n </div>\r\n\r\n <div *ngIf=\"createdUser; else waitingForUser\">\r\n <div class=\"alert alert-info\">\r\n {{'User successfully created' | translate}}\r\n </div>\r\n <lib-form-mission [organisationForMission]=\"addToOrganisation\" [userForMissionID]=\"createdUser.id\"\r\n [currentUserOrganisation]=\"currentOrg\" [isSP]=\"isSP\" (addedMissionInput)=\"onMissionInput($event)\">\r\n </lib-form-mission>\r\n </div>\r\n <ng-template #waitingForUser>\r\n <div class=\"action-button-container\">\r\n <button data-testid=\"new-user-submit-btn\" type=\"submit\" class=\"btn btn-outline-primary rounded-pill mr-3 action-button\"\r\n [disabled]=\"working\">{{'Create user' | translate}}</button>\r\n <button data-testid=\"new-user-cancel-btn\" type=\"button\" (click)=\"onCancel()\" [disabled]=\"working\"\r\n class=\"btn btn-outline-primary rounded-pill action-button\">{{'Cancel' | translate}}</button>\r\n </div>\r\n <div class=\"invalid-feedback\" *ngIf=\"errorForm\">\r\n <ngb-alert data-testid=\"new-user-form-invalid\" [dismissible]=\"false\" type=\"danger\">\r\n {{'errorForm.infoBtn' |translate}}\r\n </ngb-alert>\r\n </div>\r\n <div style=\"margin-top: 1rem;\">\r\n <h4>{{ 'Mission details' | translate }}</h4>\r\n </div>\r\n <ngb-alert type=\"warning\" [dismissible]=\"false\">{{'Please create a user first' | translate}}.</ngb-alert>\r\n\r\n </ng-template>\r\n </form>\r\n</div>", styles: [".form-group{margin:1.5rem 0}.action-button-container{display:flex;justify-content:space-evenly}.action-button-container .action-button{width:145px}\n"] }]
110
110
  }], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.BaseUserService }, { type: i3.TranslateService }, { type: i2.ValidatorsService }]; }, propDecorators: { addToOrganisation: [{
111
111
  type: Input
112
112
  }], isSP: [{
@@ -118,4 +118,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImpor
118
118
  }], added: [{
119
119
  type: Output
120
120
  }] } });
121
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-mission-form.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-smarterplan-admin/src/lib/user/user-mission-form/user-mission-form.component.ts","../../../../../../projects/ngx-smarterplan-admin/src/lib/user/user-mission-form/user-mission-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormGroup, FormBuilder, Validators, AbstractControl } from '@angular/forms';\nimport { TranslateService } from '@ngx-translate/core';\nimport { Organisation, Mission, Profile, BaseUserService, ValidatorsService,textValidator, noEmptyValidator, emailValidator } from '@smarterplan/ngx-smarterplan-core';\n\n@Component({\n    selector: 'lib-user-mission-form',\n    templateUrl: './user-mission-form.component.html',\n    styleUrls: ['./user-mission-form.component.scss']\n})\nexport class UserMissionFormComponent implements OnInit {\n\n    @Input() addToOrganisation: Organisation;\n\n    @Input() isSP: boolean;\n\n    @Input() createForExistingUser = false;\n\n    form: FormGroup;\n\n    @Input() currentOrg: Organisation;\n\n    @Output() added = new EventEmitter<boolean>();\n\n    working = false;\n\n    missionInput: Mission;\n\n    createdUser: Profile;\n\n    errorForm: boolean = false;\n\n    constructor(\n        private fb: FormBuilder,\n        private userService: BaseUserService,\n        private translate: TranslateService,\n        public validatorsService : ValidatorsService\n    ) { }\n\n    ngOnInit() {\n        this.onAddNewUserMissionToOrg();\n    }\n\n    async onAddNewUserMissionToOrg() {\n        this.form = this.fb.group({\n            email: [null, [Validators.required, emailValidator()]],\n            lastName: [\"\", [Validators.maxLength(255), textValidator(), noEmptyValidator()]],\n            firstName: [\"\",[Validators.maxLength(255), textValidator(), noEmptyValidator()]],\n        });\n    }\n\n    onCancel() {\n        this.added.emit(false);\n    }\n\n    get email(): AbstractControl {\n        return this.form.get(\"email\");\n    }\n\n    async onSubmit() {\n        if (!this.form.valid) {\n            this.errorForm = true;\n            return;\n        }\n\n        this.working = true;\n        let p: Profile;\n        try {\n            const formValue = this.form.value;\n            p = await this.userService.profileForMail(formValue.email);\n            if (p) {\n                alert(\"User with this email exists already!\");\n                this.working = false;\n                return;\n            }\n            try {\n                const profile = await this.userService.createUserAWSandProfile(\n                    formValue,\n                    true,\n                );\n                console.log(\"User created!\", profile.metadata);\n                this.createdUser = profile;\n            } catch (error) {\n                this.working = false;\n                alert(this.translate.instant(JSON.stringify(error)));\n                return;\n            }\n        } catch (error) {\n            console.error(error);\n        }\n        this.working = false;\n    }\n\n    // async updateAllMissionsFromTemplate(missionInput: UpdateMissionInput) {\n    //     // all missions of this organisation\n    //     const missionsFromTemplate =\n    //         await this.missionService.getMissionsByTemplate(\n    //             this.missionToEdit.id,\n    //         );\n    //     await Promise.all(\n    //         missionsFromTemplate.map(async (mission) => {\n    //             const missionTemplate = { ...missionInput };\n    //             if (this.sendUpdate) {\n    //                 missionTemplate.emailStatus = EmailStatus.UPDATE_TO_DELIVER;\n    //             }\n    //             missionTemplate.id = mission.id;\n    //             await this.missionService.update(missionTemplate);\n    //         }),\n    //     );\n    // }\n\n    async onMissionInput(mission: Mission) {\n        if (mission) {\n            this.missionInput = mission;\n            await this.userService.createOrUpdateMissionForOrgWithProperty(\n                this.missionInput as Mission,\n                this.missionInput.organisationID,\n            );\n            this.added.emit(true);\n        } else {\n            this.added.emit(false);\n        }\n    }\n\n    isFormError(control) {\n        return control && control.invalid && this.errorForm;\n    }\n\n\n    onFormChange() {\n        if (this.errorForm && this.form.valid) {\n            this.errorForm = false;\n        }\n\n    }\n}\n","<div *ngIf=\"form\">\n    <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\">\n        <div id=\"personalInfo\">\n            <div style=\"margin-top: 1rem;\">\n                <h4>{{ 'User Personal Information' | translate }}</h4>\n            </div>\n            <div class=\"form-group row\">\n                <label class=\"col-sm-4 col-form-label\">{{'Email' | translate}} *</label>\n                <div class=\"col-sm-8\">\n                    <input type=\"text\" class=\"form-control\" data-testid=\"new-user-email\"\n                        [ngClass]=\"{'is-invalid' : validatorsService.isControlError(form.controls['email'])||  isFormError(form.controls['email'])}\"\n                        required formControlName=\"email\">\n                    <div class=\"invalid-feedback\">\n                        <ngb-alert data-testid=\"new-user-email-invalid\" [dismissible]=\"false\" type=\"danger\" *ngIf=\"validatorsService.isControlError(form.controls['email']) \n                                ||  isFormError(form.controls['email'])\">\n                            {{validatorsService.getError(form.controls['email']) | translate}}\n                        </ngb-alert>\n\n                    </div>\n                </div>\n            </div>\n\n            <div class=\"form-group row\">\n                <label class=\"col-sm-4 col-form-label\">{{'Last name' | translate}}</label>\n                <div class=\"col-sm-8\">\n                    <input type=\"text\" class=\"form-control\" formControlName=\"lastName\" data-testid=\"new-user-lastName\"\n                    [ngClass]=\"{'is-invalid' : validatorsService.isControlError(form.controls['lastName'])||  isFormError(form.controls['lastName'])}\">\n                    <div class=\"invalid-feedback\">\n                        <ngb-alert data-testid=\"new-user-lastName-invalid\" [dismissible]=\"false\" type=\"danger\" *ngIf=\"validatorsService.isControlError(form.controls['lastName']) \n                                ||  isFormError(form.controls['lastName'])\">\n                            {{validatorsService.getError(form.controls['lastName']) | translate}}\n                        </ngb-alert>\n\n                    </div>\n                </div>\n            </div>\n\n            <div class=\"form-group row\">\n                <label class=\"col-sm-4 col-form-label\">{{'First name' | translate}}</label>\n                <div class=\"col-sm-8\">\n                    <input type=\"text\" class=\"form-control\" formControlName=\"firstName\" data-testid=\"new-user-firstName\"\n                    [ngClass]=\"{'is-invalid' : validatorsService.isControlError(form.controls['firstName'])||  isFormError(form.controls['firstName'])}\">\n                    <div class=\"invalid-feedback\">\n                        <ngb-alert data-testid=\"new-user-firstName-invalid\" [dismissible]=\"false\" type=\"danger\" *ngIf=\"validatorsService.isControlError(form.controls['firstName']) \n                                ||  isFormError(form.controls['firstName'])\">\n                            {{validatorsService.getError(form.controls['firstName']) | translate}}\n                        </ngb-alert>\n\n                    </div>\n                </div>\n            </div>\n        </div>\n        <div class=\"d-flex justify-content-center\" *ngIf=\"working\">\n            <lib-loader></lib-loader>\n        </div>\n\n        <div *ngIf=\"createdUser; else waitingForUser\">\n            <div class=\"alert alert-info\">\n                {{'User successfully created' | translate}}\n            </div>\n            <lib-form-mission [organisationForMission]=\"addToOrganisation\" [userForMissionID]=\"createdUser.id\"\n                [currentUserOrganisation]=\"currentOrg\" [isSP]=\"isSP\" (addedMissionInput)=\"onMissionInput($event)\">\n            </lib-form-mission>\n        </div>\n        <ng-template #waitingForUser>\n            <div class=\"action-button-container\">\n                <button data-testid=\"new-user-submit-btn\" type=\"submit\" class=\"btn btn-outline-primary rounded-pill mr-3 action-button\"\n                    [disabled]=\"working\">{{'Create user' | translate}}</button>\n                <button data-testid=\"new-user-cancel-btn\" type=\"button\" (click)=\"onCancel()\" [disabled]=\"working\"\n                    class=\"btn btn-outline-primary rounded-pill action-button\">{{'Cancel' | translate}}</button>\n            </div>\n            <div class=\"invalid-feedback\" *ngIf=\"errorForm\">\n                <ngb-alert data-testid=\"new-user-form-invalid\" [dismissible]=\"false\" type=\"danger\">\n                    {{'errorForm.infoBtn' |translate}}\n                </ngb-alert>\n            </div>\n            <div style=\"margin-top: 1rem;\">\n                <h4>{{ 'Mission details' | translate }}</h4>\n            </div>\n            <ngb-alert type=\"warning\" [dismissible]=\"false\">{{'Please create a user first' | translate}}.</ngb-alert>\n\n        </ng-template>\n    </form>\n</div>"]}
121
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-mission-form.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-smarterplan-admin/src/lib/user/user-mission-form/user-mission-form.component.ts","../../../../../../projects/ngx-smarterplan-admin/src/lib/user/user-mission-form/user-mission-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { FormGroup, FormBuilder, Validators, AbstractControl } from '@angular/forms';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Organisation, Mission, Profile, BaseUserService, ValidatorsService,textValidator, noEmptyValidator, emailValidator } from '@smarterplan/ngx-smarterplan-core';\r\n\r\n@Component({\r\n    selector: 'lib-user-mission-form',\r\n    templateUrl: './user-mission-form.component.html',\r\n    styleUrls: ['./user-mission-form.component.scss']\r\n})\r\nexport class UserMissionFormComponent implements OnInit {\r\n\r\n    @Input() addToOrganisation: Organisation;\r\n\r\n    @Input() isSP: boolean;\r\n\r\n    @Input() createForExistingUser = false;\r\n\r\n    form: FormGroup;\r\n\r\n    @Input() currentOrg: Organisation;\r\n\r\n    @Output() added = new EventEmitter<boolean>();\r\n\r\n    working = false;\r\n\r\n    missionInput: Mission;\r\n\r\n    createdUser: Profile;\r\n\r\n    errorForm: boolean = false;\r\n\r\n    constructor(\r\n        private fb: FormBuilder,\r\n        private userService: BaseUserService,\r\n        private translate: TranslateService,\r\n        public validatorsService : ValidatorsService\r\n    ) { }\r\n\r\n    ngOnInit() {\r\n        this.onAddNewUserMissionToOrg();\r\n    }\r\n\r\n    async onAddNewUserMissionToOrg() {\r\n        this.form = this.fb.group({\r\n            email: [null, [Validators.required, emailValidator()]],\r\n            lastName: [\"\", [Validators.maxLength(255), textValidator(), noEmptyValidator()]],\r\n            firstName: [\"\",[Validators.maxLength(255), textValidator(), noEmptyValidator()]],\r\n        });\r\n    }\r\n\r\n    onCancel() {\r\n        this.added.emit(false);\r\n    }\r\n\r\n    get email(): AbstractControl {\r\n        return this.form.get(\"email\");\r\n    }\r\n\r\n    async onSubmit() {\r\n        if (!this.form.valid) {\r\n            this.errorForm = true;\r\n            return;\r\n        }\r\n\r\n        this.working = true;\r\n        let p: Profile;\r\n        try {\r\n            const formValue = this.form.value;\r\n            p = await this.userService.profileForMail(formValue.email);\r\n            if (p) {\r\n                alert(\"User with this email exists already!\");\r\n                this.working = false;\r\n                return;\r\n            }\r\n            try {\r\n                const profile = await this.userService.createUserAWSandProfile(\r\n                    formValue,\r\n                    true,\r\n                );\r\n                console.log(\"User created!\", profile.metadata);\r\n                this.createdUser = profile;\r\n            } catch (error) {\r\n                this.working = false;\r\n                alert(this.translate.instant(JSON.stringify(error)));\r\n                return;\r\n            }\r\n        } catch (error) {\r\n            console.error(error);\r\n        }\r\n        this.working = false;\r\n    }\r\n\r\n    // async updateAllMissionsFromTemplate(missionInput: UpdateMissionInput) {\r\n    //     // all missions of this organisation\r\n    //     const missionsFromTemplate =\r\n    //         await this.missionService.getMissionsByTemplate(\r\n    //             this.missionToEdit.id,\r\n    //         );\r\n    //     await Promise.all(\r\n    //         missionsFromTemplate.map(async (mission) => {\r\n    //             const missionTemplate = { ...missionInput };\r\n    //             if (this.sendUpdate) {\r\n    //                 missionTemplate.emailStatus = EmailStatus.UPDATE_TO_DELIVER;\r\n    //             }\r\n    //             missionTemplate.id = mission.id;\r\n    //             await this.missionService.update(missionTemplate);\r\n    //         }),\r\n    //     );\r\n    // }\r\n\r\n    async onMissionInput(mission: Mission) {\r\n        if (mission) {\r\n            this.missionInput = mission;\r\n            await this.userService.createOrUpdateMissionForOrgWithProperty(\r\n                this.missionInput as Mission,\r\n                this.missionInput.organisationID,\r\n            );\r\n            this.added.emit(true);\r\n        } else {\r\n            this.added.emit(false);\r\n        }\r\n    }\r\n\r\n    isFormError(control) {\r\n        return control && control.invalid && this.errorForm;\r\n    }\r\n\r\n\r\n    onFormChange() {\r\n        if (this.errorForm && this.form.valid) {\r\n            this.errorForm = false;\r\n        }\r\n\r\n    }\r\n}\r\n","<div *ngIf=\"form\">\r\n    <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\">\r\n        <div id=\"personalInfo\">\r\n            <div style=\"margin-top: 1rem;\">\r\n                <h4>{{ 'User Personal Information' | translate }}</h4>\r\n            </div>\r\n            <div class=\"form-group row\">\r\n                <label class=\"col-sm-4 col-form-label\">{{'Email' | translate}} *</label>\r\n                <div class=\"col-sm-8\">\r\n                    <input type=\"text\" class=\"form-control\" data-testid=\"new-user-email\"\r\n                        [ngClass]=\"{'is-invalid' : validatorsService.isControlError(form.controls['email'])||  isFormError(form.controls['email'])}\"\r\n                        required formControlName=\"email\">\r\n                    <div class=\"invalid-feedback\">\r\n                        <ngb-alert data-testid=\"new-user-email-invalid\" [dismissible]=\"false\" type=\"danger\" *ngIf=\"validatorsService.isControlError(form.controls['email']) \r\n                                ||  isFormError(form.controls['email'])\">\r\n                            {{validatorsService.getError(form.controls['email']) | translate}}\r\n                        </ngb-alert>\r\n\r\n                    </div>\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"form-group row\">\r\n                <label class=\"col-sm-4 col-form-label\">{{'Last name' | translate}}</label>\r\n                <div class=\"col-sm-8\">\r\n                    <input type=\"text\" class=\"form-control\" formControlName=\"lastName\" data-testid=\"new-user-lastName\"\r\n                    [ngClass]=\"{'is-invalid' : validatorsService.isControlError(form.controls['lastName'])||  isFormError(form.controls['lastName'])}\">\r\n                    <div class=\"invalid-feedback\">\r\n                        <ngb-alert data-testid=\"new-user-lastName-invalid\" [dismissible]=\"false\" type=\"danger\" *ngIf=\"validatorsService.isControlError(form.controls['lastName']) \r\n                                ||  isFormError(form.controls['lastName'])\">\r\n                            {{validatorsService.getError(form.controls['lastName']) | translate}}\r\n                        </ngb-alert>\r\n\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\">{{'First name' | translate}}</label>\r\n                <div class=\"col-sm-8\">\r\n                    <input type=\"text\" class=\"form-control\" formControlName=\"firstName\" data-testid=\"new-user-firstName\"\r\n                    [ngClass]=\"{'is-invalid' : validatorsService.isControlError(form.controls['firstName'])||  isFormError(form.controls['firstName'])}\">\r\n                    <div class=\"invalid-feedback\">\r\n                        <ngb-alert data-testid=\"new-user-firstName-invalid\" [dismissible]=\"false\" type=\"danger\" *ngIf=\"validatorsService.isControlError(form.controls['firstName']) \r\n                                ||  isFormError(form.controls['firstName'])\">\r\n                            {{validatorsService.getError(form.controls['firstName']) | translate}}\r\n                        </ngb-alert>\r\n\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div class=\"d-flex justify-content-center\" *ngIf=\"working\">\r\n            <lib-loader></lib-loader>\r\n        </div>\r\n\r\n        <div *ngIf=\"createdUser; else waitingForUser\">\r\n            <div class=\"alert alert-info\">\r\n                {{'User successfully created' | translate}}\r\n            </div>\r\n            <lib-form-mission [organisationForMission]=\"addToOrganisation\" [userForMissionID]=\"createdUser.id\"\r\n                [currentUserOrganisation]=\"currentOrg\" [isSP]=\"isSP\" (addedMissionInput)=\"onMissionInput($event)\">\r\n            </lib-form-mission>\r\n        </div>\r\n        <ng-template #waitingForUser>\r\n            <div class=\"action-button-container\">\r\n                <button data-testid=\"new-user-submit-btn\" type=\"submit\" class=\"btn btn-outline-primary rounded-pill mr-3 action-button\"\r\n                    [disabled]=\"working\">{{'Create user' | translate}}</button>\r\n                <button data-testid=\"new-user-cancel-btn\" type=\"button\" (click)=\"onCancel()\" [disabled]=\"working\"\r\n                    class=\"btn btn-outline-primary rounded-pill action-button\">{{'Cancel' | translate}}</button>\r\n            </div>\r\n            <div class=\"invalid-feedback\" *ngIf=\"errorForm\">\r\n                <ngb-alert data-testid=\"new-user-form-invalid\" [dismissible]=\"false\" type=\"danger\">\r\n                    {{'errorForm.infoBtn' |translate}}\r\n                </ngb-alert>\r\n            </div>\r\n            <div style=\"margin-top: 1rem;\">\r\n                <h4>{{ 'Mission details' | translate }}</h4>\r\n            </div>\r\n            <ngb-alert type=\"warning\" [dismissible]=\"false\">{{'Please create a user first' | translate}}.</ngb-alert>\r\n\r\n        </ng-template>\r\n    </form>\r\n</div>"]}