fabrikantencore 2.9.4 → 2.9.6

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.
@@ -88,6 +88,20 @@ class FabFormComponent {
88
88
  this.ChangeDetectorRef.detectChanges();
89
89
  });
90
90
  }
91
+ else {
92
+ alert('form invalid');
93
+ Object.keys(this.FormGroup.controls).forEach(key => {
94
+ var temp = this.FormGroup.get(key);
95
+ if (temp != undefined) {
96
+ const controlErrors = temp.errors;
97
+ if (controlErrors != null) {
98
+ Object.keys(controlErrors).forEach(keyError => {
99
+ console.log('Key control: ' + key + ', keyError: ' + keyError + ', err value: ', controlErrors[keyError]);
100
+ });
101
+ }
102
+ }
103
+ });
104
+ }
91
105
  }
92
106
  Close() {
93
107
  this.completed.emit();
@@ -104,4 +118,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
104
118
  }], completed: [{
105
119
  type: Output
106
120
  }] } });
107
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fab-form.component.js","sourceRoot":"","sources":["../../../../../../../../src/app/modules/fabrikantencore/components/fab-form/fab-form.component.ts","../../../../../../../../src/app/modules/fabrikantencore/components/fab-form/fab-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAqB,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAC7G,OAAO,EAAuC,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACjF,OAAO,EAA4B,aAAa,EAAwB,yBAAyB,EAAE,mBAAmB,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;;;;;;;;;;;;;AAIpL,MAMa,gBAAgB;IAiEjB;IACA;IACA;IACD;IACC;IAnEV,KAAK,CAA2B;IAChC,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,IAAa,IAAI,CAAC,KAA+B;QAC/C,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,CAAC,CAAA;QAC3C,IAAI,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC;QAEpC,IAAI,IAAI,IAAI,IAAI,EAAE;YAChB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACpC,IAAI,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;gBAExB,IAAI,IAAI,IAAI,IAAI,EAAE;oBAChB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;wBACpC,IAAI,MAAM,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;wBAE5B,IAAI,MAAM,IAAI,IAAI,EAAE;4BAClB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gCAEtC,IAAI,eAAe,GAAkB,IAAI,KAAK,EAAE,CAAC;gCAEjD,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,aAAa,IAAI,aAAa,CAAC,KAAK,EAAE;oCAClD,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;iCACxC;gCAED,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE;oCACtB,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;iCAC3C;gCAED,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,aAAa,IAAI,aAAa,CAAC,QAAQ,EAAE;oCACrD,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,EAAE,EAAE,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,cAAc,EAAE,EAAE,EAAE,eAAe,CAAC,CAAC,CAAC;iCACzH;qCACI;oCACH,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,EAAE,EAAE,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,eAAe,CAAC,CAAC,CAAC;iCAC5G;6BACF;yBACF;qBACF;iBACF;aACF;SACF;aACI;YACH,KAAK,CAAC,OAAO,CAAC,CAAC;SAChB;IACH,CAAC;IAES,SAAS,GAAuB,IAAI,YAAY,EAAQ,CAAC;IACnE,kEAAkE;IAE3D,SAAS,CAAY;IAE5B,IAAW,mBAAmB;QAC5B,OAAO,mBAAmB,CAAC;IAC7B,CAAC;IAED,IAAW,sBAAsB;QAC/B,OAAO,sBAAsB,CAAC;IAChC,CAAC;IAED,YACU,WAAwB,EACxB,oBAA0C,EAC1C,kBAAsC,EACvC,gBAAkC,EACjC,iBAAoC;QAJpC,gBAAW,GAAX,WAAW,CAAa;QACxB,yBAAoB,GAApB,oBAAoB,CAAsB;QAC1C,uBAAkB,GAAlB,kBAAkB,CAAoB;QACvC,qBAAgB,GAAhB,gBAAgB,CAAkB;QACjC,sBAAiB,GAAjB,iBAAiB,CAAmB;IAG9C,CAAC;IAEM,QAAQ;QACb,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE;YACxB,IAAI,OAAO,GAAG,IAAI,yBAAyB,EAAE,CAAC;YAE9C,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC,SAAS,CAAC;YAC3E,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;YAE9B,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;gBACxD,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,IAAI,CAAC,iBAAiB,EAAE,SAAS,EAAE,GAAG,EAAE;oBAC1E,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;gBACxB,CAAC,CAAC,CAAC;YACL,CAAC,EAAE,CAAC,KAAe,EAAE,EAAE;gBACrB,KAAK,CAAC,6BAA6B,CAAC,CAAC;gBAErC,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;YACzC,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAEM,KAAK;QACV,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IACxB,CAAC;uGA/FU,gBAAgB;2FAAhB,gBAAgB,mHCZ7B,2iGA+DA;;SDnDa,gBAAgB;2FAAhB,gBAAgB;kBAN5B,SAAS;+BACE,cAAc,iBAGT,iBAAiB,CAAC,IAAI;qOASxB,IAAI;sBAAhB,KAAK;gBA4CI,SAAS;sBAAlB,MAAM","sourcesContent":["import { Component, ChangeDetectorRef, Input, Output, EventEmitter, ViewEncapsulation } from '@angular/core';\nimport { FormBuilder, FormGroup, ValidatorFn, Validators } from '@angular/forms';\r\nimport { FabrikantenFormViewModel, FormInputType, FabrikantenApiClient, FabrikantenSetFormRequest, TranslationCategory, TranslationSubCategory } from '../../swagger/SwaggerClient';\r\nimport { FabrikantenService } from '../../services/fabrikanten.service';\r\nimport { TranslateService } from '../../services/translate.service';\r\n\n@Component({\n  selector: 'app-fab-form',\n  templateUrl: './fab-form.component.html',\n  styleUrls: ['./fab-form.component.scss'],\n  encapsulation: ViewEncapsulation.None\n})\nexport class FabFormComponent {\n\n  _form: FabrikantenFormViewModel;\r\n  get form(): FabrikantenFormViewModel {\r\n    return this._form;\r\n  }\r\n\r\n  @Input() set form(value: FabrikantenFormViewModel) {\r\n    this._form = value;\r\n\r\n    this.FormGroup = this.formBuilder.group({})\n    var cats = this.form.formCategories;\n\n    if (cats != null) {\n      for (var i = 0; i < cats.length; i++) {\n        var rows = cats[i].rows;\r\n\r\n        if (rows != null) {\r\n          for (var j = 0; j < rows.length; j++) {\r\n            var inputs = rows[j].inputs;\r\n\r\n            if (inputs != null) {\r\n              for (var p = 0; p < inputs.length; p++) {\r\n\r\n                var ValidatorsArray: ValidatorFn[] = new Array();\r\n\r\n                if (inputs[p].formInputType == FormInputType.Email) {\r\n                  ValidatorsArray.push(Validators.email);\r\n                }\r\n\r\n                if (inputs[p].required) {\r\n                  ValidatorsArray.push(Validators.required);\r\n                }\r\n\r\n                if (inputs[p].formInputType == FormInputType.Dropdown) {\r\n                  this.FormGroup.addControl(inputs[p].name + \"\", this.formBuilder.control(inputs[p].selectedOption?.id, ValidatorsArray));\r\n                }\r\n                else {\r\n                  this.FormGroup.addControl(inputs[p].name + \"\", this.formBuilder.control(inputs[p].value, ValidatorsArray));\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\n    }\n    else {\n      alert('error');\r\n    }\r\n  }\n\n  @Output() completed: EventEmitter<void> = new EventEmitter<void>();\n  //@Output() cancel: EventEmitter<void> = new EventEmitter<void>();\n\n  public FormGroup: FormGroup;\n\n  public get TranslationCategory() {\n    return TranslationCategory;\n  }\n\n  public get TranslationSubCategory() {\n    return TranslationSubCategory;\n  }\n\n  constructor(\n    private formBuilder: FormBuilder,\n    private FabrikantenApiClient: FabrikantenApiClient,\n    private FabrikantenService: FabrikantenService,\n    public TranslateService: TranslateService,\n    private ChangeDetectorRef: ChangeDetectorRef\n  ) {\n   \n  }\n\n  public OnSubmit(): void {\r\n    if (this.FormGroup.valid) {\r\n      var request = new FabrikantenSetFormRequest();\r\n\r\n      request.sessionId = this.FabrikantenService.FabrikantenViewModel.sessionId;\r\n      request.formId = this.form.id;\r\n\r\n      this.FabrikantenApiClient.setForm(request).subscribe(() => {\r\n        this.FabrikantenService.ReloadModel(this.ChangeDetectorRef, undefined, () => {\r\n          this.completed.emit();\r\n        });\r\n      }, (error: Response) => {\r\n        alert('An unexpected error occured');\r\n\r\n        this.ChangeDetectorRef.detectChanges();\r\n      });\r\n    }\r\n  }\n\n  public Close(): void {\n    this.completed.emit();\r\n  }\n}\n","<form [formGroup]=\"FormGroup\">\n  <ng-container *ngFor=\"let cat of form.formCategories\">\n    <div class=\"form-cat-name\">\n      {{ TranslateService.GetActiveValue(TranslationCategory.Forms, TranslationSubCategory.Category, cat.id) }}\n    </div>\n    <ng-container *ngFor=\"let row of cat.rows\">\n      <div class=\"form-cat-inputs displayflex\">\n        <div class=\"form-cat-input\" *ngFor=\"let input of row.inputs\">\n          <ng-container *ngIf=\"input.formInputType == 1 || input.formInputType == 6\">\n            <mat-form-field appearance=\"fill\" class=\"full-width form-cat-input-input\">\n              <mat-label>\n                {{ TranslateService.GetActiveValue(TranslationCategory.Forms, TranslationSubCategory.Input, input.id) }}\n              </mat-label>\n              <input matInput type=\"text\" formControlName=\"{{ input.name }}\">\n              <mat-error></mat-error>\n            </mat-form-field>\n          </ng-container>\n\n          <ng-container *ngIf=\"input.formInputType == 2\">\n            <mat-form-field appearance=\"fill\" class=\"full-width form-cat-input-select\">\n              <mat-label class=\"select-mat-label filter-name\">\n                {{ input.name }}\n              </mat-label>\n              <mat-select formControlName=\"{{ input.name }}\">\n                <ng-container *ngFor=\"let option of input.options\">\n                  <mat-option [value]=\"option.id\" class=\"select-mat-option\">\n                    <span class=\"name-span\">\n                      {{ option.name }}\n                    </span>\n                  </mat-option>\n                </ng-container>\n              </mat-select>\n            </mat-form-field>\n          </ng-container>\n\n          <ng-container *ngIf=\"input.formInputType == 3\">\n            <mat-checkbox class=\"form-cat-input-checkbox\">\n              <span [innerHTML]=\"TranslateService.GetActiveValue(TranslationCategory.Forms, TranslationSubCategory.Input, input.id)\"></span>\n            </mat-checkbox>\n          </ng-container>\n\n          <ng-container *ngIf=\"input.formInputType == 5\">\n            <mat-form-field class=\"full-width form-cat-input-textarea\">\n              <mat-label>\n                {{ TranslateService.GetActiveValue(TranslationCategory.Forms, TranslationSubCategory.Input, input.id) }}\n              </mat-label>\n              <textarea matInput formControlName=\"{{ input.name }}\" style=\"height: 100px;\"></textarea>\n            </mat-form-field>\n          </ng-container>\n        </div>\n      </div>\n    </ng-container>\n  </ng-container>\n\n  <div class=\"form-button-row\">\n    <button mat-raised-button (click)=\"Close()\" class=\"form-cat-close form-button-row-button\">\n      {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.Close) }}\n    </button>\n    <button mat-raised-button (click)=\"OnSubmit()\" class=\"form-cat-submit form-button-row-button\">\n      {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.Send) }}\n    </button>\n  </div>\n</form>\n"]}
121
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fab-form.component.js","sourceRoot":"","sources":["../../../../../../../../src/app/modules/fabrikantencore/components/fab-form/fab-form.component.ts","../../../../../../../../src/app/modules/fabrikantencore/components/fab-form/fab-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ChangeDetectorRef, Input, Output, EventEmitter, ViewEncapsulation } from '@angular/core';\nimport { FormBuilder, FormGroup, ValidationErrors, ValidatorFn, Validators } from '@angular/forms';\r\nimport { FabrikantenFormViewModel, FormInputType, FabrikantenApiClient, FabrikantenSetFormRequest, TranslationCategory, TranslationSubCategory } from '../../swagger/SwaggerClient';\r\nimport { FabrikantenService } from '../../services/fabrikanten.service';\r\nimport { TranslateService } from '../../services/translate.service';\r\n\n@Component({\n  selector: 'app-fab-form',\n  templateUrl: './fab-form.component.html',\n  styleUrls: ['./fab-form.component.scss'],\n  encapsulation: ViewEncapsulation.None\n})\nexport class FabFormComponent {\n\n  _form: FabrikantenFormViewModel;\r\n  get form(): FabrikantenFormViewModel {\r\n    return this._form;\r\n  }\r\n\r\n  @Input() set form(value: FabrikantenFormViewModel) {\r\n    this._form = value;\r\n\r\n    this.FormGroup = this.formBuilder.group({})\n    var cats = this.form.formCategories;\n\n    if (cats != null) {\n      for (var i = 0; i < cats.length; i++) {\n        var rows = cats[i].rows;\r\n\r\n        if (rows != null) {\r\n          for (var j = 0; j < rows.length; j++) {\r\n            var inputs = rows[j].inputs;\r\n\r\n            if (inputs != null) {\r\n              for (var p = 0; p < inputs.length; p++) {\r\n\r\n                var ValidatorsArray: ValidatorFn[] = new Array();\r\n\r\n                if (inputs[p].formInputType == FormInputType.Email) {\r\n                  ValidatorsArray.push(Validators.email);\r\n                }\r\n\r\n                if (inputs[p].required) {\r\n                  ValidatorsArray.push(Validators.required);\r\n                }\r\n\r\n                if (inputs[p].formInputType == FormInputType.Dropdown) {\r\n                  this.FormGroup.addControl(inputs[p].name + \"\", this.formBuilder.control(inputs[p].selectedOption?.id, ValidatorsArray));\r\n                }\r\n                else {\r\n                  this.FormGroup.addControl(inputs[p].name + \"\", this.formBuilder.control(inputs[p].value, ValidatorsArray));\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\n    }\n    else {\n      alert('error');\r\n    }\r\n  }\n\n  @Output() completed: EventEmitter<void> = new EventEmitter<void>();\n  //@Output() cancel: EventEmitter<void> = new EventEmitter<void>();\n\n  public FormGroup: FormGroup;\n\n  public get TranslationCategory() {\n    return TranslationCategory;\n  }\n\n  public get TranslationSubCategory() {\n    return TranslationSubCategory;\n  }\n\n  constructor(\n    private formBuilder: FormBuilder,\n    private FabrikantenApiClient: FabrikantenApiClient,\n    private FabrikantenService: FabrikantenService,\n    public TranslateService: TranslateService,\n    private ChangeDetectorRef: ChangeDetectorRef\n  ) {\n   \n  }\n\n  public OnSubmit(): void {\r\n    if (this.FormGroup.valid) {\r\n      var request = new FabrikantenSetFormRequest();\r\n\r\n      request.sessionId = this.FabrikantenService.FabrikantenViewModel.sessionId;\r\n      request.formId = this.form.id;\r\n\r\n      this.FabrikantenApiClient.setForm(request).subscribe(() => {\r\n        this.FabrikantenService.ReloadModel(this.ChangeDetectorRef, undefined, () => {\r\n          this.completed.emit();\r\n        });\r\n      }, (error: Response) => {\r\n        alert('An unexpected error occured');\r\n\r\n        this.ChangeDetectorRef.detectChanges();\r\n      });\r\n    }\r\n    else {\r\n      alert('form invalid');\r\n\r\n      Object.keys(this.FormGroup.controls).forEach(key => {\r\n        var temp = this.FormGroup.get(key);\r\n\r\n        if (temp != undefined) {\r\n          const controlErrors: ValidationErrors = temp.errors as ValidationErrors;\r\n          if (controlErrors != null) {\r\n            Object.keys(controlErrors).forEach(keyError => {\r\n              console.log('Key control: ' + key + ', keyError: ' + keyError + ', err value: ', controlErrors[keyError]);\r\n            });\r\n          }\r\n        }\r\n      });\r\n    }\r\n  }\n\n  public Close(): void {\n    this.completed.emit();\r\n  }\n}\n","<form [formGroup]=\"FormGroup\">\n  <ng-container *ngFor=\"let cat of form.formCategories\">\n    <div class=\"form-cat-name\">\n      {{ TranslateService.GetActiveValue(TranslationCategory.Forms, TranslationSubCategory.Category, cat.id) }}\n    </div>\n    <ng-container *ngFor=\"let row of cat.rows\">\n      <div class=\"form-cat-inputs displayflex\">\n        <div class=\"form-cat-input\" *ngFor=\"let input of row.inputs\">\n          <ng-container *ngIf=\"input.formInputType == 1 || input.formInputType == 6\">\n            <mat-form-field appearance=\"fill\" class=\"full-width form-cat-input-input\">\n              <mat-label>\n                {{ TranslateService.GetActiveValue(TranslationCategory.Forms, TranslationSubCategory.Input, input.id) }}\n              </mat-label>\n              <input matInput type=\"text\" formControlName=\"{{ input.name }}\">\n              <mat-error></mat-error>\n            </mat-form-field>\n          </ng-container>\n\n          <ng-container *ngIf=\"input.formInputType == 2\">\n            <mat-form-field appearance=\"fill\" class=\"full-width form-cat-input-select\">\n              <mat-label class=\"select-mat-label filter-name\">\n                {{ input.name }}\n              </mat-label>\n              <mat-select formControlName=\"{{ input.name }}\">\n                <ng-container *ngFor=\"let option of input.options\">\n                  <mat-option [value]=\"option.id\" class=\"select-mat-option\">\n                    <span class=\"name-span\">\n                      {{ option.name }}\n                    </span>\n                  </mat-option>\n                </ng-container>\n              </mat-select>\n            </mat-form-field>\n          </ng-container>\n\n          <ng-container *ngIf=\"input.formInputType == 3\">\n            <mat-checkbox class=\"form-cat-input-checkbox\">\n              <span [innerHTML]=\"TranslateService.GetActiveValue(TranslationCategory.Forms, TranslationSubCategory.Input, input.id)\"></span>\n            </mat-checkbox>\n          </ng-container>\n\n          <ng-container *ngIf=\"input.formInputType == 5\">\n            <mat-form-field class=\"full-width form-cat-input-textarea\">\n              <mat-label>\n                {{ TranslateService.GetActiveValue(TranslationCategory.Forms, TranslationSubCategory.Input, input.id) }}\n              </mat-label>\n              <textarea matInput formControlName=\"{{ input.name }}\" style=\"height: 100px;\"></textarea>\n            </mat-form-field>\n          </ng-container>\n        </div>\n      </div>\n    </ng-container>\n  </ng-container>\n\n  <div class=\"form-button-row\">\n    <button mat-raised-button (click)=\"Close()\" class=\"form-cat-close form-button-row-button\">\n      {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.Close) }}\n    </button>\n    <button mat-raised-button (click)=\"OnSubmit()\" class=\"form-cat-submit form-button-row-button\">\n      {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.Send) }}\n    </button>\n  </div>\n</form>\n"]}
@@ -17427,6 +17427,20 @@ class FabFormComponent {
17427
17427
  this.ChangeDetectorRef.detectChanges();
17428
17428
  });
17429
17429
  }
17430
+ else {
17431
+ alert('form invalid');
17432
+ Object.keys(this.FormGroup.controls).forEach(key => {
17433
+ var temp = this.FormGroup.get(key);
17434
+ if (temp != undefined) {
17435
+ const controlErrors = temp.errors;
17436
+ if (controlErrors != null) {
17437
+ Object.keys(controlErrors).forEach(keyError => {
17438
+ console.log('Key control: ' + key + ', keyError: ' + keyError + ', err value: ', controlErrors[keyError]);
17439
+ });
17440
+ }
17441
+ }
17442
+ });
17443
+ }
17430
17444
  }
17431
17445
  Close() {
17432
17446
  this.completed.emit();