awf-test-lib 0.0.99 → 0.1.0

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.
@@ -29,6 +29,12 @@ export class ContactComponent {
29
29
  this.selectPM(this.selectedSystem);
30
30
  this.loadForm();
31
31
  console.log('changed');
32
+ this.systems = this.systems.map((system) => {
33
+ return {
34
+ ...system,
35
+ name: system.systemId + ' - ' + system.name,
36
+ };
37
+ });
32
38
  }
33
39
  // convenience getter for easy access to form fields
34
40
  get f() {
@@ -136,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
136
142
  }], sendForm: [{
137
143
  type: Output
138
144
  }] } });
139
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contact.component.js","sourceRoot":"","sources":["../../../../../../projects/awf-test-lib/src/lib/shared/contact/contact.component.ts","../../../../../../projects/awf-test-lib/src/lib/shared/contact/contact.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Output, OnChanges, Input, EventEmitter } from '@angular/core';\r\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\r\nimport { MessageService } from 'primeng/api';\r\nimport { DetailedPmJob } from '../../models/detailedPmJob.model';\r\nimport { EventStatus } from '../../models/eventStatus';\r\nimport { PmJob } from '../../models/pmJob.model';\r\nimport { PmJobStatus } from '../../models/pmJobStatus';\r\nimport { Reason } from '../../models/reason.model';\r\nimport { ReasonCode } from '../../models/reasonCode';\r\nimport { ReasonContact } from '../../models/reasonContact';\r\nimport { System } from '../../models/system';\r\n@Component({\r\n  selector: 'awf-contact',\r\n  templateUrl: './contact.component.html',\r\n  styleUrls: ['./contact.component.css'],\r\n  providers: [MessageService],\r\n})\r\nexport class ContactComponent implements OnChanges {\r\n\r\n  @Input() loading = false;\r\n  @Input() submitted = false;\r\n  @Input() systems: System[] = [];\r\n  @Input() selectedSystems: System[] = [];\r\n  @Input() translate!:any;\r\n  @Input() reasons!: Reason[];\r\n  @Output() sendForm: EventEmitter<any> = new EventEmitter();\r\n  form!: FormGroup;\r\n  selectedReason!: any;\r\n  selectedSystem!: System;\r\n  selectedPm!: any;\r\n  pmJobs!:PmJob[];\r\n  systemContainPm = true ;\r\n\r\n  showPm = false ;\r\n  constructor(\r\n      private formBuilder: FormBuilder,\r\n      private messageService: MessageService,\r\n  ) {}\r\n\r\n  ngOnChanges(): void {\r\n    this.reasons = this.reasons.filter(x=> (x.code== ReasonCode.SDI|| x.code== ReasonCode.OTH ));\r\n    this.selectPM(this.selectedSystem)  \r\n    this.loadForm();\r\n    console.log('changed')\r\n  }\r\n\r\n  // convenience getter for easy access to form fields\r\n  get f() {\r\n      return this.form.controls;\r\n  }\r\n\r\n  preventStringKeypress(event: any): void {\r\n      if (\r\n          isNaN(Number(String.fromCharCode(event.charCode))) ||\r\n    String.fromCharCode(event.charCode) === ' '\r\n      ) {\r\n          event.preventDefault();\r\n      }\r\n  }\r\n\r\n  onSubmit() {\r\n    this.submitted = true;\r\n\r\n    if (this.form.invalid) {\r\n        this.messageService.add({\r\n            severity: 'error',\r\n            summary: 'Error',\r\n            detail: 'The form is invalid',\r\n        });\r\n        return;\r\n    }\r\n\r\n    console.log(this.form.value.pms)\r\n    let detailedPmJob = { } as DetailedPmJob ;\r\n    detailedPmJob.name = this.form.value.name;\r\n    detailedPmJob.phone = this.form.value.phone;\r\n    detailedPmJob.email = this.form.value.email;\r\n    detailedPmJob.reason = this.form.value.reason.name;\r\n    detailedPmJob.comment = this.form.value.message;\r\n    if( this.form.value.pms !== undefined){\r\n      detailedPmJob.pmJob = this.form.value.pms;\r\n    }\r\n    detailedPmJob.systemName = this.selectedSystem.name ;\r\n    detailedPmJob.systemId = this.selectedSystem.systemId ;\r\n    detailedPmJob.siteName = this.selectedSystem.siteName ;\r\n    detailedPmJob.siteCity = this.selectedSystem.siteCity ;\r\n    detailedPmJob.sitePostalCode =this.selectedSystem.sitePostalCode\r\n    detailedPmJob.toUpdate = true ;\r\n    if( this.form.value.pms !== undefined)\r\n    {\r\n  detailedPmJob.selectedDate = detailedPmJob.pmJob.startDateTime ;\r\n\r\n}\r\n    detailedPmJob.reasonContact = ReasonContact.Contact ;\r\n    detailedPmJob.futureStatus = this.slectsFutureStatus(this.form.value.reason.code) \r\n    console.log() \r\n    this.sendForm.emit(detailedPmJob);\r\n  }\r\n\r\n  slectsFutureStatus(status:any)\r\n  {\r\n      switch (status) {\r\n          case ReasonCode.MPM : return PmJobStatus.WAITING;\r\n          case ReasonCode.RPM : return PmJobStatus.REPORTED;\r\n          case ReasonCode.CPM : return PmJobStatus.CANCELLED;\r\n          case ReasonCode.SDI : return PmJobStatus.DESINSTALLED;\r\n          case ReasonCode.OTH: return PmJobStatus.OTHER;\r\n          default : return \"Erreur\";\r\n      }\r\n  } \r\n\r\n \r\n  loadForm() {\r\n    let name = sessionStorage.getItem('userName') as string  ;\r\n    let email = sessionStorage.getItem('email') as string;\r\n    let phone = sessionStorage.getItem('mobilePhoneNumber') as string;\r\n      this.form = this.formBuilder.group({\r\n        name: [  name !== 'null' ? name : '' , [Validators.required, Validators.minLength(3)]],\r\n        email: [ email!== 'null' ? email  : '', [Validators.required, Validators.email]],\r\n        phone: [ phone!== 'null' ? phone  : '', [Validators.required]],\r\n        reason: ['' , [Validators.required]],\r\n        systems: [[], [Validators.required]],\r\n        pms: [[], this.showPm ? [] :[]],\r\n        message: ['', [Validators.required, Validators.minLength(15)]],\r\n      });\r\n  }\r\n\r\n\r\n  selectPM(selectedSystem:any)\r\n  {\r\n    console.log(selectedSystem)\r\n    this.systemContainPm = true ;\r\n    if(selectedSystem === undefined )\r\n    {\r\n      return;\r\n    }\r\n    else\r\n    {\r\n\r\n\r\n      if(selectedSystem.pmJobs.length  === 0 )\r\n      {\r\n        this.showPm = false ;\r\n      }\r\n      else\r\n      {\r\n        this.selectedSystem = selectedSystem;\r\n        this.pmJobs = selectedSystem.pmJobs;\r\n        this.showPm = true ;\r\n\r\n      }\r\n      \r\n      \r\n      \r\n    }\r\n  }\r\n\r\n\r\n}\r\n\r\n","<div *ngIf=\"translate && reasons \">\r\n    <section class=\"pt-0\">\r\n        <div class=\"app-section-header-img\">\r\n            <div class=\"container pt-4\">\r\n                <div class=\"\">\r\n                    <h2>{{translate.title}} </h2>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </section>\r\n    <section class=\"py-5 background-light\">\r\n        <div class=\"container px-lg-5\">\r\n            <div class=\"row align-items-center\">\r\n                <div class=\"col-md-6\">\r\n                    <div class=\"container-contact100\">\r\n                        <div class=\"wrap-contact100\">\r\n                            <form [formGroup]=\"form\" *ngIf=\"form && systems && reasons\" class=\"contact100-form validate-form\">\r\n                                <span class=\"contact100-form-title\">{{translate.title}} </span>\r\n                                <div class=\"p-grid p-fluid p-mt-2\">\r\n                                    <div class=\"p-col-12 p-md-12 \">\r\n                                        <span class=\"titre\">{{translate.placeholderName}}</span> <span class=\"requis\">* </span>:\r\n                                        <input [placeholder]=\"translate.placeholderName\" type=\"text\" pInputText formControlName=\"name\" [ngClass]=\"{ 'is-invalid': submitted && f.name.invalid }\">\r\n                                        <div *ngIf=\"submitted && f.name.errors\">\r\n                                            <div class=\"requis\" *ngIf=\"f.name.errors.required\">{{translate.requiredName}}</div>\r\n                                            <div class=\"requis\" *ngIf=\"f.name.errors.minlength\">{{translate.requiredNameMin}}</div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"p-grid p-fluid p-mt-2\">\r\n                                    <div class=\"p-col-12 p-md-12 \">\r\n                                        <span class=\"titre\">{{translate.placeholderEmail}}</span> <span class=\"requis\">*</span>:\r\n                                        <input [placeholder]=\"translate.placeholderEmail\" type=\"text\" pInputText formControlName=\"email\" [ngClass]=\"{ 'is-invalid': submitted && f.email.invalid }\">\r\n                                        <div *ngIf=\"submitted && f.email.errors\">\r\n                                            <div class=\"requis\" *ngIf=\"f.email.errors.required\">{{translate.requiredEmail}}</div>\r\n                                            <div class=\"requis\" *ngIf=\"f.email.errors.email\">{{translate.requiredEmailFormat}}</div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"p-grid p-fluid p-mt-2\">\r\n                                    <div class=\"p-col-12 p-md-12 \">\r\n                                        <span class=\"titre\">{{translate.placeholderPhone}}</span> <span class=\"requis\">*</span>:\r\n                                        <input [placeholder]=\"translate.placeholderPhone\" type=\"text\" pInputText formControlName=\"phone\" [ngClass]=\"{ 'is-invalid': submitted && f.phone.invalid }\" (keypress)=\"preventStringKeypress($event)\">\r\n                                        <div *ngIf=\"submitted && f.phone.errors\">\r\n                                            <div class=\"requis\" *ngIf=\"f.phone.errors.required\">{{translate.requiredPhone}}</div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"p-grid p-fluid p-mt-2\">\r\n                                    <div class=\"p-col-12 p-md-12 \">\r\n                                        <span class=\"titre\">{{translate.RelatedSystems}}</span> <span class=\"requis\">*</span>:\r\n                                        <p-dropdown (click)=\"selectPM(selectedSystem)\" [options]=\"systems\" [placeholder]=\"translate.selectSystem\" [(ngModel)]=\"selectedSystem\" [optionLabel]=\"'systemId - name'\" formControlName=\"systems\"  optionDisabled=\"inactive\" [ngClass]=\"{ 'is-invalid': submitted && f.systems.invalid }\"></p-dropdown>                                        \r\n                                      \r\n                                        <div *ngIf=\"submitted && f.systems.errors\">\r\n                                            <div class=\"requis\" *ngIf=\"f.systems.errors.required\">{{translate.requiredSystem}}</div>\r\n                                        </div>\r\n                                    </div>\r\n\r\n                                </div>\r\n                                <div class=\"p-grid p-fluid p-mt-2\" *ngIf=\"showPm\">\r\n                                    <div class=\"p-col-12 p-md-12 \">\r\n                                        <span class=\"titre\">{{translate.RelatedPMs}}</span>:\r\n                                        <p-dropdown  [options]=\"pmJobs\" [placeholder]=\"translate.selectPM\" [(ngModel)]=\"selectedPm\" [optionLabel]=\"'workorderNumber'\" formControlName=\"pms\"  optionDisabled=\"inactive\" [ngClass]=\"{ 'is-invalid': submitted && f.pms.invalid }\"></p-dropdown>                                        \r\n                                       <!-- <div *ngIf=\"submitted && f.pms.errors\">\r\n                                            <div class=\"requis\" *ngIf=\"f.pms.errors.required\">{{translate.requiredPM }}</div>\r\n                                        </div>-->\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"p-grid p-fluid p-mt-2\">\r\n                                    <div class=\"p-col-12 p-md-12 \">\r\n                                        <span class=\"titre\">{{translate.reason}}</span> <span class=\"requis\">*</span>:\r\n                                        <p-dropdown [options]=\"reasons\" [placeholder]=\"translate.selectReason\" [(ngModel)]=\"selectedReason\" optionLabel=\"name\" formControlName=\"reason\"  optionDisabled=\"inactive\" [ngClass]=\"{ 'is-invalid': submitted && f.reason.invalid }\"></p-dropdown>\r\n                                        <!-- <input [placeholder]=\"translate.reason\" type=\"text\" pInputText formControlName=\"reason\" [ngClass]=\"{ 'is-invalid': submitted && f.reason.invalid }\"> -->\r\n                                        <div *ngIf=\"submitted && f.reason.errors\">\r\n                                            <div class=\"requis\" *ngIf=\"f.reason.errors.required\">{{translate.reasonRequired}}</div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"p-grid p-fluid p-mt-2\">\r\n                                    <div class=\"p-col-12 p-md-12 \">\r\n                                        <span class=\"titre\">{{translate.placeholderMessage}} </span> <span class=\"requis\">*</span>:\r\n                                        <textarea pInputTextarea style=\" min-height:100px;height:100%;width:100%;\" [placeholder]=\"translate.placeholderMessage +'...'\" formControlName=\"message\" [ngClass]=\"{ 'is-invalid': submitted && f.message.errors }\"></textarea>\r\n                                        <div *ngIf=\"submitted && f.message.errors\">\r\n                                            <div class=\"requis\" *ngIf=\"f.message.errors.required\">{{translate.requiredMessage}}</div>\r\n                                            <div class=\"requis\" *ngIf=\"f.message.errors.minlength\">{{translate.requiredMessageMin}}</div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                                <br>\r\n                                <br>\r\n                                <div class=\"container-contact100-form-btn\">\r\n                                    <div class=\"wrap-contact100-form-btn\">\r\n                                        <div class=\"contact100-form-bgbtn\"></div>\r\n                                        <button class=\"btn-warranty mt-3\" (click)=\"onSubmit()\">\r\n                                      {{translate.send}}\r\n                                </button>\r\n                                    </div>\r\n                                </div>\r\n                            </form>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                <div class=\"col-md-6 contact\">\r\n                    <iframe src=\"https://maps.google.com/maps?q=283,%20Rue%20De%20la%20Miniere-BP34%20%2078533%20BUC%20%E2%80%93%20Cedex&amp;t=&amp;z=13&amp;ie=UTF8&amp;iwloc=&amp;output=embed\" width=\"100%\" height=\"250\" style=\"border:0;\" allowfullscreen=\"\" loading=\"lazy\"></iframe>\r\n                    <h6 class=\"fs-4 mt-3\"> {{translate.information}}</h6>\r\n                    <section class=\"mb-4\">\r\n                        <div class=\"\">\r\n                            <i class=\"pi pi-envelope\"></i><label> &nbsp; {{translate.emailText}}</label>\r\n                            <p class=\"\">{{translate.email}} </p>\r\n                        </div>\r\n                        <div class=\" mt-4\">\r\n                            <i class=\"pi pi-map\"></i><label> &nbsp; {{translate.addressText}}</label>\r\n                            <p class=\"\">{{translate.adress}}</p>\r\n                            <p class=\"\">{{translate.town}}</p>\r\n                            <p class=\"\">{{translate.country}}</p>\r\n                        </div>\r\n                    </section>\r\n                </div>\r\n\r\n            </div>\r\n        </div>\r\n    </section>\r\n</div>\r\n\r\n<p-toast position=\"top-center\"></p-toast>\r\n"]}
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contact.component.js","sourceRoot":"","sources":["../../../../../../projects/awf-test-lib/src/lib/shared/contact/contact.component.ts","../../../../../../projects/awf-test-lib/src/lib/shared/contact/contact.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Output, OnChanges, Input, EventEmitter } from '@angular/core';\r\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\r\nimport { MessageService } from 'primeng/api';\r\nimport { DetailedPmJob } from '../../models/detailedPmJob.model';\r\nimport { EventStatus } from '../../models/eventStatus';\r\nimport { PmJob } from '../../models/pmJob.model';\r\nimport { PmJobStatus } from '../../models/pmJobStatus';\r\nimport { Reason } from '../../models/reason.model';\r\nimport { ReasonCode } from '../../models/reasonCode';\r\nimport { ReasonContact } from '../../models/reasonContact';\r\nimport { System } from '../../models/system';\r\n@Component({\r\n  selector: 'awf-contact',\r\n  templateUrl: './contact.component.html',\r\n  styleUrls: ['./contact.component.css'],\r\n  providers: [MessageService],\r\n})\r\nexport class ContactComponent implements OnChanges {\r\n\r\n  @Input() loading = false;\r\n  @Input() submitted = false;\r\n  @Input() systems: System[] = [];\r\n  @Input() selectedSystems: System[] = [];\r\n  @Input() translate!:any;\r\n  @Input() reasons!: Reason[];\r\n  @Output() sendForm: EventEmitter<any> = new EventEmitter();\r\n  form!: FormGroup;\r\n  selectedReason!: any;\r\n  selectedSystem!: System;\r\n  selectedPm!: any;\r\n  pmJobs!:PmJob[];\r\n  systemContainPm = true ;\r\n  \r\n  showPm = false ;\r\n  constructor(\r\n      private formBuilder: FormBuilder,\r\n      private messageService: MessageService,\r\n  ) {}\r\n\r\n  ngOnChanges(): void {\r\n    this.reasons = this.reasons.filter(x=> (x.code== ReasonCode.SDI|| x.code== ReasonCode.OTH ));\r\n    this.selectPM(this.selectedSystem)  \r\n    this.loadForm();\r\n    console.log('changed')\r\n    this.systems = this.systems.map((system: any) => {\r\n      return {\r\n        ...system,\r\n        name: system.systemId + ' - ' + system.name,\r\n      };\r\n    });\r\n  }\r\n\r\n  // convenience getter for easy access to form fields\r\n  get f() {\r\n      return this.form.controls;\r\n  }\r\n\r\n  preventStringKeypress(event: any): void {\r\n      if (\r\n          isNaN(Number(String.fromCharCode(event.charCode))) ||\r\n    String.fromCharCode(event.charCode) === ' '\r\n      ) {\r\n          event.preventDefault();\r\n      }\r\n  }\r\n\r\n  onSubmit() {\r\n    this.submitted = true;\r\n\r\n    if (this.form.invalid) {\r\n        this.messageService.add({\r\n            severity: 'error',\r\n            summary: 'Error',\r\n            detail: 'The form is invalid',\r\n        });\r\n        return;\r\n    }\r\n\r\n    console.log(this.form.value.pms)\r\n    let detailedPmJob = { } as DetailedPmJob ;\r\n    detailedPmJob.name = this.form.value.name;\r\n    detailedPmJob.phone = this.form.value.phone;\r\n    detailedPmJob.email = this.form.value.email;\r\n    detailedPmJob.reason = this.form.value.reason.name;\r\n    detailedPmJob.comment = this.form.value.message;\r\n    if( this.form.value.pms !== undefined){\r\n      detailedPmJob.pmJob = this.form.value.pms;\r\n    }\r\n    detailedPmJob.systemName = this.selectedSystem.name ;\r\n    detailedPmJob.systemId = this.selectedSystem.systemId ;\r\n    detailedPmJob.siteName = this.selectedSystem.siteName ;\r\n    detailedPmJob.siteCity = this.selectedSystem.siteCity ;\r\n    detailedPmJob.sitePostalCode =this.selectedSystem.sitePostalCode\r\n    detailedPmJob.toUpdate = true ;\r\n    if( this.form.value.pms !== undefined)\r\n    {\r\n  detailedPmJob.selectedDate = detailedPmJob.pmJob.startDateTime ;\r\n\r\n}\r\n    detailedPmJob.reasonContact = ReasonContact.Contact ;\r\n    detailedPmJob.futureStatus = this.slectsFutureStatus(this.form.value.reason.code) \r\n    console.log() \r\n    this.sendForm.emit(detailedPmJob);\r\n  }\r\n\r\n  slectsFutureStatus(status:any)\r\n  {\r\n      switch (status) {\r\n          case ReasonCode.MPM : return PmJobStatus.WAITING;\r\n          case ReasonCode.RPM : return PmJobStatus.REPORTED;\r\n          case ReasonCode.CPM : return PmJobStatus.CANCELLED;\r\n          case ReasonCode.SDI : return PmJobStatus.DESINSTALLED;\r\n          case ReasonCode.OTH: return PmJobStatus.OTHER;\r\n          default : return \"Erreur\";\r\n      }\r\n  } \r\n\r\n \r\n  loadForm() {\r\n    let name = sessionStorage.getItem('userName') as string  ;\r\n    let email = sessionStorage.getItem('email') as string;\r\n    let phone = sessionStorage.getItem('mobilePhoneNumber') as string;\r\n      this.form = this.formBuilder.group({\r\n        name: [  name !== 'null' ? name : '' , [Validators.required, Validators.minLength(3)]],\r\n        email: [ email!== 'null' ? email  : '', [Validators.required, Validators.email]],\r\n        phone: [ phone!== 'null' ? phone  : '', [Validators.required]],\r\n        reason: ['' , [Validators.required]],\r\n        systems: [[], [Validators.required]],\r\n        pms: [[], this.showPm ? [] :[]],\r\n        message: ['', [Validators.required, Validators.minLength(15)]],\r\n      });\r\n  }\r\n\r\n\r\n  selectPM(selectedSystem:any)\r\n  {\r\n    console.log(selectedSystem)\r\n    this.systemContainPm = true ;\r\n    if(selectedSystem === undefined )\r\n    {\r\n      return;\r\n    }\r\n    else\r\n    {\r\n\r\n\r\n      if(selectedSystem.pmJobs.length  === 0 )\r\n      {\r\n        this.showPm = false ;\r\n      }\r\n      else\r\n      {\r\n        this.selectedSystem = selectedSystem;\r\n        this.pmJobs = selectedSystem.pmJobs;\r\n        this.showPm = true ;\r\n\r\n      }\r\n      \r\n      \r\n      \r\n    }\r\n  }\r\n\r\n\r\n}\r\n\r\n","<div *ngIf=\"translate && reasons \">\r\n    <section class=\"pt-0\">\r\n        <div class=\"app-section-header-img\">\r\n            <div class=\"container pt-4\">\r\n                <div class=\"\">\r\n                    <h2>{{translate.title}} </h2>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </section>\r\n    <section class=\"py-5 background-light\">\r\n        <div class=\"container px-lg-5\">\r\n            <div class=\"row align-items-center\">\r\n                <div class=\"col-md-6\">\r\n                    <div class=\"container-contact100\">\r\n                        <div class=\"wrap-contact100\">\r\n                            <form [formGroup]=\"form\" *ngIf=\"form && systems && reasons\" class=\"contact100-form validate-form\">\r\n                                <span class=\"contact100-form-title\">{{translate.title}} </span>\r\n                                <div class=\"p-grid p-fluid p-mt-2\">\r\n                                    <div class=\"p-col-12 p-md-12 \">\r\n                                        <span class=\"titre\">{{translate.placeholderName}}</span> <span class=\"requis\">* </span>:\r\n                                        <input [placeholder]=\"translate.placeholderName\" type=\"text\" pInputText formControlName=\"name\" [ngClass]=\"{ 'is-invalid': submitted && f.name.invalid }\">\r\n                                        <div *ngIf=\"submitted && f.name.errors\">\r\n                                            <div class=\"requis\" *ngIf=\"f.name.errors.required\">{{translate.requiredName}}</div>\r\n                                            <div class=\"requis\" *ngIf=\"f.name.errors.minlength\">{{translate.requiredNameMin}}</div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"p-grid p-fluid p-mt-2\">\r\n                                    <div class=\"p-col-12 p-md-12 \">\r\n                                        <span class=\"titre\">{{translate.placeholderEmail}}</span> <span class=\"requis\">*</span>:\r\n                                        <input [placeholder]=\"translate.placeholderEmail\" type=\"text\" pInputText formControlName=\"email\" [ngClass]=\"{ 'is-invalid': submitted && f.email.invalid }\">\r\n                                        <div *ngIf=\"submitted && f.email.errors\">\r\n                                            <div class=\"requis\" *ngIf=\"f.email.errors.required\">{{translate.requiredEmail}}</div>\r\n                                            <div class=\"requis\" *ngIf=\"f.email.errors.email\">{{translate.requiredEmailFormat}}</div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"p-grid p-fluid p-mt-2\">\r\n                                    <div class=\"p-col-12 p-md-12 \">\r\n                                        <span class=\"titre\">{{translate.placeholderPhone}}</span> <span class=\"requis\">*</span>:\r\n                                        <input [placeholder]=\"translate.placeholderPhone\" type=\"text\" pInputText formControlName=\"phone\" [ngClass]=\"{ 'is-invalid': submitted && f.phone.invalid }\" (keypress)=\"preventStringKeypress($event)\">\r\n                                        <div *ngIf=\"submitted && f.phone.errors\">\r\n                                            <div class=\"requis\" *ngIf=\"f.phone.errors.required\">{{translate.requiredPhone}}</div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"p-grid p-fluid p-mt-2\">\r\n                                    <div class=\"p-col-12 p-md-12 \">\r\n                                        <span class=\"titre\">{{translate.RelatedSystems}}</span> <span class=\"requis\">*</span>:\r\n                                        <p-dropdown (click)=\"selectPM(selectedSystem)\" [options]=\"systems\" [placeholder]=\"translate.selectSystem\" [(ngModel)]=\"selectedSystem\" [optionLabel]=\"'systemId - name'\" formControlName=\"systems\"  optionDisabled=\"inactive\" [ngClass]=\"{ 'is-invalid': submitted && f.systems.invalid }\"></p-dropdown>                                        \r\n                                      \r\n                                        <div *ngIf=\"submitted && f.systems.errors\">\r\n                                            <div class=\"requis\" *ngIf=\"f.systems.errors.required\">{{translate.requiredSystem}}</div>\r\n                                        </div>\r\n                                    </div>\r\n\r\n                                </div>\r\n                                <div class=\"p-grid p-fluid p-mt-2\" *ngIf=\"showPm\">\r\n                                    <div class=\"p-col-12 p-md-12 \">\r\n                                        <span class=\"titre\">{{translate.RelatedPMs}}</span>:\r\n                                        <p-dropdown  [options]=\"pmJobs\" [placeholder]=\"translate.selectPM\" [(ngModel)]=\"selectedPm\" [optionLabel]=\"'workorderNumber'\" formControlName=\"pms\"  optionDisabled=\"inactive\" [ngClass]=\"{ 'is-invalid': submitted && f.pms.invalid }\"></p-dropdown>                                        \r\n                                       <!-- <div *ngIf=\"submitted && f.pms.errors\">\r\n                                            <div class=\"requis\" *ngIf=\"f.pms.errors.required\">{{translate.requiredPM }}</div>\r\n                                        </div>-->\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"p-grid p-fluid p-mt-2\">\r\n                                    <div class=\"p-col-12 p-md-12 \">\r\n                                        <span class=\"titre\">{{translate.reason}}</span> <span class=\"requis\">*</span>:\r\n                                        <p-dropdown [options]=\"reasons\" [placeholder]=\"translate.selectReason\" [(ngModel)]=\"selectedReason\" optionLabel=\"name\" formControlName=\"reason\"  optionDisabled=\"inactive\" [ngClass]=\"{ 'is-invalid': submitted && f.reason.invalid }\"></p-dropdown>\r\n                                        <!-- <input [placeholder]=\"translate.reason\" type=\"text\" pInputText formControlName=\"reason\" [ngClass]=\"{ 'is-invalid': submitted && f.reason.invalid }\"> -->\r\n                                        <div *ngIf=\"submitted && f.reason.errors\">\r\n                                            <div class=\"requis\" *ngIf=\"f.reason.errors.required\">{{translate.reasonRequired}}</div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"p-grid p-fluid p-mt-2\">\r\n                                    <div class=\"p-col-12 p-md-12 \">\r\n                                        <span class=\"titre\">{{translate.placeholderMessage}} </span> <span class=\"requis\">*</span>:\r\n                                        <textarea pInputTextarea style=\" min-height:100px;height:100%;width:100%;\" [placeholder]=\"translate.placeholderMessage +'...'\" formControlName=\"message\" [ngClass]=\"{ 'is-invalid': submitted && f.message.errors }\"></textarea>\r\n                                        <div *ngIf=\"submitted && f.message.errors\">\r\n                                            <div class=\"requis\" *ngIf=\"f.message.errors.required\">{{translate.requiredMessage}}</div>\r\n                                            <div class=\"requis\" *ngIf=\"f.message.errors.minlength\">{{translate.requiredMessageMin}}</div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                                <br>\r\n                                <br>\r\n                                <div class=\"container-contact100-form-btn\">\r\n                                    <div class=\"wrap-contact100-form-btn\">\r\n                                        <div class=\"contact100-form-bgbtn\"></div>\r\n                                        <button class=\"btn-warranty mt-3\" (click)=\"onSubmit()\">\r\n                                      {{translate.send}}\r\n                                </button>\r\n                                    </div>\r\n                                </div>\r\n                            </form>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                <div class=\"col-md-6 contact\">\r\n                    <iframe src=\"https://maps.google.com/maps?q=283,%20Rue%20De%20la%20Miniere-BP34%20%2078533%20BUC%20%E2%80%93%20Cedex&amp;t=&amp;z=13&amp;ie=UTF8&amp;iwloc=&amp;output=embed\" width=\"100%\" height=\"250\" style=\"border:0;\" allowfullscreen=\"\" loading=\"lazy\"></iframe>\r\n                    <h6 class=\"fs-4 mt-3\"> {{translate.information}}</h6>\r\n                    <section class=\"mb-4\">\r\n                        <div class=\"\">\r\n                            <i class=\"pi pi-envelope\"></i><label> &nbsp; {{translate.emailText}}</label>\r\n                            <p class=\"\">{{translate.email}} </p>\r\n                        </div>\r\n                        <div class=\" mt-4\">\r\n                            <i class=\"pi pi-map\"></i><label> &nbsp; {{translate.addressText}}</label>\r\n                            <p class=\"\">{{translate.adress}}</p>\r\n                            <p class=\"\">{{translate.town}}</p>\r\n                            <p class=\"\">{{translate.country}}</p>\r\n                        </div>\r\n                    </section>\r\n                </div>\r\n\r\n            </div>\r\n        </div>\r\n    </section>\r\n</div>\r\n\r\n<p-toast position=\"top-center\"></p-toast>\r\n"]}
@@ -388,6 +388,9 @@ class ContactComponent {
388
388
  this.selectPM(this.selectedSystem);
389
389
  this.loadForm();
390
390
  console.log('changed');
391
+ this.systems = this.systems.map((system) => {
392
+ return Object.assign(Object.assign({}, system), { name: system.systemId + ' - ' + system.name });
393
+ });
391
394
  }
392
395
  // convenience getter for easy access to form fields
393
396
  get f() {