@smarterplan/ngx-smarterplan-core 0.3.13 → 0.3.14
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.
- package/esm2020/lib/components/support-modal/support-modal.component.mjs +5 -4
- package/esm2020/lib/services/validators.service.mjs +8 -5
- package/esm2020/lib/validators/text.directive.mjs +7 -0
- package/fesm2015/smarterplan-ngx-smarterplan-core.mjs +17 -7
- package/fesm2015/smarterplan-ngx-smarterplan-core.mjs.map +1 -1
- package/fesm2020/smarterplan-ngx-smarterplan-core.mjs +17 -7
- package/fesm2020/smarterplan-ngx-smarterplan-core.mjs.map +1 -1
- package/lib/services/validators.service.d.ts +1 -1
- package/lib/validators/text.directive.d.ts +2 -0
- package/package.json +1 -1
|
@@ -3,6 +3,7 @@ import { Validators } from "@angular/forms";
|
|
|
3
3
|
import { Auth } from "aws-amplify";
|
|
4
4
|
import { noEmptyValidator } from '../../validators/no-empty.directive';
|
|
5
5
|
import { emailValidator } from '../../validators/email.directive';
|
|
6
|
+
import { textValidator } from '../../validators/text.directive';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "../../services/support.service";
|
|
8
9
|
import * as i2 from "@ng-bootstrap/ng-bootstrap";
|
|
@@ -42,9 +43,9 @@ export class SupportModalComponent {
|
|
|
42
43
|
async iniForm() {
|
|
43
44
|
this.currentUser = await this.getCurrentUser();
|
|
44
45
|
this.supportForm = this.formBuilder.group({
|
|
45
|
-
title: ['', [Validators.required, Validators.maxLength(255), noEmptyValidator()]],
|
|
46
|
-
email: [(this.currentUser ? this.currentUser.email : ''), [Validators.required, emailValidator(), Validators.maxLength(255)]],
|
|
47
|
-
description: ['', [Validators.required, noEmptyValidator()]],
|
|
46
|
+
title: ['', [Validators.required, Validators.maxLength(255), noEmptyValidator(), textValidator()]],
|
|
47
|
+
email: [(this.currentUser ? this.currentUser.email : ''), [Validators.required, emailValidator(), Validators.maxLength(255), textValidator()]],
|
|
48
|
+
description: ['', [Validators.required, noEmptyValidator(), textValidator()]],
|
|
48
49
|
});
|
|
49
50
|
this.loading = false;
|
|
50
51
|
}
|
|
@@ -62,4 +63,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImpor
|
|
|
62
63
|
type: Component,
|
|
63
64
|
args: [{ selector: 'app-support-modal', template: "<div class=\"modal-header\">\r\n <h5 class=\"modal-title\" translate=\"Help\"></h5>\r\n</div>\r\n<div class=\"modal-body\">\r\n <div class=\"support-loader-container\">\r\n <lib-loader *ngIf=\"loading\"></lib-loader>\r\n </div>\r\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"supportForm\" style=\"margin-top:1rem;\" *ngIf=\"!loading && status==='new'\">\r\n <div>\r\n <label>{{'Title' | translate}} *</label>\r\n <div>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"title\" data-testid=\"new-support-title\"\r\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(supportForm.controls['title'])}\"\r\n maxlength=\"255\">\r\n </div>\r\n <div class=\"invalid-feedback\">\r\n <span data-testid=\"new-support-title-invalid\" [translate]=\"validatorsService.getError(supportForm.controls['title'])\"\r\n *ngIf=\" validatorsService.isControlError(supportForm.controls['title'])\"></span>\r\n </div>\r\n </div>\r\n <div *ngIf=\"!currentUser\">\r\n <label>{{'Email' | translate}} *</label>\r\n <div>\r\n <input type=\"email\" class=\"form-control\" formControlName=\"email\" data-testid=\"new-support-email\"\r\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(supportForm.controls['email'])}\"\r\n maxlength=\"255\">\r\n </div>\r\n <div class=\"invalid-feedback\">\r\n <span data-testid=\"new-support-email-invalid\" [translate]=\"validatorsService.getError(supportForm.controls['email'])\"\r\n *ngIf=\" validatorsService.isControlError(supportForm.controls['email'])\"></span>\r\n </div>\r\n </div>\r\n <div>\r\n <label>{{'Description' | translate}} *</label>\r\n <div>\r\n <textarea formControlName=\"description\" class=\"form-control\"\r\n data-testid=\"new-support-description\"\r\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(supportForm.controls['description'])}\"></textarea>\r\n </div>\r\n <div class=\"invalid-feedback\" >\r\n <span data-testid=\"new-support-description-invalid\" [translate]=\" validatorsService.getError(supportForm.controls['description'])\"\r\n *ngIf=\"validatorsService.isControlError(supportForm.controls['description'])\"></span>\r\n </div>\r\n </div>\r\n </form>\r\n\r\n <div *ngIf=\"status ==='send'\" translate=\"Your request has been registered\" data-testid=\"new-support-send-info\">\r\n </div>\r\n <div *ngIf=\"status ==='error'\" translate=\"An error has occurred, please renew your request\"\r\n data-testid=\"new-support-error-info\">\r\n\r\n </div>\r\n</div>\r\n<div class=\"modal-footer\">\r\n <button type=\"button\" class=\"btn rounded-pill btn-museum\" data-dismiss=\"modal\" translate=\"Close\" (click)=\"onClose()\"\r\n data-testid=\"new-support-close-btn\"></button>\r\n <button *ngIf=\"!loading && status==='new'\" type=\"button\" class=\"btn rounded-pill btn-museum\" translate=\"Submit\"\r\n (click)=\"onSubmit()\" [disabled]=\"!supportForm.valid\" data-testid=\"new-support-submit-btn\"></button>\r\n</div>", styles: [".support-loader-container{width:88px;margin:auto}.invalid-feedback{height:16px}\n"] }]
|
|
64
65
|
}], ctorParameters: function () { return [{ type: i1.SupportService }, { type: i2.NgbActiveModal }, { type: i3.FormBuilder }, { type: i4.BaseUserService }, { type: i5.ValidatorsService }]; } });
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"support-modal.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-smarterplan-core/src/lib/components/support-modal/support-modal.component.ts","../../../../../../projects/ngx-smarterplan-core/src/lib/components/support-modal/support-modal.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,MAAM,eAAe,CAAC;AAElD,OAAO,EAA0B,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAEpE,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAEnC,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AAEvE,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;;;;;;;;;;AAOlE,MAAM,OAAO,qBAAqB;IAShC,YACU,cAA8B,EAC/B,WAA2B,EAC1B,WAAwB,EACxB,WAA4B,EAC7B,iBAAqC;QAJpC,mBAAc,GAAd,cAAc,CAAgB;QAC/B,gBAAW,GAAX,WAAW,CAAgB;QAC1B,gBAAW,GAAX,WAAW,CAAa;QACxB,gBAAW,GAAX,WAAW,CAAiB;QAC7B,sBAAiB,GAAjB,iBAAiB,CAAoB;QAb9C,WAAM,GAAG,KAAK,CAAC;QAMf,YAAO,GAAY,IAAI,CAAC;IAQpB,CAAC;IAEL,QAAQ;QACN,IAAI,CAAC,OAAO,EAAE,CAAC;IACjB,CAAC;IAED,OAAO;QACL,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;IAED,KAAK,CAAC,cAAc;QAClB,OAAO,IAAI,OAAO,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;YACnC,IAAI;gBACF,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,wBAAwB,EAAE,CAAC;gBAClD,OAAO,CAAC,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;aAC9C;YAAC,OAAO,KAAK,EAAE;gBACd,OAAO,CAAC,SAAS,CAAC,CAAC;aACpB;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,KAAK,CAAC,OAAO;QACX,IAAI,CAAC,WAAW,GAAG,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;QAC/C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;YACxC,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAG,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,gBAAgB,EAAE,CAAC,CAAC;YAClF,KAAK,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,cAAc,EAAE,EAAG,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;YAC9H,WAAW,EAAE,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,gBAAgB,EAAE,CAAC,CAAC;SAC7D,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,KAAK,CAAC,QAAQ;QACZ,IAAG,IAAI,CAAC,WAAW,CAAC,KAAK,EAAC;YACxB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,MAAM,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YAC5E,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;SACtB;IACH,CAAC;;kHApDU,qBAAqB;sGAArB,qBAAqB,yDCflC,m3GA0DM;2FD3CO,qBAAqB;kBALjC,SAAS;+BACE,mBAAmB","sourcesContent":["import { Component, OnInit } from '@angular/core';\r\nimport { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap';\r\nimport { FormBuilder, FormGroup, Validators } from \"@angular/forms\";\r\nimport { BaseUserService } from '../../services/user.service';\r\nimport { Auth } from \"aws-amplify\";\r\nimport { SupportService } from '../../services/support.service';\r\nimport { noEmptyValidator } from '../../validators/no-empty.directive';\r\nimport { ValidatorsService } from '../../services/validators.service';\r\nimport { emailValidator } from '../../validators/email.directive';\r\n\r\n@Component({\r\n  selector: 'app-support-modal',\r\n  templateUrl: './support-modal.component.html',\r\n  styleUrls: ['./support-modal.component.scss']\r\n})\r\nexport class SupportModalComponent implements OnInit {\r\n  status = 'new';\r\n\r\n  supportForm: FormGroup;\r\n\r\n  currentUser: any;\r\n\r\n  loading: boolean = true;\r\n\r\n  constructor(\r\n    private supportService: SupportService,\r\n    public activeModal: NgbActiveModal,\r\n    private formBuilder: FormBuilder,\r\n    private userService: BaseUserService,\r\n    public validatorsService : ValidatorsService\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    this.iniForm();\r\n  }\r\n\r\n  onClose() {\r\n    this.activeModal.close();\r\n  }\r\n\r\n  async getCurrentUser(): Promise<any> {\r\n    return new Promise(async (resolve) => {\r\n      try {\r\n        const cau = await Auth.currentAuthenticatedUser();\r\n        resolve(await this.userService.current(cau));\r\n      } catch (error) {\r\n        resolve(undefined);\r\n      }\r\n    })\r\n  }\r\n\r\n  async iniForm() {\r\n    this.currentUser = await this.getCurrentUser();\r\n    this.supportForm = this.formBuilder.group({\r\n      title: ['', [Validators.required , Validators.maxLength(255), noEmptyValidator()]],\r\n      email: [(this.currentUser ? this.currentUser.email : ''), [Validators.required, emailValidator(),  Validators.maxLength(255)]],\r\n      description: ['', [Validators.required, noEmptyValidator()]],\r\n    });\r\n    this.loading = false;\r\n  }\r\n  \r\n  async onSubmit() {\r\n    if(this.supportForm.valid){\r\n      this.loading = true;\r\n      this.status = await this.supportService.sendSupport(this.supportForm.value);\r\n      this.loading = false;\r\n    }\r\n  }\r\n\r\n}","<div class=\"modal-header\">\r\n    <h5 class=\"modal-title\" translate=\"Help\"></h5>\r\n</div>\r\n<div class=\"modal-body\">\r\n    <div class=\"support-loader-container\">\r\n        <lib-loader *ngIf=\"loading\"></lib-loader>\r\n    </div>\r\n    <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"supportForm\" style=\"margin-top:1rem;\" *ngIf=\"!loading && status==='new'\">\r\n        <div>\r\n            <label>{{'Title' | translate}} *</label>\r\n            <div>\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"title\" data-testid=\"new-support-title\"\r\n                    [ngClass]=\"{'is-invalid' : validatorsService.isControlError(supportForm.controls['title'])}\"\r\n                    maxlength=\"255\">\r\n            </div>\r\n            <div class=\"invalid-feedback\">\r\n                <span data-testid=\"new-support-title-invalid\" [translate]=\"validatorsService.getError(supportForm.controls['title'])\"\r\n                    *ngIf=\" validatorsService.isControlError(supportForm.controls['title'])\"></span>\r\n            </div>\r\n        </div>\r\n        <div *ngIf=\"!currentUser\">\r\n            <label>{{'Email' | translate}} *</label>\r\n            <div>\r\n                <input type=\"email\" class=\"form-control\" formControlName=\"email\" data-testid=\"new-support-email\"\r\n                    [ngClass]=\"{'is-invalid' : validatorsService.isControlError(supportForm.controls['email'])}\"\r\n                    maxlength=\"255\">\r\n            </div>\r\n            <div class=\"invalid-feedback\">\r\n                <span data-testid=\"new-support-email-invalid\" [translate]=\"validatorsService.getError(supportForm.controls['email'])\"\r\n                    *ngIf=\" validatorsService.isControlError(supportForm.controls['email'])\"></span>\r\n            </div>\r\n        </div>\r\n        <div>\r\n            <label>{{'Description' | translate}} *</label>\r\n            <div>\r\n                <textarea formControlName=\"description\" class=\"form-control\"\r\n                    data-testid=\"new-support-description\"\r\n                    [ngClass]=\"{'is-invalid' : validatorsService.isControlError(supportForm.controls['description'])}\"></textarea>\r\n            </div>\r\n            <div class=\"invalid-feedback\" >\r\n                <span data-testid=\"new-support-description-invalid\" [translate]=\" validatorsService.getError(supportForm.controls['description'])\"\r\n                *ngIf=\"validatorsService.isControlError(supportForm.controls['description'])\"></span>\r\n            </div>\r\n        </div>\r\n    </form>\r\n\r\n    <div *ngIf=\"status ==='send'\" translate=\"Your request has been registered\" data-testid=\"new-support-send-info\">\r\n    </div>\r\n    <div *ngIf=\"status ==='error'\" translate=\"An error has occurred, please renew your request\"\r\n        data-testid=\"new-support-error-info\">\r\n\r\n    </div>\r\n</div>\r\n<div class=\"modal-footer\">\r\n    <button type=\"button\" class=\"btn rounded-pill btn-museum\" data-dismiss=\"modal\" translate=\"Close\" (click)=\"onClose()\"\r\n        data-testid=\"new-support-close-btn\"></button>\r\n    <button *ngIf=\"!loading && status==='new'\" type=\"button\" class=\"btn rounded-pill btn-museum\" translate=\"Submit\"\r\n        (click)=\"onSubmit()\" [disabled]=\"!supportForm.valid\" data-testid=\"new-support-submit-btn\"></button>\r\n</div>"]}
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"support-modal.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-smarterplan-core/src/lib/components/support-modal/support-modal.component.ts","../../../../../../projects/ngx-smarterplan-core/src/lib/components/support-modal/support-modal.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,MAAM,eAAe,CAAC;AAElD,OAAO,EAA0B,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAEpE,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAEnC,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AAEvE,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AAClE,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;;;;;;;;;;AAOhE,MAAM,OAAO,qBAAqB;IAShC,YACU,cAA8B,EAC/B,WAA2B,EAC1B,WAAwB,EACxB,WAA4B,EAC7B,iBAAqC;QAJpC,mBAAc,GAAd,cAAc,CAAgB;QAC/B,gBAAW,GAAX,WAAW,CAAgB;QAC1B,gBAAW,GAAX,WAAW,CAAa;QACxB,gBAAW,GAAX,WAAW,CAAiB;QAC7B,sBAAiB,GAAjB,iBAAiB,CAAoB;QAb9C,WAAM,GAAG,KAAK,CAAC;QAMf,YAAO,GAAY,IAAI,CAAC;IAQpB,CAAC;IAEL,QAAQ;QACN,IAAI,CAAC,OAAO,EAAE,CAAC;IACjB,CAAC;IAED,OAAO;QACL,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;IAED,KAAK,CAAC,cAAc;QAClB,OAAO,IAAI,OAAO,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;YACnC,IAAI;gBACF,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,wBAAwB,EAAE,CAAC;gBAClD,OAAO,CAAC,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;aAC9C;YAAC,OAAO,KAAK,EAAE;gBACd,OAAO,CAAC,SAAS,CAAC,CAAC;aACpB;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,KAAK,CAAC,OAAO;QACX,IAAI,CAAC,WAAW,GAAG,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;QAC/C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;YACxC,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAG,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,gBAAgB,EAAE,EAAE,aAAa,EAAE,CAAC,CAAC;YACnG,KAAK,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,cAAc,EAAE,EAAG,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,aAAa,EAAE,CAAC,CAAC;YAC/I,WAAW,EAAE,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,gBAAgB,EAAE,EAAE,aAAa,EAAE,CAAC,CAAC;SAC9E,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,KAAK,CAAC,QAAQ;QACZ,IAAG,IAAI,CAAC,WAAW,CAAC,KAAK,EAAC;YACxB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,MAAM,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YAC5E,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;SACtB;IACH,CAAC;;kHApDU,qBAAqB;sGAArB,qBAAqB,yDChBlC,m3GA0DM;2FD1CO,qBAAqB;kBALjC,SAAS;+BACE,mBAAmB","sourcesContent":["import { Component, OnInit } from '@angular/core';\r\nimport { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap';\r\nimport { FormBuilder, FormGroup, Validators } from \"@angular/forms\";\r\nimport { BaseUserService } from '../../services/user.service';\r\nimport { Auth } from \"aws-amplify\";\r\nimport { SupportService } from '../../services/support.service';\r\nimport { noEmptyValidator } from '../../validators/no-empty.directive';\r\nimport { ValidatorsService } from '../../services/validators.service';\r\nimport { emailValidator } from '../../validators/email.directive';\r\nimport { textValidator } from '../../validators/text.directive';\r\n\r\n@Component({\r\n  selector: 'app-support-modal',\r\n  templateUrl: './support-modal.component.html',\r\n  styleUrls: ['./support-modal.component.scss']\r\n})\r\nexport class SupportModalComponent implements OnInit {\r\n  status = 'new';\r\n\r\n  supportForm: FormGroup;\r\n\r\n  currentUser: any;\r\n\r\n  loading: boolean = true;\r\n\r\n  constructor(\r\n    private supportService: SupportService,\r\n    public activeModal: NgbActiveModal,\r\n    private formBuilder: FormBuilder,\r\n    private userService: BaseUserService,\r\n    public validatorsService : ValidatorsService\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    this.iniForm();\r\n  }\r\n\r\n  onClose() {\r\n    this.activeModal.close();\r\n  }\r\n\r\n  async getCurrentUser(): Promise<any> {\r\n    return new Promise(async (resolve) => {\r\n      try {\r\n        const cau = await Auth.currentAuthenticatedUser();\r\n        resolve(await this.userService.current(cau));\r\n      } catch (error) {\r\n        resolve(undefined);\r\n      }\r\n    })\r\n  }\r\n\r\n  async iniForm() {\r\n    this.currentUser = await this.getCurrentUser();\r\n    this.supportForm = this.formBuilder.group({\r\n      title: ['', [Validators.required , Validators.maxLength(255), noEmptyValidator(), textValidator()]],\r\n      email: [(this.currentUser ? this.currentUser.email : ''), [Validators.required, emailValidator(),  Validators.maxLength(255), textValidator()]],\r\n      description: ['', [Validators.required, noEmptyValidator(), textValidator()]],\r\n    });\r\n    this.loading = false;\r\n  }\r\n  \r\n  async onSubmit() {\r\n    if(this.supportForm.valid){\r\n      this.loading = true;\r\n      this.status = await this.supportService.sendSupport(this.supportForm.value);\r\n      this.loading = false;\r\n    }\r\n  }\r\n\r\n}","<div class=\"modal-header\">\r\n    <h5 class=\"modal-title\" translate=\"Help\"></h5>\r\n</div>\r\n<div class=\"modal-body\">\r\n    <div class=\"support-loader-container\">\r\n        <lib-loader *ngIf=\"loading\"></lib-loader>\r\n    </div>\r\n    <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"supportForm\" style=\"margin-top:1rem;\" *ngIf=\"!loading && status==='new'\">\r\n        <div>\r\n            <label>{{'Title' | translate}} *</label>\r\n            <div>\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"title\" data-testid=\"new-support-title\"\r\n                    [ngClass]=\"{'is-invalid' : validatorsService.isControlError(supportForm.controls['title'])}\"\r\n                    maxlength=\"255\">\r\n            </div>\r\n            <div class=\"invalid-feedback\">\r\n                <span data-testid=\"new-support-title-invalid\" [translate]=\"validatorsService.getError(supportForm.controls['title'])\"\r\n                    *ngIf=\" validatorsService.isControlError(supportForm.controls['title'])\"></span>\r\n            </div>\r\n        </div>\r\n        <div *ngIf=\"!currentUser\">\r\n            <label>{{'Email' | translate}} *</label>\r\n            <div>\r\n                <input type=\"email\" class=\"form-control\" formControlName=\"email\" data-testid=\"new-support-email\"\r\n                    [ngClass]=\"{'is-invalid' : validatorsService.isControlError(supportForm.controls['email'])}\"\r\n                    maxlength=\"255\">\r\n            </div>\r\n            <div class=\"invalid-feedback\">\r\n                <span data-testid=\"new-support-email-invalid\" [translate]=\"validatorsService.getError(supportForm.controls['email'])\"\r\n                    *ngIf=\" validatorsService.isControlError(supportForm.controls['email'])\"></span>\r\n            </div>\r\n        </div>\r\n        <div>\r\n            <label>{{'Description' | translate}} *</label>\r\n            <div>\r\n                <textarea formControlName=\"description\" class=\"form-control\"\r\n                    data-testid=\"new-support-description\"\r\n                    [ngClass]=\"{'is-invalid' : validatorsService.isControlError(supportForm.controls['description'])}\"></textarea>\r\n            </div>\r\n            <div class=\"invalid-feedback\" >\r\n                <span data-testid=\"new-support-description-invalid\" [translate]=\" validatorsService.getError(supportForm.controls['description'])\"\r\n                *ngIf=\"validatorsService.isControlError(supportForm.controls['description'])\"></span>\r\n            </div>\r\n        </div>\r\n    </form>\r\n\r\n    <div *ngIf=\"status ==='send'\" translate=\"Your request has been registered\" data-testid=\"new-support-send-info\">\r\n    </div>\r\n    <div *ngIf=\"status ==='error'\" translate=\"An error has occurred, please renew your request\"\r\n        data-testid=\"new-support-error-info\">\r\n\r\n    </div>\r\n</div>\r\n<div class=\"modal-footer\">\r\n    <button type=\"button\" class=\"btn rounded-pill btn-museum\" data-dismiss=\"modal\" translate=\"Close\" (click)=\"onClose()\"\r\n        data-testid=\"new-support-close-btn\"></button>\r\n    <button *ngIf=\"!loading && status==='new'\" type=\"button\" class=\"btn rounded-pill btn-museum\" translate=\"Submit\"\r\n        (click)=\"onSubmit()\" [disabled]=\"!supportForm.valid\" data-testid=\"new-support-submit-btn\"></button>\r\n</div>"]}
|
|
@@ -18,16 +18,19 @@ export class ValidatorsService {
|
|
|
18
18
|
getError(control) {
|
|
19
19
|
if (control.errors) {
|
|
20
20
|
if (control.errors.required) {
|
|
21
|
-
return '
|
|
21
|
+
return 'errorForm.required';
|
|
22
22
|
}
|
|
23
23
|
if (control.errors.isEmpty) {
|
|
24
|
-
return '
|
|
24
|
+
return 'errorForm.isEmpty';
|
|
25
|
+
}
|
|
26
|
+
if (control.errors.text) {
|
|
27
|
+
return 'errorForm.text';
|
|
25
28
|
}
|
|
26
29
|
if (control.errors.email) {
|
|
27
|
-
return '
|
|
30
|
+
return 'errorForm.email';
|
|
28
31
|
}
|
|
29
32
|
if (control.errors.maxLength) {
|
|
30
|
-
return '
|
|
33
|
+
return 'errorForm.maxLength';
|
|
31
34
|
}
|
|
32
35
|
}
|
|
33
36
|
return '';
|
|
@@ -41,4 +44,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImpor
|
|
|
41
44
|
providedIn: 'root'
|
|
42
45
|
}]
|
|
43
46
|
}], ctorParameters: function () { return []; } });
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdG9ycy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXNtYXJ0ZXJwbGFuLWNvcmUvc3JjL2xpYi9zZXJ2aWNlcy92YWxpZGF0b3JzLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFLM0MsTUFBTSxPQUFPLGlCQUFpQjtJQUU1QixnQkFBZ0IsQ0FBQztJQUVqQjs7OztPQUlHO0lBQ0ksY0FBYyxDQUFDLE9BQU87UUFDM0IsT0FBTyxDQUFDLE9BQU8sSUFBSSxPQUFPLENBQUMsT0FBTyxJQUFJLE9BQU8sQ0FBQyxPQUFPLENBQUUsQ0FBQTtJQUN6RCxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNJLFFBQVEsQ0FBQyxPQUFPO1FBQ3JCLElBQUcsT0FBTyxDQUFDLE1BQU0sRUFBQztZQUNoQixJQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFDO2dCQUN6QixPQUFPLG9CQUFvQixDQUFBO2FBQzVCO1lBQ0QsSUFBRyxPQUFPLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBQztnQkFDeEIsT0FBTyxtQkFBbUIsQ0FBQTthQUMzQjtZQUNELElBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUM7Z0JBQ3JCLE9BQU8sZ0JBQWdCLENBQUE7YUFDeEI7WUFDRCxJQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFDO2dCQUN0QixPQUFPLGlCQUFpQixDQUFBO2FBQ3pCO1lBQ0QsSUFBRyxPQUFPLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBQztnQkFDMUIsT0FBTyxxQkFBcUIsQ0FBQTthQUM3QjtTQUNGO1FBR0QsT0FBTyxFQUFFLENBQUM7SUFDWixDQUFDOzs4R0F2Q1UsaUJBQWlCO2tIQUFqQixpQkFBaUIsY0FGaEIsTUFBTTsyRkFFUCxpQkFBaUI7a0JBSDdCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgVmFsaWRhdG9yc1NlcnZpY2Uge1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuICAvKipcclxuICAgKiByZXR1cm4gaWYgY29udHJvbCBhcyBlcnJvclxyXG4gICAqIEBwYXJhbSBjb250cm9sIFxyXG4gICAqIEByZXR1cm5zIFxyXG4gICAqL1xyXG4gIHB1YmxpYyBpc0NvbnRyb2xFcnJvcihjb250cm9sKSB7XHJcbiAgICByZXR1cm4gKGNvbnRyb2wgJiYgY29udHJvbC5pbnZhbGlkICYmIGNvbnRyb2wudG91Y2hlZCApXHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiByZXR1cm4gZXJyb3Igb2YgY29udHJvbFxyXG4gICAqIEBwYXJhbSBjb250cm9sIFxyXG4gICAqIEByZXR1cm5zIFxyXG4gICAqL1xyXG4gIHB1YmxpYyBnZXRFcnJvcihjb250cm9sKXtcclxuICAgIGlmKGNvbnRyb2wuZXJyb3JzKXtcclxuICAgICAgaWYoY29udHJvbC5lcnJvcnMucmVxdWlyZWQpe1xyXG4gICAgICAgIHJldHVybiAnZXJyb3JGb3JtLnJlcXVpcmVkJ1xyXG4gICAgICB9XHJcbiAgICAgIGlmKGNvbnRyb2wuZXJyb3JzLmlzRW1wdHkpe1xyXG4gICAgICAgIHJldHVybiAnZXJyb3JGb3JtLmlzRW1wdHknXHJcbiAgICAgIH1cclxuICAgICAgaWYoY29udHJvbC5lcnJvcnMudGV4dCl7XHJcbiAgICAgICAgcmV0dXJuICdlcnJvckZvcm0udGV4dCdcclxuICAgICAgfVxyXG4gICAgICBpZihjb250cm9sLmVycm9ycy5lbWFpbCl7XHJcbiAgICAgICAgcmV0dXJuICdlcnJvckZvcm0uZW1haWwnXHJcbiAgICAgIH1cclxuICAgICAgaWYoY29udHJvbC5lcnJvcnMubWF4TGVuZ3RoKXtcclxuICAgICAgICByZXR1cm4gJ2Vycm9yRm9ybS5tYXhMZW5ndGgnXHJcbiAgICAgIH1cclxuICAgIH1cclxuXHJcblxyXG4gICAgcmV0dXJuICcnO1xyXG4gIH1cclxuXHJcblxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export function textValidator() {
|
|
2
|
+
return (control) => {
|
|
3
|
+
const regex = /[a-zA-Z]/;
|
|
4
|
+
return !regex.test(control.value) ? { text: control.value } : null;
|
|
5
|
+
};
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc21hcnRlcnBsYW4tY29yZS9zcmMvbGliL3ZhbGlkYXRvcnMvdGV4dC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxVQUFVLGFBQWE7SUFDekIsT0FBTyxDQUFDLE9BQXdCLEVBQTJCLEVBQUU7UUFDM0QsTUFBTSxLQUFLLEdBQUcsVUFBVSxDQUFDO1FBQ3pCLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLEtBQUssRUFBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDbkUsQ0FBQyxDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFZhbGlkYXRvckZuLCBBYnN0cmFjdENvbnRyb2wsIFZhbGlkYXRpb25FcnJvcnMgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcclxuXHJcbmV4cG9ydCBmdW5jdGlvbiB0ZXh0VmFsaWRhdG9yKCk6IFZhbGlkYXRvckZuIHtcclxuICAgIHJldHVybiAoY29udHJvbDogQWJzdHJhY3RDb250cm9sKTogVmFsaWRhdGlvbkVycm9ycyB8IG51bGwgPT4ge1xyXG4gICAgICBjb25zdCByZWdleCA9IC9bYS16QS1aXS87XHJcbiAgICAgIHJldHVybiAhcmVnZXgudGVzdChjb250cm9sLnZhbHVlKSA/IHt0ZXh0OiBjb250cm9sLnZhbHVlfSA6IG51bGw7XHJcbiAgICB9O1xyXG4gIH0iXX0=
|
|
@@ -6555,6 +6555,13 @@ function emailValidator() {
|
|
|
6555
6555
|
};
|
|
6556
6556
|
}
|
|
6557
6557
|
|
|
6558
|
+
function textValidator() {
|
|
6559
|
+
return (control) => {
|
|
6560
|
+
const regex = /[a-zA-Z]/;
|
|
6561
|
+
return !regex.test(control.value) ? { text: control.value } : null;
|
|
6562
|
+
};
|
|
6563
|
+
}
|
|
6564
|
+
|
|
6558
6565
|
class SupportService {
|
|
6559
6566
|
constructor(modalService) {
|
|
6560
6567
|
this.modalService = modalService;
|
|
@@ -6613,16 +6620,19 @@ class ValidatorsService {
|
|
|
6613
6620
|
getError(control) {
|
|
6614
6621
|
if (control.errors) {
|
|
6615
6622
|
if (control.errors.required) {
|
|
6616
|
-
return '
|
|
6623
|
+
return 'errorForm.required';
|
|
6617
6624
|
}
|
|
6618
6625
|
if (control.errors.isEmpty) {
|
|
6619
|
-
return '
|
|
6626
|
+
return 'errorForm.isEmpty';
|
|
6627
|
+
}
|
|
6628
|
+
if (control.errors.text) {
|
|
6629
|
+
return 'errorForm.text';
|
|
6620
6630
|
}
|
|
6621
6631
|
if (control.errors.email) {
|
|
6622
|
-
return '
|
|
6632
|
+
return 'errorForm.email';
|
|
6623
6633
|
}
|
|
6624
6634
|
if (control.errors.maxLength) {
|
|
6625
|
-
return '
|
|
6635
|
+
return 'errorForm.maxLength';
|
|
6626
6636
|
}
|
|
6627
6637
|
}
|
|
6628
6638
|
return '';
|
|
@@ -6682,9 +6692,9 @@ class SupportModalComponent {
|
|
|
6682
6692
|
return __awaiter(this, void 0, void 0, function* () {
|
|
6683
6693
|
this.currentUser = yield this.getCurrentUser();
|
|
6684
6694
|
this.supportForm = this.formBuilder.group({
|
|
6685
|
-
title: ['', [Validators.required, Validators.maxLength(255), noEmptyValidator()]],
|
|
6686
|
-
email: [(this.currentUser ? this.currentUser.email : ''), [Validators.required, emailValidator(), Validators.maxLength(255)]],
|
|
6687
|
-
description: ['', [Validators.required, noEmptyValidator()]],
|
|
6695
|
+
title: ['', [Validators.required, Validators.maxLength(255), noEmptyValidator(), textValidator()]],
|
|
6696
|
+
email: [(this.currentUser ? this.currentUser.email : ''), [Validators.required, emailValidator(), Validators.maxLength(255), textValidator()]],
|
|
6697
|
+
description: ['', [Validators.required, noEmptyValidator(), textValidator()]],
|
|
6688
6698
|
});
|
|
6689
6699
|
this.loading = false;
|
|
6690
6700
|
});
|