fabrikantencore 2.9.2 → 2.9.4
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/esm2022/public_api.mjs +2 -1
- package/esm2022/src/app/modules/fabrikantencore/beheer/components/beheer-import-sets/beheer-import-sets.component.mjs +4 -4
- package/esm2022/src/app/modules/fabrikantencore/beheer/components/beheer-products/beheer-products-eigenschap/beheer-products-eigenschap.component.mjs +21 -4
- package/esm2022/src/app/modules/fabrikantencore/beheer/components/beheer-products/beheer-products.component.mjs +4 -4
- package/esm2022/src/app/modules/fabrikantencore/beheer/components/beheer-searchproducts/beheer-searchproducts.component.mjs +3 -3
- package/esm2022/src/app/modules/fabrikantencore/beheer/components/beheer-select-filter-dialog/beheer-select-filter-dialog.component.mjs +3 -2
- package/esm2022/src/app/modules/fabrikantencore/components/fab-actionmenu/fab-actionmenu.component.mjs +3 -10
- package/esm2022/src/app/modules/fabrikantencore/components/fab-display-photo-dialog/fab-display-photo-dialog.component.mjs +25 -0
- package/esm2022/src/app/modules/fabrikantencore/components/fab-filter-label/fab-filter-label.component.mjs +3 -3
- package/esm2022/src/app/modules/fabrikantencore/components/fab-filter-picture-select/fab-filter-picture-select.component.mjs +70 -0
- package/esm2022/src/app/modules/fabrikantencore/components/fab-filters-input/fab-filters-input.component.mjs +18 -3
- package/esm2022/src/app/modules/fabrikantencore/components/fab-form/fab-form.component.mjs +107 -0
- package/esm2022/src/app/modules/fabrikantencore/components/fab-form-dialog/fab-form-dialog.component.mjs +14 -80
- package/esm2022/src/app/modules/fabrikantencore/components/fab-input/fab-input.component.mjs +4 -3
- package/esm2022/src/app/modules/fabrikantencore/components/fab-input-code/fab-input-code.component.mjs +8 -9
- package/esm2022/src/app/modules/fabrikantencore/components/fab-product/fab-product.component.mjs +11 -3
- package/esm2022/src/app/modules/fabrikantencore/fabrikantencore.module.mjs +16 -5
- package/esm2022/src/app/modules/fabrikantencore/services/fabrikanten.service.mjs +51 -51
- package/esm2022/src/app/modules/fabrikantencore/services/products.service.mjs +2 -2
- package/esm2022/src/app/modules/fabrikantencore/swagger/SwaggerClient.mjs +96 -1
- package/fesm2022/fabrikantencore.mjs +741 -492
- package/fesm2022/fabrikantencore.mjs.map +1 -1
- package/package.json +1 -1
- package/public_api.d.ts +1 -0
- package/src/app/modules/fabrikantencore/beheer/components/beheer-products/beheer-products-eigenschap/beheer-products-eigenschap.component.d.ts +1 -0
- package/src/app/modules/fabrikantencore/components/fab-actionmenu/fab-actionmenu.component.d.ts +0 -1
- package/src/app/modules/fabrikantencore/components/fab-display-photo-dialog/fab-display-photo-dialog.component.d.ts +10 -0
- package/src/app/modules/fabrikantencore/components/fab-filter-picture-select/fab-filter-picture-select.component.d.ts +28 -0
- package/src/app/modules/fabrikantencore/components/fab-filters-input/fab-filters-input.component.d.ts +2 -0
- package/src/app/modules/fabrikantencore/components/fab-form/fab-form.component.d.ts +25 -0
- package/src/app/modules/fabrikantencore/components/fab-form-dialog/fab-form-dialog.component.d.ts +2 -11
- package/src/app/modules/fabrikantencore/components/fab-product/fab-product.component.d.ts +1 -0
- package/src/app/modules/fabrikantencore/fabrikantencore.module.d.ts +32 -29
- package/src/app/modules/fabrikantencore/swagger/SwaggerClient.d.ts +26 -1
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { TranslationCategory, TranslationSubCategory } from '../../swagger/SwaggerClient';
|
|
3
|
+
import { FabDisplayPhotoDialogComponent } from '../fab-display-photo-dialog/fab-display-photo-dialog.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../../services/fabrikanten.service";
|
|
6
|
+
import * as i2 from "../../services/translate.service";
|
|
7
|
+
import * as i3 from "@angular/router";
|
|
8
|
+
import * as i4 from "@angular/material/legacy-dialog";
|
|
9
|
+
import * as i5 from "@angular/common";
|
|
10
|
+
import * as i6 from "@angular/material/legacy-tooltip";
|
|
11
|
+
import * as i7 from "@angular/material/legacy-button";
|
|
12
|
+
import * as i8 from "@angular/material/icon";
|
|
13
|
+
class FabFilterPictureSelectComponent {
|
|
14
|
+
FabrikantenService;
|
|
15
|
+
TranslateService;
|
|
16
|
+
ActivatedRoute;
|
|
17
|
+
dialog;
|
|
18
|
+
ChangeDetectorRef;
|
|
19
|
+
get TranslationCategory() {
|
|
20
|
+
return TranslationCategory;
|
|
21
|
+
}
|
|
22
|
+
get TranslationSubCategory() {
|
|
23
|
+
return TranslationSubCategory;
|
|
24
|
+
}
|
|
25
|
+
_filter;
|
|
26
|
+
get filter() {
|
|
27
|
+
return this._filter;
|
|
28
|
+
}
|
|
29
|
+
set filter(value) {
|
|
30
|
+
this._filter = value;
|
|
31
|
+
}
|
|
32
|
+
filterchanged = new EventEmitter();
|
|
33
|
+
constructor(FabrikantenService, TranslateService, ActivatedRoute, dialog, ChangeDetectorRef) {
|
|
34
|
+
this.FabrikantenService = FabrikantenService;
|
|
35
|
+
this.TranslateService = TranslateService;
|
|
36
|
+
this.ActivatedRoute = ActivatedRoute;
|
|
37
|
+
this.dialog = dialog;
|
|
38
|
+
this.ChangeDetectorRef = ChangeDetectorRef;
|
|
39
|
+
}
|
|
40
|
+
ngOnInit() {
|
|
41
|
+
}
|
|
42
|
+
OpenPhoto(url) {
|
|
43
|
+
var dialogRef = this.dialog.open(FabDisplayPhotoDialogComponent, {
|
|
44
|
+
data: {
|
|
45
|
+
url: url
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
SelectOption(optionid) {
|
|
50
|
+
this.FabrikantenService.SelectOption(this.filter.id, optionid, this.ChangeDetectorRef, this.ActivatedRoute);
|
|
51
|
+
}
|
|
52
|
+
ResetSelection() {
|
|
53
|
+
this.FabrikantenService.ResetSelectionFilter(this.filter, this.ChangeDetectorRef, this.ActivatedRoute);
|
|
54
|
+
}
|
|
55
|
+
HasSelectedOption() {
|
|
56
|
+
return this.filter.selectedOption != 0;
|
|
57
|
+
}
|
|
58
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: FabFilterPictureSelectComponent, deps: [{ token: i1.FabrikantenService }, { token: i2.TranslateService }, { token: i3.ActivatedRoute }, { token: i4.MatLegacyDialog }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
59
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: FabFilterPictureSelectComponent, selector: "app-fab-filter-picture-select", inputs: { filter: "filter" }, outputs: { filterchanged: "filterchanged" }, ngImport: i0, template: "<div *ngIf=\"!filter.hidden\">\r\n <div class=\"filter-label\">\r\n <span class=\"filter-label-name\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Filter, TranslationSubCategory.Name, filter.id) }}\r\n </span>\r\n <span class=\"filter-label-standard\" *ngIf=\"filter.standard != null && filter.standard != ''\"> ({{ filter.standard }})</span>\r\n <span class=\"filter-label-asterix\" *ngIf=\"filter.blocksProductSelect || filter.required\">*</span>\r\n <ng-container *ngIf=\"TranslateService.GetActiveValue(TranslationCategory.Filter, TranslationSubCategory.Tooltip, filter.id) != ''\">\r\n <span class=\"filter-label-tooltip\" matTooltipClass=\"filter-tooltip\" matTooltip=\"{{ TranslateService.GetActiveValue(TranslationCategory.Filter, TranslationSubCategory.Tooltip, filter.id) }}\">\r\n <mat-icon class=\"expand_less\">info</mat-icon>\r\n </span>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"HasSelectedOption()\">\r\n <ng-container *ngFor=\"let option of filter.options\">\r\n <ng-container *ngIf=\"!option.hidden && (filter.selectedOption == 0 || option.id == filter.selectedOption)\">\r\n\r\n <span class=\"name-span\">{{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, option.id) }}</span>\r\n <span class=\"filteroption-label-unit\" *ngIf=\"filter.unit != null && filter.unit != ''\"> {{ filter.unit }}</span>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <div class=\"reset\" (click)=\"ResetSelection()\">\r\n <mat-icon class=\"icon-position clear\" [inline]=\"true\">clear</mat-icon>\r\n </div>\r\n </ng-container>\r\n </div>\r\n\r\n <div *ngIf=\"!HasSelectedOption()\" class=\"select-options\">\r\n <ng-container *ngFor=\"let option of filter.options\">\r\n <div>\r\n <ng-container *ngIf=\"option.imagePath != null && option.imagePath != ''\">\r\n <div class=\"filter-option-image-div\" (click)=\"OpenPhoto(option.imagePath)\">\r\n <img src=\"{{ option.imagePath }}\" class=\"filter-option-image\" />\r\n </div>\r\n </ng-container>\r\n <button mat-raised-button (click)=\"SelectOption(option.id)\" class=\"fab-picture-select-button\">\r\n <span class=\"name-span\">{{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, option.id) }}</span>\r\n <span class=\"filteroption-label-unit\" *ngIf=\"filter.unit != null && filter.unit != ''\"> {{ filter.unit }}</span>\r\n </button> \r\n </div>\r\n </ng-container>\r\n </div>\r\n</div>\r\n", styles: [".filter-label,.select-options{display:flex}.filter-option-image-div{text-align:center}.filter-option-image{width:100px;cursor:zoom-in}.reset{cursor:pointer;font-size:26px}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.MatLegacyTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i7.MatLegacyButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] });
|
|
60
|
+
}
|
|
61
|
+
export { FabFilterPictureSelectComponent };
|
|
62
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: FabFilterPictureSelectComponent, decorators: [{
|
|
63
|
+
type: Component,
|
|
64
|
+
args: [{ selector: 'app-fab-filter-picture-select', template: "<div *ngIf=\"!filter.hidden\">\r\n <div class=\"filter-label\">\r\n <span class=\"filter-label-name\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Filter, TranslationSubCategory.Name, filter.id) }}\r\n </span>\r\n <span class=\"filter-label-standard\" *ngIf=\"filter.standard != null && filter.standard != ''\"> ({{ filter.standard }})</span>\r\n <span class=\"filter-label-asterix\" *ngIf=\"filter.blocksProductSelect || filter.required\">*</span>\r\n <ng-container *ngIf=\"TranslateService.GetActiveValue(TranslationCategory.Filter, TranslationSubCategory.Tooltip, filter.id) != ''\">\r\n <span class=\"filter-label-tooltip\" matTooltipClass=\"filter-tooltip\" matTooltip=\"{{ TranslateService.GetActiveValue(TranslationCategory.Filter, TranslationSubCategory.Tooltip, filter.id) }}\">\r\n <mat-icon class=\"expand_less\">info</mat-icon>\r\n </span>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"HasSelectedOption()\">\r\n <ng-container *ngFor=\"let option of filter.options\">\r\n <ng-container *ngIf=\"!option.hidden && (filter.selectedOption == 0 || option.id == filter.selectedOption)\">\r\n\r\n <span class=\"name-span\">{{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, option.id) }}</span>\r\n <span class=\"filteroption-label-unit\" *ngIf=\"filter.unit != null && filter.unit != ''\"> {{ filter.unit }}</span>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <div class=\"reset\" (click)=\"ResetSelection()\">\r\n <mat-icon class=\"icon-position clear\" [inline]=\"true\">clear</mat-icon>\r\n </div>\r\n </ng-container>\r\n </div>\r\n\r\n <div *ngIf=\"!HasSelectedOption()\" class=\"select-options\">\r\n <ng-container *ngFor=\"let option of filter.options\">\r\n <div>\r\n <ng-container *ngIf=\"option.imagePath != null && option.imagePath != ''\">\r\n <div class=\"filter-option-image-div\" (click)=\"OpenPhoto(option.imagePath)\">\r\n <img src=\"{{ option.imagePath }}\" class=\"filter-option-image\" />\r\n </div>\r\n </ng-container>\r\n <button mat-raised-button (click)=\"SelectOption(option.id)\" class=\"fab-picture-select-button\">\r\n <span class=\"name-span\">{{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, option.id) }}</span>\r\n <span class=\"filteroption-label-unit\" *ngIf=\"filter.unit != null && filter.unit != ''\"> {{ filter.unit }}</span>\r\n </button> \r\n </div>\r\n </ng-container>\r\n </div>\r\n</div>\r\n", styles: [".filter-label,.select-options{display:flex}.filter-option-image-div{text-align:center}.filter-option-image{width:100px;cursor:zoom-in}.reset{cursor:pointer;font-size:26px}\n"] }]
|
|
65
|
+
}], ctorParameters: function () { return [{ type: i1.FabrikantenService }, { type: i2.TranslateService }, { type: i3.ActivatedRoute }, { type: i4.MatLegacyDialog }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { filter: [{
|
|
66
|
+
type: Input
|
|
67
|
+
}], filterchanged: [{
|
|
68
|
+
type: Output
|
|
69
|
+
}] } });
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fab-filter-picture-select.component.js","sourceRoot":"","sources":["../../../../../../../../src/app/modules/fabrikantencore/components/fab-filter-picture-select/fab-filter-picture-select.component.ts","../../../../../../../../src/app/modules/fabrikantencore/components/fab-filter-picture-select/fab-filter-picture-select.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAqB,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAqB,MAAM,eAAe,CAAC;AAKrH,OAAO,EAAgE,mBAAmB,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AACxJ,OAAO,EAAE,8BAA8B,EAAE,MAAM,gEAAgE,CAAC;;;;;;;;;;AAEhH,MAKa,+BAA+B;IAqBhC;IACD;IACA;IACA;IACC;IAxBV,IAAW,mBAAmB;QAC5B,OAAO,mBAAmB,CAAC;IAC7B,CAAC;IAED,IAAW,sBAAsB;QAC/B,OAAO,sBAAsB,CAAC;IAChC,CAAC;IAED,OAAO,CAA6B;IACpC,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,IAAa,MAAM,CAAC,KAAiC;QACnD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IAES,aAAa,GAAuB,IAAI,YAAY,EAAQ,CAAC;IAEvE,YACU,kBAAsC,EACvC,gBAAkC,EAClC,cAA8B,EAC9B,MAAiB,EAChB,iBAAoC;QAJpC,uBAAkB,GAAlB,kBAAkB,CAAoB;QACvC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,mBAAc,GAAd,cAAc,CAAgB;QAC9B,WAAM,GAAN,MAAM,CAAW;QAChB,sBAAiB,GAAjB,iBAAiB,CAAmB;IAAI,CAAC;IAEnD,QAAQ;IACR,CAAC;IAEM,SAAS,CAAC,GAAW;QAC1B,IAAI,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,8BAA8B,EAAE;YAC/D,IAAI,EAAE;gBACJ,GAAG,EAAE,GAAG;aACT;SACF,CAAC,CAAC;IACL,CAAC;IAEM,YAAY,CAAC,QAAgB;QAClC,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,iBAAiB,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;IAC9G,CAAC;IAEM,cAAc;QACnB,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,iBAAiB,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;IACzG,CAAC;IAEM,iBAAiB;QACtB,OAAO,IAAI,CAAC,MAAM,CAAC,cAAc,IAAI,CAAC,CAAA;IACxC,CAAC;uGAhDU,+BAA+B;2FAA/B,+BAA+B,gJCb5C,0mFA4CA;;SD/Ba,+BAA+B;2FAA/B,+BAA+B;kBAL3C,SAAS;+BACE,+BAA+B;mOAkB5B,MAAM;sBAAlB,KAAK;gBAII,aAAa;sBAAtB,MAAM","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, OnInit, Output, ViewEncapsulation } from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport { MatLegacyDialog as MatDialog } from '@angular/material/legacy-dialog';\nimport { FabrikantenService } from '../../services/fabrikanten.service';\nimport { TranslateService } from '../../services/translate.service';\nimport { FabrikantenFilterOptionViewModel, FabrikantenFilterViewModel, TranslationCategory, TranslationSubCategory } from '../../swagger/SwaggerClient';\nimport { FabDisplayPhotoDialogComponent } from '../fab-display-photo-dialog/fab-display-photo-dialog.component';\n\n@Component({\n  selector: 'app-fab-filter-picture-select',\n  templateUrl: './fab-filter-picture-select.component.html',\n  styleUrls: ['./fab-filter-picture-select.component.scss']\n})\nexport class FabFilterPictureSelectComponent {\n  public get TranslationCategory() {\n    return TranslationCategory;\n  }\n\n  public get TranslationSubCategory() {\n    return TranslationSubCategory;\n  }\n\n  _filter: FabrikantenFilterViewModel;\n  get filter(): FabrikantenFilterViewModel {\n    return this._filter;\n  }\n\n  @Input() set filter(value: FabrikantenFilterViewModel) {\n    this._filter = value;\n  }\n\n  @Output() filterchanged: EventEmitter<void> = new EventEmitter<void>();\n\n  constructor(\n    private FabrikantenService: FabrikantenService,\n    public TranslateService: TranslateService,\n    public ActivatedRoute: ActivatedRoute,\n    public dialog: MatDialog,\n    private ChangeDetectorRef: ChangeDetectorRef) { }\n\n  ngOnInit(): void {\n  }\n\n  public OpenPhoto(url: string): void {\n    var dialogRef = this.dialog.open(FabDisplayPhotoDialogComponent, {\r\n      data: {\r\n        url: url\r\n      }\r\n    });\r\n  }\n\n  public SelectOption(optionid: number): void {\n    this.FabrikantenService.SelectOption(this.filter.id, optionid, this.ChangeDetectorRef, this.ActivatedRoute);\n  }\n\n  public ResetSelection(): void {\n    this.FabrikantenService.ResetSelectionFilter(this.filter, this.ChangeDetectorRef, this.ActivatedRoute);\n  }\n\n  public HasSelectedOption(): boolean {\n    return this.filter.selectedOption != 0\r\n  }\n}\n","<div *ngIf=\"!filter.hidden\">\r\n  <div class=\"filter-label\">\r\n    <span class=\"filter-label-name\">\r\n      {{ TranslateService.GetActiveValue(TranslationCategory.Filter, TranslationSubCategory.Name, filter.id) }}\r\n    </span>\r\n    <span class=\"filter-label-standard\" *ngIf=\"filter.standard != null && filter.standard != ''\"> ({{ filter.standard }})</span>\r\n    <span class=\"filter-label-asterix\" *ngIf=\"filter.blocksProductSelect || filter.required\">*</span>\r\n    <ng-container *ngIf=\"TranslateService.GetActiveValue(TranslationCategory.Filter, TranslationSubCategory.Tooltip, filter.id) != ''\">\r\n      <span class=\"filter-label-tooltip\" matTooltipClass=\"filter-tooltip\" matTooltip=\"{{ TranslateService.GetActiveValue(TranslationCategory.Filter, TranslationSubCategory.Tooltip, filter.id) }}\">\r\n        <mat-icon class=\"expand_less\">info</mat-icon>\r\n      </span>\r\n    </ng-container>\r\n\r\n    <ng-container *ngIf=\"HasSelectedOption()\">\r\n      <ng-container *ngFor=\"let option of filter.options\">\r\n        <ng-container *ngIf=\"!option.hidden && (filter.selectedOption == 0 || option.id == filter.selectedOption)\">\r\n\r\n          <span class=\"name-span\">{{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, option.id) }}</span>\r\n          <span class=\"filteroption-label-unit\" *ngIf=\"filter.unit != null && filter.unit != ''\"> {{ filter.unit }}</span>\r\n        </ng-container>\r\n      </ng-container>\r\n\r\n      <div class=\"reset\" (click)=\"ResetSelection()\">\r\n        <mat-icon class=\"icon-position clear\" [inline]=\"true\">clear</mat-icon>\r\n      </div>\r\n    </ng-container>\r\n  </div>\r\n\r\n  <div *ngIf=\"!HasSelectedOption()\" class=\"select-options\">\r\n    <ng-container *ngFor=\"let option of filter.options\">\r\n      <div>\r\n        <ng-container *ngIf=\"option.imagePath != null && option.imagePath != ''\">\r\n          <div class=\"filter-option-image-div\" (click)=\"OpenPhoto(option.imagePath)\">\r\n            <img src=\"{{ option.imagePath }}\" class=\"filter-option-image\" />\r\n          </div>\r\n        </ng-container>\r\n        <button mat-raised-button (click)=\"SelectOption(option.id)\" class=\"fab-picture-select-button\">\r\n          <span class=\"name-span\">{{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, option.id) }}</span>\r\n          <span class=\"filteroption-label-unit\" *ngIf=\"filter.unit != null && filter.unit != ''\"> {{ filter.unit }}</span>\r\n        </button>        \r\n      </div>\r\n    </ng-container>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -7,6 +7,7 @@ import * as i3 from "@angular/common";
|
|
|
7
7
|
import * as i4 from "@angular/material/icon";
|
|
8
8
|
import * as i5 from "@angular/material/stepper";
|
|
9
9
|
import * as i6 from "../fab-input/fab-input.component";
|
|
10
|
+
import * as i7 from "../fab-input-code/fab-input-code.component";
|
|
10
11
|
class FabFiltersInputComponent {
|
|
11
12
|
FabrikantenService;
|
|
12
13
|
TranslateService;
|
|
@@ -49,12 +50,26 @@ class FabFiltersInputComponent {
|
|
|
49
50
|
}
|
|
50
51
|
return false;
|
|
51
52
|
}
|
|
53
|
+
ShowInputCode() {
|
|
54
|
+
if (this.FabrikantenService.FabrikantenSettingsViewModel?.inputCodeEnabled == true) {
|
|
55
|
+
return true;
|
|
56
|
+
}
|
|
57
|
+
return false;
|
|
58
|
+
}
|
|
59
|
+
GetHeaderName() {
|
|
60
|
+
if (this.FabrikantenService.FabrikantenSettingsViewModel.showProductNameInFiltersInput == true) {
|
|
61
|
+
if (this.FabrikantenService.FabrikantenViewModel.selectedProduct != null) {
|
|
62
|
+
return this.TranslateService.GetActiveValue(TranslationCategory.Product, TranslationSubCategory.Name, this.FabrikantenService.FabrikantenViewModel.selectedProduct.id);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
return this.TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.Filters);
|
|
66
|
+
}
|
|
52
67
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: FabFiltersInputComponent, deps: [{ token: i1.FabrikantenService }, { token: i2.TranslateService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
53
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: FabFiltersInputComponent, selector: "fab-filters-input", ngImport: i0, template: "<div class=\"filter-view-margin\">\r\n <div class=\"filter-view-header\">\r\n <div class=\"filter-view-header-h1\">\r\n <h1>{{
|
|
68
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: FabFiltersInputComponent, selector: "fab-filters-input", ngImport: i0, template: "<div class=\"filter-view-margin\">\r\n <div class=\"filter-view-header\">\r\n <div class=\"filter-view-header-h1\">\r\n <h1>{{ GetHeaderName() }}</h1>\r\n </div>\r\n <div *ngIf=\"ShowInputCode()\">\r\n <app-fab-input-code></app-fab-input-code>\r\n </div>\r\n <div class=\"filter-view-header-reset\" (click)=\"ResetAllFilters()\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.ResetFilters) }}\r\n </div>\r\n </div>\r\n\r\n <ng-container *ngIf=\"!ShowCategories()\">\r\n <ng-container *ngFor=\"let inputviewmodel of FabrikantenService.FabrikantenViewModel.inputs\">\r\n <app-fab-input [input]=\"inputviewmodel\"></app-fab-input>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"ShowAffectsOnlyBestek()\">\r\n <div class=\"affects-only-bestek\">\r\n <span><sup>1</sup></span>\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.AffectsOnlyBestek) }}\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n \r\n <div *ngIf=\"ShowCategories()\">\r\n <mat-stepper orientation=\"vertical\" [linear]=\"true\" #stepper>\r\n <ng-template matStepperIcon=\"edit\">\r\n <mat-icon>done</mat-icon>\r\n </ng-template>\r\n <!--<ng-container *ngFor=\"let cat of FabrikantenService.FabrikantenViewModel.filterCategories\">\r\n <ng-template matStepperIcon=\"{{ cat.id }}\">\r\n {{ cat.id }}\r\n\r\n <ng-container *ngIf=\"cat.canBeOpened\">\r\n \r\n </ng-container>\r\n </ng-template>\r\n </ng-container>-->\r\n <mat-step *ngFor=\"let cat of FabrikantenService.FabrikantenViewModel.filterCategories\" state=\"{{ cat.id }}\" [completed]=\"cat.completed\" [aria-labelledby]=\"cat.canBeOpened ? 'enabled' : 'disabled_af'\">\r\n <ng-template matStepLabel>\r\n <div class=\"step-name-div\">\r\n <div class=\"step-name-name\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.FilterCategory, TranslationSubCategory.Name, cat.id) }}\r\n </div>\r\n <div class=\"step-name-icon\" *ngIf=\"cat.icon != null\">\r\n <span class=\"helper\"></span>\r\n <img [src]=\"cat.icon\" class=\"filter-category-icon\" />\r\n </div>\r\n </div>\r\n </ng-template>\r\n\r\n <ng-container *ngFor=\"let inputviewmodel of cat.inputs\">\r\n <app-fab-input [input]=\"inputviewmodel\"></app-fab-input>\r\n </ng-container>\r\n </mat-step>\r\n </mat-stepper>\r\n </div>\r\n</div>\r\n", styles: ["fab-filters-input .mat-step-header[aria-labelledby=disabled_af]{cursor:not-allowed!important;opacity:.6}fab-filters-input .mat-step-header[aria-labelledby=enabled] .mat-step-icon{background-color:#000}fab-filters-input .mat-step-header[aria-labelledby=enabled] .mat-step-icon-selected{background-color:#3f51b5}fab-filters-input .filter-view-header{display:flex}fab-filters-input .filter-view-header-h1{flex:auto;text-transform:capitalize}fab-filters-input .step-name-icon{height:54px;white-space:nowrap;text-align:center;margin:auto 0}fab-filters-input .step-name-div{width:100%}fab-filters-input .filter-category-icon{height:48px;vertical-align:middle}fab-filters-input .mat-step-text-label{width:100%}fab-filters-input .mat-step-label{width:100%}fab-filters-input .step-name-name{line-height:56px}fab-filters-input .helper{display:inline-block;height:100%;vertical-align:middle}fab-filters-input .filter-view-margin{padding:10px}fab-filters-input .filter-view-header-reset{cursor:pointer}fab-filters-input .mat-vertical-content-container{padding-top:10px}fab-filters-input .mat-vertical-content{padding:0}fab-filters-input .step-name-div{display:flex}fab-filters-input .step-name-name{flex:auto}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5.MatStep, selector: "mat-step", inputs: ["color"], exportAs: ["matStep"] }, { kind: "directive", type: i5.MatStepLabel, selector: "[matStepLabel]" }, { kind: "component", type: i5.MatStepper, selector: "mat-stepper, mat-vertical-stepper, mat-horizontal-stepper, [matStepper]", inputs: ["selectedIndex", "disableRipple", "color", "labelPosition", "headerPosition", "animationDuration"], outputs: ["animationDone"], exportAs: ["matStepper", "matVerticalStepper", "matHorizontalStepper"] }, { kind: "directive", type: i5.MatStepperIcon, selector: "ng-template[matStepperIcon]", inputs: ["matStepperIcon"] }, { kind: "component", type: i6.FabInputComponent, selector: "app-fab-input", inputs: ["input"] }, { kind: "component", type: i7.FabInputCodeComponent, selector: "app-fab-input-code" }], encapsulation: i0.ViewEncapsulation.None });
|
|
54
69
|
}
|
|
55
70
|
export { FabFiltersInputComponent };
|
|
56
71
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: FabFiltersInputComponent, decorators: [{
|
|
57
72
|
type: Component,
|
|
58
|
-
args: [{ selector: 'fab-filters-input', encapsulation: ViewEncapsulation.None, template: "<div class=\"filter-view-margin\">\r\n <div class=\"filter-view-header\">\r\n <div class=\"filter-view-header-h1\">\r\n <h1>{{
|
|
73
|
+
args: [{ selector: 'fab-filters-input', encapsulation: ViewEncapsulation.None, template: "<div class=\"filter-view-margin\">\r\n <div class=\"filter-view-header\">\r\n <div class=\"filter-view-header-h1\">\r\n <h1>{{ GetHeaderName() }}</h1>\r\n </div>\r\n <div *ngIf=\"ShowInputCode()\">\r\n <app-fab-input-code></app-fab-input-code>\r\n </div>\r\n <div class=\"filter-view-header-reset\" (click)=\"ResetAllFilters()\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.ResetFilters) }}\r\n </div>\r\n </div>\r\n\r\n <ng-container *ngIf=\"!ShowCategories()\">\r\n <ng-container *ngFor=\"let inputviewmodel of FabrikantenService.FabrikantenViewModel.inputs\">\r\n <app-fab-input [input]=\"inputviewmodel\"></app-fab-input>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"ShowAffectsOnlyBestek()\">\r\n <div class=\"affects-only-bestek\">\r\n <span><sup>1</sup></span>\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.AffectsOnlyBestek) }}\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n \r\n <div *ngIf=\"ShowCategories()\">\r\n <mat-stepper orientation=\"vertical\" [linear]=\"true\" #stepper>\r\n <ng-template matStepperIcon=\"edit\">\r\n <mat-icon>done</mat-icon>\r\n </ng-template>\r\n <!--<ng-container *ngFor=\"let cat of FabrikantenService.FabrikantenViewModel.filterCategories\">\r\n <ng-template matStepperIcon=\"{{ cat.id }}\">\r\n {{ cat.id }}\r\n\r\n <ng-container *ngIf=\"cat.canBeOpened\">\r\n \r\n </ng-container>\r\n </ng-template>\r\n </ng-container>-->\r\n <mat-step *ngFor=\"let cat of FabrikantenService.FabrikantenViewModel.filterCategories\" state=\"{{ cat.id }}\" [completed]=\"cat.completed\" [aria-labelledby]=\"cat.canBeOpened ? 'enabled' : 'disabled_af'\">\r\n <ng-template matStepLabel>\r\n <div class=\"step-name-div\">\r\n <div class=\"step-name-name\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.FilterCategory, TranslationSubCategory.Name, cat.id) }}\r\n </div>\r\n <div class=\"step-name-icon\" *ngIf=\"cat.icon != null\">\r\n <span class=\"helper\"></span>\r\n <img [src]=\"cat.icon\" class=\"filter-category-icon\" />\r\n </div>\r\n </div>\r\n </ng-template>\r\n\r\n <ng-container *ngFor=\"let inputviewmodel of cat.inputs\">\r\n <app-fab-input [input]=\"inputviewmodel\"></app-fab-input>\r\n </ng-container>\r\n </mat-step>\r\n </mat-stepper>\r\n </div>\r\n</div>\r\n", styles: ["fab-filters-input .mat-step-header[aria-labelledby=disabled_af]{cursor:not-allowed!important;opacity:.6}fab-filters-input .mat-step-header[aria-labelledby=enabled] .mat-step-icon{background-color:#000}fab-filters-input .mat-step-header[aria-labelledby=enabled] .mat-step-icon-selected{background-color:#3f51b5}fab-filters-input .filter-view-header{display:flex}fab-filters-input .filter-view-header-h1{flex:auto;text-transform:capitalize}fab-filters-input .step-name-icon{height:54px;white-space:nowrap;text-align:center;margin:auto 0}fab-filters-input .step-name-div{width:100%}fab-filters-input .filter-category-icon{height:48px;vertical-align:middle}fab-filters-input .mat-step-text-label{width:100%}fab-filters-input .mat-step-label{width:100%}fab-filters-input .step-name-name{line-height:56px}fab-filters-input .helper{display:inline-block;height:100%;vertical-align:middle}fab-filters-input .filter-view-margin{padding:10px}fab-filters-input .filter-view-header-reset{cursor:pointer}fab-filters-input .mat-vertical-content-container{padding-top:10px}fab-filters-input .mat-vertical-content{padding:0}fab-filters-input .step-name-div{display:flex}fab-filters-input .step-name-name{flex:auto}\n"] }]
|
|
59
74
|
}], ctorParameters: function () { return [{ type: i1.FabrikantenService }, { type: i2.TranslateService }, { type: i0.ChangeDetectorRef }]; } });
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFiLWZpbHRlcnMtaW5wdXQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2FwcC9tb2R1bGVzL2ZhYnJpa2FudGVuY29yZS9jb21wb25lbnRzL2ZhYi1maWx0ZXJzLWlucHV0L2ZhYi1maWx0ZXJzLWlucHV0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kdWxlcy9mYWJyaWthbnRlbmNvcmUvY29tcG9uZW50cy9mYWItZmlsdGVycy1pbnB1dC9mYWItZmlsdGVycy1pbnB1dC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXFCLFNBQVMsRUFBVSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUd4RixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQzs7Ozs7Ozs7QUFFMUYsTUFNYSx3QkFBd0I7SUFXMUI7SUFDQTtJQUNBO0lBWFQsSUFBVyxtQkFBbUI7UUFDNUIsT0FBTyxtQkFBbUIsQ0FBQztJQUM3QixDQUFDO0lBRUQsSUFBVyxzQkFBc0I7UUFDL0IsT0FBTyxzQkFBc0IsQ0FBQztJQUNoQyxDQUFDO0lBRUQsWUFDUyxrQkFBc0MsRUFDdEMsZ0JBQWtDLEVBQ2xDLGlCQUFvQztRQUZwQyx1QkFBa0IsR0FBbEIsa0JBQWtCLENBQW9CO1FBQ3RDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7UUFDbEMsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFtQjtJQUFJLENBQUM7SUFFbEQsUUFBUTtJQUNSLENBQUM7SUFFTSxlQUFlO1FBQ3BCLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLENBQUM7SUFDbEUsQ0FBQztJQUVNLGNBQWM7UUFDbkIsSUFBSSxJQUFJLENBQUMsa0JBQWtCLENBQUMsb0JBQW9CLEVBQUUsZ0JBQWdCLElBQUksSUFBSSxFQUFFO1lBQzFFLElBQUksSUFBSSxDQUFDLGtCQUFrQixDQUFDLG9CQUFvQixDQUFDLGdCQUFnQixDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7Z0JBQzVFLElBQUksSUFBSSxDQUFDLGtCQUFrQixDQUFDLG9CQUFvQixDQUFDLGVBQWUsSUFBSSxJQUFJLEVBQUU7b0JBQ3hFLE9BQU8sSUFBSSxDQUFDO2lCQUNiO2FBQ0Y7U0FDRjtRQUVELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVNLHFCQUFxQjtRQUMxQixJQUFJLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxvQkFBb0IsRUFBRSxNQUFNLElBQUksSUFBSSxFQUFFO1lBQ2hFLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsa0JBQWtCLENBQUMsb0JBQW9CLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRTtnQkFDbkYsSUFBSSxJQUFJLENBQUMsa0JBQWtCLENBQUMsb0JBQW9CLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sSUFBSSxJQUFJLEVBQUU7b0JBQ3pFLElBQUksSUFBSSxDQUFDLGtCQUFrQixDQUFDLG9CQUFvQixDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEVBQUUsaUJBQWlCLElBQUksSUFBSSxFQUFFO3dCQUM1RixPQUFPLElBQUksQ0FBQztxQkFDYjtpQkFDRjthQUNGO1NBQ0Y7UUFFRCxPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7dUdBOUNVLHdCQUF3QjsyRkFBeEIsd0JBQXdCLHlEQ1hyQyw4b0VBZ0RBOztTRHJDYSx3QkFBd0I7MkZBQXhCLHdCQUF3QjtrQkFOcEMsU0FBUzsrQkFDRSxtQkFBbUIsaUJBR2QsaUJBQWlCLENBQUMsSUFBSSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIE9uSW5pdCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRmFicmlrYW50ZW5TZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvZmFicmlrYW50ZW4uc2VydmljZSc7XHJcbmltcG9ydCB7IFRyYW5zbGF0ZVNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy90cmFuc2xhdGUuc2VydmljZSc7XHJcbmltcG9ydCB7IFRyYW5zbGF0aW9uQ2F0ZWdvcnksIFRyYW5zbGF0aW9uU3ViQ2F0ZWdvcnkgfSBmcm9tICcuLi8uLi9zd2FnZ2VyL1N3YWdnZXJDbGllbnQnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdmYWItZmlsdGVycy1pbnB1dCcsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2ZhYi1maWx0ZXJzLWlucHV0LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9mYWItZmlsdGVycy1pbnB1dC5jb21wb25lbnQuc2NzcyddLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcclxufSlcclxuZXhwb3J0IGNsYXNzIEZhYkZpbHRlcnNJbnB1dENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcblxyXG4gIHB1YmxpYyBnZXQgVHJhbnNsYXRpb25DYXRlZ29yeSgpIHtcclxuICAgIHJldHVybiBUcmFuc2xhdGlvbkNhdGVnb3J5O1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldCBUcmFuc2xhdGlvblN1YkNhdGVnb3J5KCkge1xyXG4gICAgcmV0dXJuIFRyYW5zbGF0aW9uU3ViQ2F0ZWdvcnk7XHJcbiAgfVxyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHB1YmxpYyBGYWJyaWthbnRlblNlcnZpY2U6IEZhYnJpa2FudGVuU2VydmljZSxcclxuICAgIHB1YmxpYyBUcmFuc2xhdGVTZXJ2aWNlOiBUcmFuc2xhdGVTZXJ2aWNlLFxyXG4gICAgcHVibGljIENoYW5nZURldGVjdG9yUmVmOiBDaGFuZ2VEZXRlY3RvclJlZikgeyB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gIH1cclxuXHJcbiAgcHVibGljIFJlc2V0QWxsRmlsdGVycygpOiB2b2lkIHtcclxuICAgIHRoaXMuRmFicmlrYW50ZW5TZXJ2aWNlLlJlc2V0QWxsRmlsdGVycyh0aGlzLkNoYW5nZURldGVjdG9yUmVmKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBTaG93Q2F0ZWdvcmllcygpOiBib29sZWFuIHtcclxuICAgIGlmICh0aGlzLkZhYnJpa2FudGVuU2VydmljZS5GYWJyaWthbnRlblZpZXdNb2RlbD8uZmlsdGVyQ2F0ZWdvcmllcyAhPSBudWxsKSB7XHJcbiAgICAgIGlmICh0aGlzLkZhYnJpa2FudGVuU2VydmljZS5GYWJyaWthbnRlblZpZXdNb2RlbC5maWx0ZXJDYXRlZ29yaWVzLmxlbmd0aCA+IDApIHtcclxuICAgICAgICBpZiAodGhpcy5GYWJyaWthbnRlblNlcnZpY2UuRmFicmlrYW50ZW5WaWV3TW9kZWwuc2VsZWN0ZWRQcm9kdWN0ICE9IG51bGwpIHtcclxuICAgICAgICAgIHJldHVybiB0cnVlO1xyXG4gICAgICAgIH1cclxuICAgICAgfVxyXG4gICAgfVxyXG5cclxuICAgIHJldHVybiBmYWxzZTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBTaG93QWZmZWN0c09ubHlCZXN0ZWsoKTogYm9vbGVhbiB7XHJcbiAgICBpZiAodGhpcy5GYWJyaWthbnRlblNlcnZpY2UuRmFicmlrYW50ZW5WaWV3TW9kZWw/LmlucHV0cyAhPSBudWxsKSB7XHJcbiAgICAgIGZvciAodmFyIGkgPSAwOyBpIDwgdGhpcy5GYWJyaWthbnRlblNlcnZpY2UuRmFicmlrYW50ZW5WaWV3TW9kZWwuaW5wdXRzLmxlbmd0aDsgaSsrKSB7XHJcbiAgICAgICAgaWYgKHRoaXMuRmFicmlrYW50ZW5TZXJ2aWNlLkZhYnJpa2FudGVuVmlld01vZGVsLmlucHV0c1tpXS5maWx0ZXIgIT0gbnVsbCkge1xyXG4gICAgICAgICAgaWYgKHRoaXMuRmFicmlrYW50ZW5TZXJ2aWNlLkZhYnJpa2FudGVuVmlld01vZGVsLmlucHV0c1tpXS5maWx0ZXI/LmFmZmVjdHNPbmx5QmVzdGVrID09IHRydWUpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIGZhbHNlO1xyXG4gIH1cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwiZmlsdGVyLXZpZXctbWFyZ2luXCI+XHJcbiAgPGRpdiBjbGFzcz1cImZpbHRlci12aWV3LWhlYWRlclwiPlxyXG4gICAgPGRpdiBjbGFzcz1cImZpbHRlci12aWV3LWhlYWRlci1oMVwiPlxyXG4gICAgICA8aDE+e3sgVHJhbnNsYXRlU2VydmljZS5HZXRBY3RpdmVWYWx1ZShUcmFuc2xhdGlvbkNhdGVnb3J5LkNvbW1vbiwgVHJhbnNsYXRpb25TdWJDYXRlZ29yeS5GaWx0ZXJzKSB9fTwvaDE+XHJcbiAgICA8L2Rpdj5cclxuICAgIDxkaXYgY2xhc3M9XCJmaWx0ZXItdmlldy1oZWFkZXItcmVzZXRcIiAoY2xpY2spPVwiUmVzZXRBbGxGaWx0ZXJzKClcIj5cclxuICAgICAge3sgVHJhbnNsYXRlU2VydmljZS5HZXRBY3RpdmVWYWx1ZShUcmFuc2xhdGlvbkNhdGVnb3J5LkNvbW1vbiwgVHJhbnNsYXRpb25TdWJDYXRlZ29yeS5SZXNldEZpbHRlcnMpIH19XHJcbiAgICA8L2Rpdj5cclxuICA8L2Rpdj5cclxuXHJcbiAgPG5nLWNvbnRhaW5lciAqbmdJZj1cIiFTaG93Q2F0ZWdvcmllcygpXCI+XHJcbiAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBpbnB1dHZpZXdtb2RlbCBvZiBGYWJyaWthbnRlblNlcnZpY2UuRmFicmlrYW50ZW5WaWV3TW9kZWwuaW5wdXRzXCI+XHJcbiAgICAgIDxhcHAtZmFiLWlucHV0IFtpbnB1dF09XCJpbnB1dHZpZXdtb2RlbFwiPjwvYXBwLWZhYi1pbnB1dD5cclxuICAgIDwvbmctY29udGFpbmVyPlxyXG5cclxuICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJTaG93QWZmZWN0c09ubHlCZXN0ZWsoKVwiPlxyXG4gICAgICA8ZGl2IGNsYXNzPVwiYWZmZWN0cy1vbmx5LWJlc3Rla1wiPlxyXG4gICAgICAgIDxzcGFuPjxzdXA+MTwvc3VwPjwvc3Bhbj5cclxuICAgICAgICB7eyBUcmFuc2xhdGVTZXJ2aWNlLkdldEFjdGl2ZVZhbHVlKFRyYW5zbGF0aW9uQ2F0ZWdvcnkuQ29tbW9uLCBUcmFuc2xhdGlvblN1YkNhdGVnb3J5LkFmZmVjdHNPbmx5QmVzdGVrKSB9fVxyXG4gICAgICA8L2Rpdj5cclxuICAgIDwvbmctY29udGFpbmVyPlxyXG4gIDwvbmctY29udGFpbmVyPlxyXG4gIFxyXG4gIDxkaXYgKm5nSWY9XCJTaG93Q2F0ZWdvcmllcygpXCI+XHJcbiAgICA8bWF0LXN0ZXBwZXIgb3JpZW50YXRpb249XCJ2ZXJ0aWNhbFwiIFtsaW5lYXJdPVwidHJ1ZVwiICNzdGVwcGVyPlxyXG4gICAgICA8bmctdGVtcGxhdGUgbWF0U3RlcHBlckljb249XCJlZGl0XCI+XHJcbiAgICAgICAgPG1hdC1pY29uPmRvbmU8L21hdC1pY29uPlxyXG4gICAgICA8L25nLXRlbXBsYXRlPlxyXG4gICAgICA8bWF0LXN0ZXAgKm5nRm9yPVwibGV0IGNhdCBvZiBGYWJyaWthbnRlblNlcnZpY2UuRmFicmlrYW50ZW5WaWV3TW9kZWwuZmlsdGVyQ2F0ZWdvcmllc1wiIFtjb21wbGV0ZWRdPVwiY2F0LmNvbXBsZXRlZFwiIFtlZGl0YWJsZV09XCJ0cnVlXCI+XHJcbiAgICAgICAgPG5nLXRlbXBsYXRlIG1hdFN0ZXBMYWJlbD5cclxuICAgICAgICAgIDxkaXYgY2xhc3M9XCJzdGVwLW5hbWUtZGl2XCI+XHJcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJzdGVwLW5hbWUtbmFtZVwiPlxyXG4gICAgICAgICAgICAgIHt7IFRyYW5zbGF0ZVNlcnZpY2UuR2V0QWN0aXZlVmFsdWUoVHJhbnNsYXRpb25DYXRlZ29yeS5GaWx0ZXJDYXRlZ29yeSwgVHJhbnNsYXRpb25TdWJDYXRlZ29yeS5OYW1lLCBjYXQuaWQpIH19XHJcbiAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwic3RlcC1uYW1lLWljb25cIiAqbmdJZj1cImNhdC5pY29uICE9IG51bGxcIj5cclxuICAgICAgICAgICAgICA8c3BhbiBjbGFzcz1cImhlbHBlclwiPjwvc3Bhbj5cclxuICAgICAgICAgICAgICA8aW1nIFtzcmNdPVwiY2F0Lmljb25cIiBjbGFzcz1cImZpbHRlci1jYXRlZ29yeS1pY29uXCIgLz5cclxuICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8L25nLXRlbXBsYXRlPlxyXG5cclxuICAgICAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBpbnB1dHZpZXdtb2RlbCBvZiBjYXQuaW5wdXRzXCI+XHJcbiAgICAgICAgICA8YXBwLWZhYi1pbnB1dCBbaW5wdXRdPVwiaW5wdXR2aWV3bW9kZWxcIj48L2FwcC1mYWItaW5wdXQ+XHJcbiAgICAgICAgPC9uZy1jb250YWluZXI+XHJcbiAgICAgIDwvbWF0LXN0ZXA+XHJcbiAgICA8L21hdC1zdGVwcGVyPlxyXG4gIDwvZGl2PlxyXG48L2Rpdj5cclxuIl19
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fab-filters-input.component.js","sourceRoot":"","sources":["../../../../../../../../src/app/modules/fabrikantencore/components/fab-filters-input/fab-filters-input.component.ts","../../../../../../../../src/app/modules/fabrikantencore/components/fab-filters-input/fab-filters-input.component.html"],"names":[],"mappings":"AACA,OAAO,EAAqB,SAAS,EAAU,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAGxF,OAAO,EAAE,mBAAmB,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;;;;;;;;;AAE1F,MASa,wBAAwB;IAW1B;IACA;IACA;IAXT,IAAW,mBAAmB;QAC5B,OAAO,mBAAmB,CAAC;IAC7B,CAAC;IAED,IAAW,sBAAsB;QAC/B,OAAO,sBAAsB,CAAC;IAChC,CAAC;IAED,YACS,kBAAsC,EACtC,gBAAkC,EAClC,iBAAoC;QAFpC,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,sBAAiB,GAAjB,iBAAiB,CAAmB;IAAI,CAAC;IAElD,QAAQ;IACR,CAAC;IAEM,eAAe;QACpB,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAClE,CAAC;IAEM,cAAc;QACnB,IAAI,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,EAAE,gBAAgB,IAAI,IAAI,EAAE;YAC1E,IAAI,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE;gBAC5E,IAAI,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC,eAAe,IAAI,IAAI,EAAE;oBACxE,OAAO,IAAI,CAAC;iBACb;aACF;SACF;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAEM,qBAAqB;QAC1B,IAAI,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,EAAE,MAAM,IAAI,IAAI,EAAE;YAChE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACnF,IAAI,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,IAAI,EAAE;oBACzE,IAAI,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,iBAAiB,IAAI,IAAI,EAAE;wBAC5F,OAAO,IAAI,CAAC;qBACb;iBACF;aACF;SACF;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAEM,aAAa;QAClB,IAAI,IAAI,CAAC,kBAAkB,CAAC,4BAA4B,EAAE,gBAAgB,IAAI,IAAI,EAAE;YAClF,OAAO,IAAI,CAAC;SACb;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAEM,aAAa;QAElB,IAAI,IAAI,CAAC,kBAAkB,CAAC,4BAA4B,CAAC,6BAA6B,IAAI,IAAI,EAAE;YAC9F,IAAI,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC,eAAe,IAAI,IAAI,EAAE;gBACxE,OAAO,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,mBAAmB,CAAC,OAAO,EAAE,sBAAsB,CAAC,IAAI,EAAE,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;aACxK;SACF;QAED,OAAO,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,mBAAmB,CAAC,MAAM,EAAE,sBAAsB,CAAC,OAAO,CAAC,CAAC;IAC1G,CAAC;uGAjEU,wBAAwB;2FAAxB,wBAAwB,yDCfrC,0kFA4DA;;SD7Ca,wBAAwB;2FAAxB,wBAAwB;kBATpC,SAAS;+BACE,mBAAmB,iBAGd,iBAAiB,CAAC,IAAI","sourcesContent":["import { STEPPER_GLOBAL_OPTIONS } from '@angular/cdk/stepper';\r\nimport { ChangeDetectorRef, Component, OnInit, ViewEncapsulation } from '@angular/core';\r\nimport { FabrikantenService } from '../../services/fabrikanten.service';\r\nimport { TranslateService } from '../../services/translate.service';\r\nimport { TranslationCategory, TranslationSubCategory } from '../../swagger/SwaggerClient';\r\n\r\n@Component({\r\n  selector: 'fab-filters-input',\r\n  templateUrl: './fab-filters-input.component.html',\r\n  styleUrls: ['./fab-filters-input.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  //providers: [{\r\n  //  provide: STEPPER_GLOBAL_OPTIONS, useValue: { displayDefaultIndicatorType: false }\r\n  //}]\r\n})\r\nexport class FabFiltersInputComponent implements OnInit {\r\n\r\n  public get TranslationCategory() {\r\n    return TranslationCategory;\r\n  }\r\n\r\n  public get TranslationSubCategory() {\r\n    return TranslationSubCategory;\r\n  }\r\n\r\n  constructor(\r\n    public FabrikantenService: FabrikantenService,\r\n    public TranslateService: TranslateService,\r\n    public ChangeDetectorRef: ChangeDetectorRef) { }\r\n\r\n  ngOnInit(): void {\r\n  }\r\n\r\n  public ResetAllFilters(): void {\r\n    this.FabrikantenService.ResetAllFilters(this.ChangeDetectorRef);\r\n  }\r\n\r\n  public ShowCategories(): boolean {\r\n    if (this.FabrikantenService.FabrikantenViewModel?.filterCategories != null) {\r\n      if (this.FabrikantenService.FabrikantenViewModel.filterCategories.length > 0) {\r\n        if (this.FabrikantenService.FabrikantenViewModel.selectedProduct != null) {\r\n          return true;\r\n        }\r\n      }\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  public ShowAffectsOnlyBestek(): boolean {\r\n    if (this.FabrikantenService.FabrikantenViewModel?.inputs != null) {\r\n      for (var i = 0; i < this.FabrikantenService.FabrikantenViewModel.inputs.length; i++) {\r\n        if (this.FabrikantenService.FabrikantenViewModel.inputs[i].filter != null) {\r\n          if (this.FabrikantenService.FabrikantenViewModel.inputs[i].filter?.affectsOnlyBestek == true) {\r\n            return true;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  public ShowInputCode(): boolean {\r\n    if (this.FabrikantenService.FabrikantenSettingsViewModel?.inputCodeEnabled == true) {\r\n      return true;\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  public GetHeaderName(): string {\r\n\r\n    if (this.FabrikantenService.FabrikantenSettingsViewModel.showProductNameInFiltersInput == true) {\r\n      if (this.FabrikantenService.FabrikantenViewModel.selectedProduct != null) {\r\n        return this.TranslateService.GetActiveValue(TranslationCategory.Product, TranslationSubCategory.Name, this.FabrikantenService.FabrikantenViewModel.selectedProduct.id);\r\n      }\r\n    }\r\n\r\n    return this.TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.Filters);\r\n  }\r\n}\r\n","<div class=\"filter-view-margin\">\r\n  <div class=\"filter-view-header\">\r\n    <div class=\"filter-view-header-h1\">\r\n      <h1>{{ GetHeaderName() }}</h1>\r\n    </div>\r\n    <div *ngIf=\"ShowInputCode()\">\r\n      <app-fab-input-code></app-fab-input-code>\r\n    </div>\r\n    <div class=\"filter-view-header-reset\" (click)=\"ResetAllFilters()\">\r\n      {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.ResetFilters) }}\r\n    </div>\r\n  </div>\r\n\r\n  <ng-container *ngIf=\"!ShowCategories()\">\r\n    <ng-container *ngFor=\"let inputviewmodel of FabrikantenService.FabrikantenViewModel.inputs\">\r\n      <app-fab-input [input]=\"inputviewmodel\"></app-fab-input>\r\n    </ng-container>\r\n\r\n    <ng-container *ngIf=\"ShowAffectsOnlyBestek()\">\r\n      <div class=\"affects-only-bestek\">\r\n        <span><sup>1</sup></span>\r\n        {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.AffectsOnlyBestek) }}\r\n      </div>\r\n    </ng-container>\r\n  </ng-container>\r\n  \r\n  <div *ngIf=\"ShowCategories()\">\r\n    <mat-stepper orientation=\"vertical\" [linear]=\"true\" #stepper>\r\n      <ng-template matStepperIcon=\"edit\">\r\n        <mat-icon>done</mat-icon>\r\n      </ng-template>\r\n      <!--<ng-container *ngFor=\"let cat of FabrikantenService.FabrikantenViewModel.filterCategories\">\r\n        <ng-template matStepperIcon=\"{{ cat.id }}\">\r\n          {{ cat.id }}\r\n\r\n          <ng-container *ngIf=\"cat.canBeOpened\">\r\n            \r\n          </ng-container>\r\n        </ng-template>\r\n      </ng-container>-->\r\n      <mat-step *ngFor=\"let cat of FabrikantenService.FabrikantenViewModel.filterCategories\" state=\"{{ cat.id }}\" [completed]=\"cat.completed\" [aria-labelledby]=\"cat.canBeOpened ? 'enabled' : 'disabled_af'\">\r\n        <ng-template matStepLabel>\r\n          <div class=\"step-name-div\">\r\n            <div class=\"step-name-name\">\r\n              {{ TranslateService.GetActiveValue(TranslationCategory.FilterCategory, TranslationSubCategory.Name, cat.id) }}\r\n            </div>\r\n            <div class=\"step-name-icon\" *ngIf=\"cat.icon != null\">\r\n              <span class=\"helper\"></span>\r\n              <img [src]=\"cat.icon\" class=\"filter-category-icon\" />\r\n            </div>\r\n          </div>\r\n        </ng-template>\r\n\r\n        <ng-container *ngFor=\"let inputviewmodel of cat.inputs\">\r\n          <app-fab-input [input]=\"inputviewmodel\"></app-fab-input>\r\n        </ng-container>\r\n      </mat-step>\r\n    </mat-stepper>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
import { Component, Input, Output, EventEmitter, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { Validators } from '@angular/forms';
|
|
3
|
+
import { FormInputType, FabrikantenSetFormRequest, TranslationCategory, TranslationSubCategory } from '../../swagger/SwaggerClient';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/forms";
|
|
6
|
+
import * as i2 from "../../swagger/SwaggerClient";
|
|
7
|
+
import * as i3 from "../../services/fabrikanten.service";
|
|
8
|
+
import * as i4 from "../../services/translate.service";
|
|
9
|
+
import * as i5 from "@angular/common";
|
|
10
|
+
import * as i6 from "@angular/material/legacy-form-field";
|
|
11
|
+
import * as i7 from "@angular/material/legacy-input";
|
|
12
|
+
import * as i8 from "@angular/material/legacy-button";
|
|
13
|
+
import * as i9 from "@angular/material/legacy-checkbox";
|
|
14
|
+
import * as i10 from "@angular/material/legacy-select";
|
|
15
|
+
import * as i11 from "@angular/material/legacy-core";
|
|
16
|
+
class FabFormComponent {
|
|
17
|
+
formBuilder;
|
|
18
|
+
FabrikantenApiClient;
|
|
19
|
+
FabrikantenService;
|
|
20
|
+
TranslateService;
|
|
21
|
+
ChangeDetectorRef;
|
|
22
|
+
_form;
|
|
23
|
+
get form() {
|
|
24
|
+
return this._form;
|
|
25
|
+
}
|
|
26
|
+
set form(value) {
|
|
27
|
+
this._form = value;
|
|
28
|
+
this.FormGroup = this.formBuilder.group({});
|
|
29
|
+
var cats = this.form.formCategories;
|
|
30
|
+
if (cats != null) {
|
|
31
|
+
for (var i = 0; i < cats.length; i++) {
|
|
32
|
+
var rows = cats[i].rows;
|
|
33
|
+
if (rows != null) {
|
|
34
|
+
for (var j = 0; j < rows.length; j++) {
|
|
35
|
+
var inputs = rows[j].inputs;
|
|
36
|
+
if (inputs != null) {
|
|
37
|
+
for (var p = 0; p < inputs.length; p++) {
|
|
38
|
+
var ValidatorsArray = new Array();
|
|
39
|
+
if (inputs[p].formInputType == FormInputType.Email) {
|
|
40
|
+
ValidatorsArray.push(Validators.email);
|
|
41
|
+
}
|
|
42
|
+
if (inputs[p].required) {
|
|
43
|
+
ValidatorsArray.push(Validators.required);
|
|
44
|
+
}
|
|
45
|
+
if (inputs[p].formInputType == FormInputType.Dropdown) {
|
|
46
|
+
this.FormGroup.addControl(inputs[p].name + "", this.formBuilder.control(inputs[p].selectedOption?.id, ValidatorsArray));
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
this.FormGroup.addControl(inputs[p].name + "", this.formBuilder.control(inputs[p].value, ValidatorsArray));
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
alert('error');
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
completed = new EventEmitter();
|
|
62
|
+
//@Output() cancel: EventEmitter<void> = new EventEmitter<void>();
|
|
63
|
+
FormGroup;
|
|
64
|
+
get TranslationCategory() {
|
|
65
|
+
return TranslationCategory;
|
|
66
|
+
}
|
|
67
|
+
get TranslationSubCategory() {
|
|
68
|
+
return TranslationSubCategory;
|
|
69
|
+
}
|
|
70
|
+
constructor(formBuilder, FabrikantenApiClient, FabrikantenService, TranslateService, ChangeDetectorRef) {
|
|
71
|
+
this.formBuilder = formBuilder;
|
|
72
|
+
this.FabrikantenApiClient = FabrikantenApiClient;
|
|
73
|
+
this.FabrikantenService = FabrikantenService;
|
|
74
|
+
this.TranslateService = TranslateService;
|
|
75
|
+
this.ChangeDetectorRef = ChangeDetectorRef;
|
|
76
|
+
}
|
|
77
|
+
OnSubmit() {
|
|
78
|
+
if (this.FormGroup.valid) {
|
|
79
|
+
var request = new FabrikantenSetFormRequest();
|
|
80
|
+
request.sessionId = this.FabrikantenService.FabrikantenViewModel.sessionId;
|
|
81
|
+
request.formId = this.form.id;
|
|
82
|
+
this.FabrikantenApiClient.setForm(request).subscribe(() => {
|
|
83
|
+
this.FabrikantenService.ReloadModel(this.ChangeDetectorRef, undefined, () => {
|
|
84
|
+
this.completed.emit();
|
|
85
|
+
});
|
|
86
|
+
}, (error) => {
|
|
87
|
+
alert('An unexpected error occured');
|
|
88
|
+
this.ChangeDetectorRef.detectChanges();
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
Close() {
|
|
93
|
+
this.completed.emit();
|
|
94
|
+
}
|
|
95
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: FabFormComponent, deps: [{ token: i1.FormBuilder }, { token: i2.FabrikantenApiClient }, { token: i3.FabrikantenService }, { token: i4.TranslateService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
96
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: FabFormComponent, selector: "app-fab-form", inputs: { form: "form" }, outputs: { completed: "completed" }, ngImport: i0, template: "<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", styles: ["app-fab-form .mat-form-field-wrapper{padding-bottom:0}app-fab-form .mat-form-field-underline{bottom:0}app-fab-form .displayflex{display:flex}app-fab-form .form-cat-name{border-bottom:1px solid #000;font-size:20px;padding:5px}app-fab-form .form-cat-input{padding:3px;width:100%}app-fab-form .form-button-row{text-align:right}app-fab-form .form-button-row-button{margin:5px}app-fab-form .full-width{width:100%}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.MatLegacyError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i6.MatLegacyFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i6.MatLegacyLabel, selector: "mat-label" }, { kind: "directive", type: i7.MatLegacyInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", exportAs: ["matInput"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", 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]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i8.MatLegacyButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i9.MatLegacyCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "component", type: i10.MatLegacySelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i11.MatLegacyOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
97
|
+
}
|
|
98
|
+
export { FabFormComponent };
|
|
99
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: FabFormComponent, decorators: [{
|
|
100
|
+
type: Component,
|
|
101
|
+
args: [{ selector: 'app-fab-form', encapsulation: ViewEncapsulation.None, template: "<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", styles: ["app-fab-form .mat-form-field-wrapper{padding-bottom:0}app-fab-form .mat-form-field-underline{bottom:0}app-fab-form .displayflex{display:flex}app-fab-form .form-cat-name{border-bottom:1px solid #000;font-size:20px;padding:5px}app-fab-form .form-cat-input{padding:3px;width:100%}app-fab-form .form-button-row{text-align:right}app-fab-form .form-button-row-button{margin:5px}app-fab-form .full-width{width:100%}\n"] }]
|
|
102
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.FabrikantenApiClient }, { type: i3.FabrikantenService }, { type: i4.TranslateService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { form: [{
|
|
103
|
+
type: Input
|
|
104
|
+
}], completed: [{
|
|
105
|
+
type: Output
|
|
106
|
+
}] } });
|
|
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":"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","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"]}
|
|
@@ -1,103 +1,37 @@
|
|
|
1
|
-
import { Component, Inject
|
|
1
|
+
import { Component, Inject } from '@angular/core';
|
|
2
2
|
import { MAT_LEGACY_DIALOG_DATA as MAT_DIALOG_DATA } from '@angular/material/legacy-dialog';
|
|
3
|
-
import { FormInputType, FabrikantenSetFormRequest, TranslationCategory, TranslationSubCategory } from '../../swagger/SwaggerClient';
|
|
4
|
-
import { Validators } from '@angular/forms';
|
|
5
3
|
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "@angular/
|
|
7
|
-
import * as i2 from "
|
|
8
|
-
import * as i3 from "
|
|
9
|
-
import * as i4 from "../../services/fabrikanten.service";
|
|
10
|
-
import * as i5 from "../../services/translate.service";
|
|
11
|
-
import * as i6 from "@angular/common";
|
|
12
|
-
import * as i7 from "@angular/material/legacy-form-field";
|
|
13
|
-
import * as i8 from "@angular/material/legacy-input";
|
|
14
|
-
import * as i9 from "@angular/material/legacy-button";
|
|
15
|
-
import * as i10 from "@angular/material/legacy-select";
|
|
16
|
-
import * as i11 from "@angular/material/legacy-core";
|
|
4
|
+
import * as i1 from "@angular/material/legacy-dialog";
|
|
5
|
+
import * as i2 from "../../services/translate.service";
|
|
6
|
+
import * as i3 from "../fab-form/fab-form.component";
|
|
17
7
|
class FabFormDialogComponent {
|
|
18
|
-
formBuilder;
|
|
19
8
|
dialogRef;
|
|
20
9
|
data;
|
|
21
|
-
FabrikantenApiClient;
|
|
22
|
-
FabrikantenService;
|
|
23
10
|
TranslateService;
|
|
24
11
|
ChangeDetectorRef;
|
|
25
12
|
Form;
|
|
26
|
-
|
|
27
|
-
get TranslationCategory() {
|
|
28
|
-
return TranslationCategory;
|
|
29
|
-
}
|
|
30
|
-
get TranslationSubCategory() {
|
|
31
|
-
return TranslationSubCategory;
|
|
32
|
-
}
|
|
33
|
-
constructor(formBuilder, dialogRef, data, FabrikantenApiClient, FabrikantenService, TranslateService, ChangeDetectorRef) {
|
|
34
|
-
this.formBuilder = formBuilder;
|
|
13
|
+
constructor(dialogRef, data, TranslateService, ChangeDetectorRef) {
|
|
35
14
|
this.dialogRef = dialogRef;
|
|
36
15
|
this.data = data;
|
|
37
|
-
this.FabrikantenApiClient = FabrikantenApiClient;
|
|
38
|
-
this.FabrikantenService = FabrikantenService;
|
|
39
16
|
this.TranslateService = TranslateService;
|
|
40
17
|
this.ChangeDetectorRef = ChangeDetectorRef;
|
|
41
|
-
this.FormGroup = this.formBuilder.group({});
|
|
42
18
|
this.Form = data.form;
|
|
43
|
-
var cats = this.Form.formCategories;
|
|
44
|
-
if (cats != null) {
|
|
45
|
-
for (var i = 0; i < cats.length; i++) {
|
|
46
|
-
var rows = cats[i].rows;
|
|
47
|
-
if (rows != null) {
|
|
48
|
-
for (var j = 0; j < rows.length; j++) {
|
|
49
|
-
var inputs = rows[j].inputs;
|
|
50
|
-
if (inputs != null) {
|
|
51
|
-
for (var p = 0; p < inputs.length; p++) {
|
|
52
|
-
var ValidatorsArray = new Array();
|
|
53
|
-
if (inputs[p].formInputType == FormInputType.Email) {
|
|
54
|
-
ValidatorsArray.push(Validators.email);
|
|
55
|
-
}
|
|
56
|
-
if (inputs[p].required) {
|
|
57
|
-
ValidatorsArray.push(Validators.required);
|
|
58
|
-
}
|
|
59
|
-
if (inputs[p].formInputType == FormInputType.Dropdown) {
|
|
60
|
-
this.FormGroup.addControl(inputs[p].name + "", this.formBuilder.control(inputs[p].selectedOption?.id, ValidatorsArray));
|
|
61
|
-
}
|
|
62
|
-
else {
|
|
63
|
-
this.FormGroup.addControl(inputs[p].name + "", this.formBuilder.control(inputs[p].value, ValidatorsArray));
|
|
64
|
-
}
|
|
65
|
-
//this.FormGroup.addControl('controlName',
|
|
66
|
-
// this.formBuilder.control({ disabled: false, value: controlValue }, validators, asyncValidators));
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
OnSubmit() {
|
|
75
|
-
if (this.FormGroup.valid) {
|
|
76
|
-
var request = new FabrikantenSetFormRequest();
|
|
77
|
-
request.sessionId = this.FabrikantenService.FabrikantenViewModel.sessionId;
|
|
78
|
-
request.formId = this.Form.id;
|
|
79
|
-
this.FabrikantenApiClient.setForm(request).subscribe(() => {
|
|
80
|
-
this.FabrikantenService.ReloadModel(this.ChangeDetectorRef, undefined, () => {
|
|
81
|
-
this.dialogRef.close();
|
|
82
|
-
});
|
|
83
|
-
}, (error) => {
|
|
84
|
-
alert('An unexpected error occured');
|
|
85
|
-
this.ChangeDetectorRef.detectChanges();
|
|
86
|
-
});
|
|
87
|
-
}
|
|
88
19
|
}
|
|
20
|
+
//public OnSubmit(): void {
|
|
21
|
+
// this.dialogRef.close();
|
|
22
|
+
//}
|
|
89
23
|
Close() {
|
|
90
24
|
this.dialogRef.close();
|
|
91
25
|
}
|
|
92
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: FabFormDialogComponent, deps: [{ token: i1.
|
|
93
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: FabFormDialogComponent, selector: "app-fab-form-dialog", ngImport: i0, template: "<div
|
|
26
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: FabFormDialogComponent, deps: [{ token: i1.MatLegacyDialogRef }, { token: MAT_DIALOG_DATA }, { token: i2.TranslateService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
27
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: FabFormDialogComponent, selector: "app-fab-form-dialog", ngImport: i0, template: "<div class=\"form-container\">\n <app-fab-form [form]=\"Form\" (completed)=\"Close()\"></app-fab-form>\n</div>\n", styles: [".form-container{width:500px}\n"], dependencies: [{ kind: "component", type: i3.FabFormComponent, selector: "app-fab-form", inputs: ["form"], outputs: ["completed"] }] });
|
|
94
28
|
}
|
|
95
29
|
export { FabFormDialogComponent };
|
|
96
30
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: FabFormDialogComponent, decorators: [{
|
|
97
31
|
type: Component,
|
|
98
|
-
args: [{ selector: 'app-fab-form-dialog',
|
|
99
|
-
}], ctorParameters: function () { return [{ type: i1.
|
|
32
|
+
args: [{ selector: 'app-fab-form-dialog', template: "<div class=\"form-container\">\n <app-fab-form [form]=\"Form\" (completed)=\"Close()\"></app-fab-form>\n</div>\n", styles: [".form-container{width:500px}\n"] }]
|
|
33
|
+
}], ctorParameters: function () { return [{ type: i1.MatLegacyDialogRef }, { type: undefined, decorators: [{
|
|
100
34
|
type: Inject,
|
|
101
35
|
args: [MAT_DIALOG_DATA]
|
|
102
|
-
}] }, { type:
|
|
103
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fab-form-dialog.component.js","sourceRoot":"","sources":["../../../../../../../../src/app/modules/fabrikantencore/components/fab-form-dialog/fab-form-dialog.component.ts","../../../../../../../../src/app/modules/fabrikantencore/components/fab-form-dialog/fab-form-dialog.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,iBAAiB,EAAqB,MAAM,eAAe,CAAC;AACxF,OAAO,EAAsC,sBAAsB,IAAI,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAChI,OAAO,EAA4B,aAAa,EAAwB,yBAAyB,EAAE,mBAAmB,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AACpL,OAAO,EAAuC,UAAU,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;;;;;AAIjF,MAMa,sBAAsB;IAcvB;IACD;IACyB;IACxB;IACA;IACD;IACC;IAlBH,IAAI,CAA2B;IAC/B,SAAS,CAAY;IAE5B,IAAW,mBAAmB;QAC5B,OAAO,mBAAmB,CAAC;IAC7B,CAAC;IAED,IAAW,sBAAsB;QAC/B,OAAO,sBAAsB,CAAC;IAChC,CAAC;IAED,YACU,WAAwB,EACzB,SAA+C,EACtB,IAAS,EACjC,oBAA0C,EAC1C,kBAAsC,EACvC,gBAAkC,EACjC,iBAAoC;QANpC,gBAAW,GAAX,WAAW,CAAa;QACzB,cAAS,GAAT,SAAS,CAAsC;QACtB,SAAI,GAAJ,IAAI,CAAK;QACjC,yBAAoB,GAApB,oBAAoB,CAAsB;QAC1C,uBAAkB,GAAlB,kBAAkB,CAAoB;QACvC,qBAAgB,GAAhB,gBAAgB,CAAkB;QACjC,sBAAiB,GAAjB,iBAAiB,CAAmB;QAE5C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,CAAC,CAAA;QAC3C,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QAEtB,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;gCAID,0CAA0C;gCAC1C,qGAAqG;6BACtG;yBACF;qBACF;iBACF;aACF;SACF;IACH,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,KAAK,EAAE,CAAC;gBACzB,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,KAAK,EAAE,CAAC;IACzB,CAAC;uGAxFU,sBAAsB,+EAgBvB,eAAe;2FAhBd,sBAAsB,2DCbnC,y3FA2DA;;SD9Ca,sBAAsB;2FAAtB,sBAAsB;kBANlC,SAAS;+BACE,qBAAqB,iBAGhB,iBAAiB,CAAC,IAAI;;0BAkBlC,MAAM;2BAAC,eAAe","sourcesContent":["import { Component, Inject, ViewEncapsulation, ChangeDetectorRef } from '@angular/core';\nimport { MatLegacyDialogRef as MatDialogRef, MAT_LEGACY_DIALOG_DATA as MAT_DIALOG_DATA } from '@angular/material/legacy-dialog';\nimport { FabrikantenFormViewModel, FormInputType, FabrikantenApiClient, FabrikantenSetFormRequest, TranslationCategory, TranslationSubCategory } from '../../swagger/SwaggerClient';\r\nimport { FormBuilder, FormGroup, ValidatorFn, Validators } from '@angular/forms';\r\nimport { FabrikantenService } from '../../services/fabrikanten.service';\r\nimport { TranslateService } from '../../services/translate.service';\r\n\n@Component({\n  selector: 'app-fab-form-dialog',\n  templateUrl: './fab-form-dialog.component.html',\n  styleUrls: ['./fab-form-dialog.component.scss'],\n  encapsulation: ViewEncapsulation.None\n})\nexport class FabFormDialogComponent {\n\n  public Form: FabrikantenFormViewModel;\n  public FormGroup: FormGroup;\r\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    public dialogRef: MatDialogRef<FabFormDialogComponent>,\n    @Inject(MAT_DIALOG_DATA) public data: any,\n    private FabrikantenApiClient: FabrikantenApiClient,\n    private FabrikantenService: FabrikantenService,\n    public TranslateService: TranslateService,\n    private ChangeDetectorRef: ChangeDetectorRef\n  ) {\n    this.FormGroup = this.formBuilder.group({})\n    this.Form = data.form;\n\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                //this.FormGroup.addControl('controlName',\r\n                //  this.formBuilder.control({ disabled: false, value: controlValue }, validators, asyncValidators));\r\n              }\r\n            }\r\n          }\r\n        }\r\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.dialogRef.close();\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.dialogRef.close();\r\n  }\n}\n","<div style=\"width: 500px;\">\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 == 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</div>\n"]}
|
|
36
|
+
}] }, { type: i2.TranslateService }, { type: i0.ChangeDetectorRef }]; } });
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFiLWZvcm0tZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kdWxlcy9mYWJyaWthbnRlbmNvcmUvY29tcG9uZW50cy9mYWItZm9ybS1kaWFsb2cvZmFiLWZvcm0tZGlhbG9nLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kdWxlcy9mYWJyaWthbnRlbmNvcmUvY29tcG9uZW50cy9mYWItZm9ybS1kaWFsb2cvZmFiLWZvcm0tZGlhbG9nLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUF3QyxNQUFNLGVBQWUsQ0FBQztBQUN4RixPQUFPLEVBQXNDLHNCQUFzQixJQUFJLGVBQWUsRUFBRSxNQUFNLGlDQUFpQyxDQUFDOzs7OztBQUloSSxNQUthLHNCQUFzQjtJQUl4QjtJQUN5QjtJQUN6QjtJQUNDO0lBTkgsSUFBSSxDQUEyQjtJQUV0QyxZQUNTLFNBQStDLEVBQ3RCLElBQVMsRUFDbEMsZ0JBQWtDLEVBQ2pDLGlCQUFvQztRQUhyQyxjQUFTLEdBQVQsU0FBUyxDQUFzQztRQUN0QixTQUFJLEdBQUosSUFBSSxDQUFLO1FBQ2xDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7UUFDakMsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFtQjtRQUU1QyxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDeEIsQ0FBQztJQUVELDJCQUEyQjtJQUMzQiwyQkFBMkI7SUFDM0IsR0FBRztJQUVJLEtBQUs7UUFDVixJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ3pCLENBQUM7dUdBbEJVLHNCQUFzQixvREFLdkIsZUFBZTsyRkFMZCxzQkFBc0IsMkRDVm5DLG1IQUdBOztTRE9hLHNCQUFzQjsyRkFBdEIsc0JBQXNCO2tCQUxsQyxTQUFTOytCQUNFLHFCQUFxQjs7MEJBUzVCLE1BQU07MkJBQUMsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5qZWN0LCBWaWV3RW5jYXBzdWxhdGlvbiwgQ2hhbmdlRGV0ZWN0b3JSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdExlZ2FjeURpYWxvZ1JlZiBhcyBNYXREaWFsb2dSZWYsIE1BVF9MRUdBQ1lfRElBTE9HX0RBVEEgYXMgTUFUX0RJQUxPR19EQVRBIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvbGVnYWN5LWRpYWxvZyc7XG5pbXBvcnQgeyBGYWJyaWthbnRlbkZvcm1WaWV3TW9kZWwgfSBmcm9tICcuLi8uLi9zd2FnZ2VyL1N3YWdnZXJDbGllbnQnO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGVTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvdHJhbnNsYXRlLnNlcnZpY2UnO1xyXG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FwcC1mYWItZm9ybS1kaWFsb2cnLFxuICB0ZW1wbGF0ZVVybDogJy4vZmFiLWZvcm0tZGlhbG9nLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZmFiLWZvcm0tZGlhbG9nLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgRmFiRm9ybURpYWxvZ0NvbXBvbmVudCB7XG4gIHB1YmxpYyBGb3JtOiBGYWJyaWthbnRlbkZvcm1WaWV3TW9kZWw7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHVibGljIGRpYWxvZ1JlZjogTWF0RGlhbG9nUmVmPEZhYkZvcm1EaWFsb2dDb21wb25lbnQ+LFxuICAgIEBJbmplY3QoTUFUX0RJQUxPR19EQVRBKSBwdWJsaWMgZGF0YTogYW55LFxuICAgIHB1YmxpYyBUcmFuc2xhdGVTZXJ2aWNlOiBUcmFuc2xhdGVTZXJ2aWNlLFxuICAgIHByaXZhdGUgQ2hhbmdlRGV0ZWN0b3JSZWY6IENoYW5nZURldGVjdG9yUmVmXG4gICkge1xuICAgIHRoaXMuRm9ybSA9IGRhdGEuZm9ybTtcbiAgfVxuXG4gIC8vcHVibGljIE9uU3VibWl0KCk6IHZvaWQge1xyXG4gIC8vICB0aGlzLmRpYWxvZ1JlZi5jbG9zZSgpO1xyXG4gIC8vfVxuXG4gIHB1YmxpYyBDbG9zZSgpOiB2b2lkIHtcbiAgICB0aGlzLmRpYWxvZ1JlZi5jbG9zZSgpO1xyXG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJmb3JtLWNvbnRhaW5lclwiPlxuICA8YXBwLWZhYi1mb3JtIFtmb3JtXT1cIkZvcm1cIiAoY29tcGxldGVkKT1cIkNsb3NlKClcIj48L2FwcC1mYWItZm9ybT5cbjwvZGl2PlxuIl19
|