fabrikantencore 2.27.6 → 2.28.2

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.
@@ -0,0 +1,357 @@
1
+ import { Component } from '@angular/core';
2
+ import { TranslationCategory, TranslationSubCategory, TextureRequestModel, TextureMixRequestModel } 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/mobile.service";
6
+ import * as i2 from "../../services/fabrikanten.service";
7
+ import * as i3 from "../../services/translate.service";
8
+ import * as i4 from "@angular/router";
9
+ import * as i5 from "@angular/material/legacy-dialog";
10
+ import * as i6 from "../../swagger/SwaggerClient";
11
+ import * as i7 from "@angular/common";
12
+ import * as i8 from "@angular/material/legacy-form-field";
13
+ import * as i9 from "@angular/material/legacy-input";
14
+ import * as i10 from "@angular/forms";
15
+ import * as i11 from "@angular/material/legacy-button";
16
+ import * as i12 from "@angular/material/legacy-card";
17
+ import * as i13 from "@angular/material/legacy-progress-spinner";
18
+ import * as i14 from "@angular/material/legacy-select";
19
+ import * as i15 from "@angular/material/legacy-core";
20
+ import * as i16 from "../inputs/fab-input/fab-input.component";
21
+ class FabTextureConfiguratorComponent {
22
+ MobileService;
23
+ FabrikantenService;
24
+ TranslateService;
25
+ ActivatedRoute;
26
+ dialog;
27
+ TextureApiClient;
28
+ ChangeDetectorRef;
29
+ get TranslationCategory() {
30
+ return TranslationCategory;
31
+ }
32
+ get TranslationSubCategory() {
33
+ return TranslationSubCategory;
34
+ }
35
+ SelectedVerbandId = -1;
36
+ SelectedVoegId = -1;
37
+ Lintvoeg = "12";
38
+ Stootvoeg = "10";
39
+ Loading = false;
40
+ mShowMix = false;
41
+ TextureResponseModel = null;
42
+ TextureMixResponseModel = null;
43
+ Steen2 = null;
44
+ Steen3 = null;
45
+ Steen4 = null;
46
+ Steen5 = null;
47
+ constructor(MobileService, FabrikantenService, TranslateService, ActivatedRoute, dialog, TextureApiClient, ChangeDetectorRef) {
48
+ this.MobileService = MobileService;
49
+ this.FabrikantenService = FabrikantenService;
50
+ this.TranslateService = TranslateService;
51
+ this.ActivatedRoute = ActivatedRoute;
52
+ this.dialog = dialog;
53
+ this.TextureApiClient = TextureApiClient;
54
+ this.ChangeDetectorRef = ChangeDetectorRef;
55
+ this.TranslateService.ProcessParameters(this.ActivatedRoute, this.ChangeDetectorRef);
56
+ }
57
+ ngDoCheck() {
58
+ this.SelectFirstChoices();
59
+ this.CleanChoices();
60
+ }
61
+ ngOnInit() {
62
+ this.FabrikantenService.LoadFabrikantenViewModel(this.ChangeDetectorRef, this.ActivatedRoute);
63
+ }
64
+ SelectFirstChoices() {
65
+ if (this.SelectedVerbandId == -1) {
66
+ if (this.FabrikantenService.FabrikantenViewModel?.products != undefined && this.FabrikantenService.FabrikantenViewModel.products.length > 0) {
67
+ for (var i = 0; i < this.FabrikantenService.FabrikantenViewModel.products.length; i++) {
68
+ if (this.FabrikantenService.FabrikantenViewModel.products[i].id == 62) { // halfsteensverband
69
+ this.SelectedVerbandId = this.FabrikantenService.FabrikantenViewModel.products[i].id;
70
+ }
71
+ }
72
+ if (this.SelectedVerbandId == -1) {
73
+ this.SelectedVerbandId = this.FabrikantenService.FabrikantenViewModel.products[0].id;
74
+ }
75
+ }
76
+ }
77
+ if (this.SelectedVoegId == -1) {
78
+ var voeg = this.GetVoeg();
79
+ if (voeg?.filter?.options != undefined && voeg.filter.options.length > 0) {
80
+ this.SelectedVoegId = voeg.filter?.options[0].id;
81
+ }
82
+ }
83
+ }
84
+ CleanChoices() {
85
+ if (!this.IsSteenSelected()) {
86
+ this.mShowMix = false;
87
+ this.TextureMixResponseModel = null;
88
+ this.TextureResponseModel = null;
89
+ this.Steen2 = null;
90
+ this.Steen3 = null;
91
+ this.Steen4 = null;
92
+ this.Steen5 = null;
93
+ }
94
+ }
95
+ TextuurGenereren() {
96
+ this.mShowMix = false;
97
+ var steenid = this.GetSteen()?.filter?.selectedOption;
98
+ if (steenid != undefined) {
99
+ this.Loading = true;
100
+ var request = new TextureRequestModel();
101
+ request.verbandId = this.SelectedVerbandId;
102
+ request.steenId = steenid;
103
+ request.voegId = this.SelectedVoegId;
104
+ if (this.Steen2 == null) {
105
+ request.steen2Id = -1;
106
+ }
107
+ else {
108
+ request.steen2Id = this.Steen2.id;
109
+ }
110
+ if (this.Steen3 == null) {
111
+ request.steen3Id = -1;
112
+ }
113
+ else {
114
+ request.steen3Id = this.Steen3.id;
115
+ }
116
+ if (this.Steen4 == null) {
117
+ request.steen4Id = -1;
118
+ }
119
+ else {
120
+ request.steen4Id = this.Steen4.id;
121
+ }
122
+ if (this.Steen5 == null) {
123
+ request.steen5Id = -1;
124
+ }
125
+ else {
126
+ request.steen5Id = this.Steen5.id;
127
+ }
128
+ request.breedteStootvoeg = parseInt(this.Stootvoeg);
129
+ request.hoogteLintvoeg = parseInt(this.Lintvoeg);
130
+ this.TextureApiClient.getTexture(request).subscribe((model) => {
131
+ this.TextureResponseModel = model;
132
+ this.Loading = false;
133
+ }, (error) => {
134
+ if (error.status == 400)
135
+ console.log(error.json());
136
+ else {
137
+ console.log('An unexpected error occured');
138
+ console.log(error);
139
+ }
140
+ this.Loading = false;
141
+ });
142
+ }
143
+ }
144
+ OpenMix() {
145
+ var steenid = this.GetSteen()?.filter?.selectedOption;
146
+ if (steenid != undefined) {
147
+ this.Loading = true;
148
+ var request = new TextureMixRequestModel();
149
+ request.steenId = steenid;
150
+ this.TextureApiClient.getTextureMix(request).subscribe((model) => {
151
+ this.TextureMixResponseModel = model;
152
+ this.Loading = false;
153
+ this.mShowMix = true;
154
+ }, (error) => {
155
+ if (error.status == 400)
156
+ console.log(error.json());
157
+ else {
158
+ console.log('An unexpected error occured');
159
+ console.log(error);
160
+ }
161
+ this.Loading = false;
162
+ });
163
+ }
164
+ }
165
+ SelectSteen(steen) {
166
+ var processed = false;
167
+ if (this.Steen2 == steen) {
168
+ this.Steen2 = null;
169
+ processed = true;
170
+ }
171
+ if (this.Steen3 == steen) {
172
+ this.Steen2 = null;
173
+ processed = true;
174
+ }
175
+ if (this.Steen4 == steen) {
176
+ this.Steen4 = null;
177
+ processed = true;
178
+ }
179
+ if (this.Steen5 == steen) {
180
+ this.Steen5 = null;
181
+ processed = true;
182
+ }
183
+ if (this.Steen3 != null && this.Steen2 == null) {
184
+ this.Steen2 = this.Steen3;
185
+ this.Steen3 = null;
186
+ }
187
+ if (this.Steen4 != null && this.Steen3 == null) {
188
+ this.Steen3 = this.Steen4;
189
+ this.Steen4 = null;
190
+ }
191
+ if (this.Steen5 != null && this.Steen4 == null) {
192
+ this.Steen4 = this.Steen5;
193
+ this.Steen5 = null;
194
+ }
195
+ if (!processed) {
196
+ if (this.Steen2 == null) {
197
+ this.Steen2 = steen;
198
+ }
199
+ else if (this.Steen3 == null) {
200
+ this.Steen3 = steen;
201
+ }
202
+ else if (this.Steen4 == null) {
203
+ this.Steen4 = steen;
204
+ }
205
+ else if (this.Steen5 == null) {
206
+ this.Steen5 = steen;
207
+ }
208
+ }
209
+ }
210
+ OpenPhoto(url) {
211
+ var dialogRef = this.dialog.open(FabDisplayPhotoDialogComponent, {
212
+ data: {
213
+ url: url
214
+ }
215
+ });
216
+ }
217
+ ShowTexture() {
218
+ if (this.mShowMix) {
219
+ return false;
220
+ }
221
+ if (this.TextureResponseModel != null) {
222
+ return true;
223
+ }
224
+ return false;
225
+ }
226
+ ShowMix() {
227
+ if (!this.IsSteenSelected()) {
228
+ return false;
229
+ }
230
+ if (this.TextureMixResponseModel == null) {
231
+ return false;
232
+ }
233
+ if (this.mShowMix) {
234
+ return true;
235
+ }
236
+ return false;
237
+ }
238
+ IsLoading() {
239
+ if (this.Loading) {
240
+ return true;
241
+ }
242
+ if (this.FabrikantenService.Loading) {
243
+ return true;
244
+ }
245
+ return false;
246
+ }
247
+ IsSteenSelected() {
248
+ var steen = this.GetSteen();
249
+ if (steen?.filled == true) {
250
+ return true;
251
+ }
252
+ return false;
253
+ }
254
+ IsSelected(steen) {
255
+ var steenfilter = this.GetSteen();
256
+ if (steenfilter?.filled == true) {
257
+ if (steenfilter.filter?.selectedOption == steen.id) {
258
+ return true;
259
+ }
260
+ }
261
+ if (this.Steen2 == steen) {
262
+ return true;
263
+ }
264
+ if (this.Steen3 == steen) {
265
+ return true;
266
+ }
267
+ if (this.Steen4 == steen) {
268
+ return true;
269
+ }
270
+ if (this.Steen5 == steen) {
271
+ return true;
272
+ }
273
+ return false;
274
+ }
275
+ IsDisabled(steen) {
276
+ var steenfilter = this.GetSteen();
277
+ if (steenfilter?.filled == true) {
278
+ if (steenfilter.filter?.selectedOption == steen.id) {
279
+ return true;
280
+ }
281
+ }
282
+ if (this.Steen2 != null && this.Steen3 != null && this.Steen4 != null && this.Steen5 != null &&
283
+ this.Steen2 != steen && this.Steen3 != steen && this.Steen4 != steen && this.Steen5 != steen) {
284
+ return true;
285
+ }
286
+ return false;
287
+ }
288
+ GetPatroonDownloadURL() {
289
+ return this.FabrikantenService.FabrikantenSettingsViewModel.bcbWebserviceURLBase + "Download.aspx?file=" + this.TextureResponseModel?.patroonURL + "&doel=" + this.GetActiveSteen() + ".png";
290
+ }
291
+ GetBumpDownloadURL() {
292
+ return this.FabrikantenService.FabrikantenSettingsViewModel.bcbWebserviceURLBase + "Download.aspx?file=" + this.TextureResponseModel?.bumpURL + "&doel=" + this.GetActiveSteen() + "_bump.png";
293
+ }
294
+ CutOffFormat(name) {
295
+ var posstart = name.indexOf('(');
296
+ var posend = name.indexOf(')');
297
+ var newnameafter = name.substring(posend + 1);
298
+ var newname = name.substring(0, posstart);
299
+ return newname + newnameafter;
300
+ }
301
+ GetImagePath(option) {
302
+ var value = option.imagePath + "";
303
+ if (value.indexOf("#BCB#") != -1) {
304
+ var bcburl = this.FabrikantenService.FabrikantenSettingsViewModel.bcbWebserviceURLBase + "";
305
+ bcburl = bcburl.substring(0, bcburl.length - 1);
306
+ value = value.replace("#BCB#", bcburl);
307
+ }
308
+ return value;
309
+ }
310
+ GetSteen() {
311
+ if (this.FabrikantenService.FabrikantenViewModel?.inputs != undefined) {
312
+ for (var i = 0; i < this.FabrikantenService.FabrikantenViewModel.inputs.length; i++) {
313
+ if (this.FabrikantenService.FabrikantenViewModel.inputs[i].filter?.name == "Steen 1") {
314
+ return this.FabrikantenService.FabrikantenViewModel.inputs[i];
315
+ }
316
+ }
317
+ }
318
+ return null;
319
+ }
320
+ GetActiveSteen() {
321
+ var steen = this.GetSteen();
322
+ if (steen?.filter?.options != undefined) {
323
+ for (var i = 0; i < steen.filter.options.length; i++) {
324
+ if (steen.filter.options[i].id == steen.filter.selectedOption) {
325
+ return steen.filter.options[i].urlName + "";
326
+ }
327
+ }
328
+ }
329
+ return "";
330
+ }
331
+ GetVoeg() {
332
+ if (this.FabrikantenService.FabrikantenViewModel?.inputs != undefined) {
333
+ for (var i = 0; i < this.FabrikantenService.FabrikantenViewModel.inputs.length; i++) {
334
+ if (this.FabrikantenService.FabrikantenViewModel.inputs[i].filter?.name == "Voeg") {
335
+ return this.FabrikantenService.FabrikantenViewModel.inputs[i];
336
+ }
337
+ }
338
+ }
339
+ return null;
340
+ }
341
+ GetVerbanden() {
342
+ if (this.FabrikantenService.FabrikantenViewModel?.products != undefined) {
343
+ return this.FabrikantenService.FabrikantenViewModel?.products;
344
+ }
345
+ else {
346
+ return new Array();
347
+ }
348
+ }
349
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FabTextureConfiguratorComponent, deps: [{ token: i1.MobileService }, { token: i2.FabrikantenService }, { token: i3.TranslateService }, { token: i4.ActivatedRoute }, { token: i5.MatLegacyDialog }, { token: i6.TextureApiClient }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
350
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FabTextureConfiguratorComponent, selector: "app-fab-texture-configurator", ngImport: i0, template: "<div *ngIf=\"IsLoading()\" class=\"loader\">\r\n <mat-card class=\"loader-card\">\r\n <mat-card-content>\r\n <mat-spinner class=\"loader-spinner\" [diameter]=\"80\"></mat-spinner>\r\n </mat-card-content>\r\n <mat-card-subtitle class=\"loader-subtitle\" *ngIf=\"!FabrikantenService.IsStartingDownload()\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.ProductsLoading) }}\r\n </mat-card-subtitle>\r\n </mat-card>\r\n</div>\r\n\r\n<div *ngIf=\"!IsLoading()\">\r\n <div class=\"center-block\">\r\n <div>\r\n <div class=\"steen-select\">\r\n <ng-container *ngIf=\"GetSteen() != null\">\r\n <app-fab-input [input]=\"GetSteen()\"></app-fab-input>\r\n </ng-container>\r\n </div>\r\n\r\n <div *ngIf=\"IsSteenSelected()\">\r\n <div *ngIf=\"Steen2 != null\" class=\"steen-div\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, Steen2.id) }}\r\n </div>\r\n\r\n <div *ngIf=\"Steen3 != null\" class=\"steen-div\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, Steen3.id) }}\r\n </div>\r\n\r\n <div *ngIf=\"Steen4 != null\" class=\"steen-div\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, Steen4.id) }}\r\n </div>\r\n\r\n <div *ngIf=\"Steen5 != null\" class=\"steen-div\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, Steen5.id) }}\r\n </div>\r\n\r\n <div class=\"displayflex\">\r\n <div class=\"component-block first-row\">\r\n <mat-form-field appearance=\"fill\" class=\"fullwidth\">\r\n <mat-label class=\"select-mat-label\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.Verband) }}\r\n </mat-label>\r\n <mat-select [(ngModel)]=\"SelectedVerbandId\">\r\n <ng-container *ngFor=\"let verband of GetVerbanden()\">\r\n <mat-option [value]=\"verband.id\" class=\"select-mat-option\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Product, TranslationSubCategory.Name, verband.id) }}\r\n </mat-option>\r\n </ng-container>\r\n </mat-select>\r\n </mat-form-field>\r\n </div>\r\n <div class=\"component-block\">\r\n <mat-form-field appearance=\"fill\" class=\"small-input\">\r\n <mat-label>\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.Lintvoeg) }}\r\n </mat-label>\r\n <input matInput type=\"number\" min=\"6\" max=\"14\" [(ngModel)]=\"Lintvoeg\">\r\n <!--<mat-error>error</mat-error>-->\r\n </mat-form-field>\r\n </div>\r\n </div>\r\n <div class=\"displayflex\">\r\n <div class=\"component-block first-row\">\r\n <ng-container *ngIf=\"GetVoeg() != null\">\r\n <mat-form-field appearance=\"fill\" class=\"fullwidth\">\r\n <mat-label class=\"select-mat-label\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.Voeg) }}\r\n </mat-label>\r\n <mat-select [(ngModel)]=\"SelectedVoegId\">\r\n <ng-container *ngFor=\"let voeg of GetVoeg().filter.options\">\r\n <mat-option [value]=\"voeg.id\" class=\"select-mat-option\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, voeg.id) }}\r\n </mat-option>\r\n </ng-container>\r\n </mat-select>\r\n </mat-form-field>\r\n </ng-container>\r\n </div>\r\n <div class=\"component-block\">\r\n <mat-form-field appearance=\"fill\" class=\"small-input\">\r\n <mat-label>\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.Stootvoeg) }}\r\n </mat-label>\r\n <input matInput type=\"number\" min=\"6\" max=\"14\" [(ngModel)]=\"Stootvoeg\">\r\n <!--<mat-error>error</mat-error>-->\r\n </mat-form-field>\r\n </div>\r\n </div>\r\n\r\n <div class=\"displayflex\">\r\n <button mat-raised-button (click)=\"TextuurGenereren()\" class=\"link\">\r\n Textuur genereren\r\n </button>\r\n <div class=\"flexauto\"></div>\r\n <button mat-raised-button (click)=\"OpenMix()\" class=\"link\">\r\n Mix\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"ShowTexture()\" class=\"main-window flex-col\">\r\n <div class=\"image-row\">\r\n <div>\r\n <div>\r\n <a href=\"{{ TextureResponseModel.patroonURL }}\" target=\"_blank\">\r\n <img class=\"image image-patroon\" src=\"{{ TextureResponseModel.patroonURL }}\" />\r\n </a>\r\n </div>\r\n <div>\r\n <a href=\"{{ GetPatroonDownloadURL() }}\" target=\"_blank\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.DownloadTexture) }}\r\n </a>\r\n </div>\r\n <div>\r\n <a href=\"{{ GetBumpDownloadURL() }}\" target=\"_blank\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.DownloadBump) }}\r\n </a>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"ShowMix()\">\r\n <div class=\"main-window flex-col\">\r\n <ng-container *ngFor=\"let option of TextureMixResponseModel.stones\">\r\n <div class=\"filter-option-div\" [ngClass]=\"{'border-selected': IsSelected(option)}\">\r\n <ng-container *ngIf=\"option.imagePath != null && option.imagePath != ''\">\r\n <div class=\"filter-option-image-div\" (click)=\"OpenPhoto(GetImagePath(option))\">\r\n <img src=\"{{ GetImagePath(option) }}\" class=\"filter-option-image\" />\r\n <img class=\"filter-option-image-zoom-in\" />\r\n </div>\r\n </ng-container>\r\n <button mat-raised-button (click)=\"SelectSteen(option)\" class=\"fab-picture-select-button\" [disabled]=\"IsDisabled(option)\">\r\n <span class=\"name-span\">{{ CutOffFormat(TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, option.id)) }}</span>\r\n </button>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".displayflex{display:flex}.steen-select{padding:30px}.fullwidth{width:100%}.first-row{width:300px}.component-block{padding:5px}.center-block{width:-moz-fit-content;width:fit-content;margin:auto;display:flex}.flexauto{flex:auto}.small-input{width:100px}.loader-card{margin:200px auto auto;width:300px}.loader-subtitle{text-align:center}.loader-spinner{margin:auto}.image{width:calc(100vW - 500px);max-width:600px}.image-row{padding:20px}.filter-option-div{border:2px solid #FFF}.steen-div{padding:10px 10px 10px 30px}.border-selected{border:2px solid #0F0}.filter-option-image{max-width:200px;max-height:200px}.filter-option-image-div{width:200px;height:200px;cursor:zoom-in}.main-window{display:flex;flex-wrap:wrap;padding:10px;gap:3px}.fab-picture-select-button{width:100%}\n"], dependencies: [{ kind: "directive", type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i8.MatLegacyFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i8.MatLegacyLabel, selector: "mat-label" }, { kind: "directive", type: i9.MatLegacyInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", exportAs: ["matInput"] }, { kind: "directive", type: i10.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: i10.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i10.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i10.MinValidator, selector: "input[type=number][min][formControlName],input[type=number][min][formControl],input[type=number][min][ngModel]", inputs: ["min"] }, { kind: "directive", type: i10.MaxValidator, selector: "input[type=number][max][formControlName],input[type=number][max][formControl],input[type=number][max][ngModel]", inputs: ["max"] }, { kind: "directive", type: i10.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i11.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: i12.MatLegacyCard, selector: "mat-card", exportAs: ["matCard"] }, { kind: "directive", type: i12.MatLegacyCardContent, selector: "mat-card-content, [mat-card-content], [matCardContent]" }, { kind: "directive", type: i12.MatLegacyCardSubtitle, selector: "mat-card-subtitle, [mat-card-subtitle], [matCardSubtitle]" }, { kind: "component", type: i13.MatLegacyProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "diameter", "strokeWidth", "mode", "value"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: i14.MatLegacySelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i15.MatLegacyOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "component", type: i16.FabInputComponent, selector: "app-fab-input", inputs: ["input"] }] });
351
+ }
352
+ export { FabTextureConfiguratorComponent };
353
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FabTextureConfiguratorComponent, decorators: [{
354
+ type: Component,
355
+ args: [{ selector: 'app-fab-texture-configurator', template: "<div *ngIf=\"IsLoading()\" class=\"loader\">\r\n <mat-card class=\"loader-card\">\r\n <mat-card-content>\r\n <mat-spinner class=\"loader-spinner\" [diameter]=\"80\"></mat-spinner>\r\n </mat-card-content>\r\n <mat-card-subtitle class=\"loader-subtitle\" *ngIf=\"!FabrikantenService.IsStartingDownload()\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.ProductsLoading) }}\r\n </mat-card-subtitle>\r\n </mat-card>\r\n</div>\r\n\r\n<div *ngIf=\"!IsLoading()\">\r\n <div class=\"center-block\">\r\n <div>\r\n <div class=\"steen-select\">\r\n <ng-container *ngIf=\"GetSteen() != null\">\r\n <app-fab-input [input]=\"GetSteen()\"></app-fab-input>\r\n </ng-container>\r\n </div>\r\n\r\n <div *ngIf=\"IsSteenSelected()\">\r\n <div *ngIf=\"Steen2 != null\" class=\"steen-div\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, Steen2.id) }}\r\n </div>\r\n\r\n <div *ngIf=\"Steen3 != null\" class=\"steen-div\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, Steen3.id) }}\r\n </div>\r\n\r\n <div *ngIf=\"Steen4 != null\" class=\"steen-div\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, Steen4.id) }}\r\n </div>\r\n\r\n <div *ngIf=\"Steen5 != null\" class=\"steen-div\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, Steen5.id) }}\r\n </div>\r\n\r\n <div class=\"displayflex\">\r\n <div class=\"component-block first-row\">\r\n <mat-form-field appearance=\"fill\" class=\"fullwidth\">\r\n <mat-label class=\"select-mat-label\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.Verband) }}\r\n </mat-label>\r\n <mat-select [(ngModel)]=\"SelectedVerbandId\">\r\n <ng-container *ngFor=\"let verband of GetVerbanden()\">\r\n <mat-option [value]=\"verband.id\" class=\"select-mat-option\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Product, TranslationSubCategory.Name, verband.id) }}\r\n </mat-option>\r\n </ng-container>\r\n </mat-select>\r\n </mat-form-field>\r\n </div>\r\n <div class=\"component-block\">\r\n <mat-form-field appearance=\"fill\" class=\"small-input\">\r\n <mat-label>\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.Lintvoeg) }}\r\n </mat-label>\r\n <input matInput type=\"number\" min=\"6\" max=\"14\" [(ngModel)]=\"Lintvoeg\">\r\n <!--<mat-error>error</mat-error>-->\r\n </mat-form-field>\r\n </div>\r\n </div>\r\n <div class=\"displayflex\">\r\n <div class=\"component-block first-row\">\r\n <ng-container *ngIf=\"GetVoeg() != null\">\r\n <mat-form-field appearance=\"fill\" class=\"fullwidth\">\r\n <mat-label class=\"select-mat-label\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.Voeg) }}\r\n </mat-label>\r\n <mat-select [(ngModel)]=\"SelectedVoegId\">\r\n <ng-container *ngFor=\"let voeg of GetVoeg().filter.options\">\r\n <mat-option [value]=\"voeg.id\" class=\"select-mat-option\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, voeg.id) }}\r\n </mat-option>\r\n </ng-container>\r\n </mat-select>\r\n </mat-form-field>\r\n </ng-container>\r\n </div>\r\n <div class=\"component-block\">\r\n <mat-form-field appearance=\"fill\" class=\"small-input\">\r\n <mat-label>\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.Stootvoeg) }}\r\n </mat-label>\r\n <input matInput type=\"number\" min=\"6\" max=\"14\" [(ngModel)]=\"Stootvoeg\">\r\n <!--<mat-error>error</mat-error>-->\r\n </mat-form-field>\r\n </div>\r\n </div>\r\n\r\n <div class=\"displayflex\">\r\n <button mat-raised-button (click)=\"TextuurGenereren()\" class=\"link\">\r\n Textuur genereren\r\n </button>\r\n <div class=\"flexauto\"></div>\r\n <button mat-raised-button (click)=\"OpenMix()\" class=\"link\">\r\n Mix\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"ShowTexture()\" class=\"main-window flex-col\">\r\n <div class=\"image-row\">\r\n <div>\r\n <div>\r\n <a href=\"{{ TextureResponseModel.patroonURL }}\" target=\"_blank\">\r\n <img class=\"image image-patroon\" src=\"{{ TextureResponseModel.patroonURL }}\" />\r\n </a>\r\n </div>\r\n <div>\r\n <a href=\"{{ GetPatroonDownloadURL() }}\" target=\"_blank\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.DownloadTexture) }}\r\n </a>\r\n </div>\r\n <div>\r\n <a href=\"{{ GetBumpDownloadURL() }}\" target=\"_blank\">\r\n {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.DownloadBump) }}\r\n </a>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"ShowMix()\">\r\n <div class=\"main-window flex-col\">\r\n <ng-container *ngFor=\"let option of TextureMixResponseModel.stones\">\r\n <div class=\"filter-option-div\" [ngClass]=\"{'border-selected': IsSelected(option)}\">\r\n <ng-container *ngIf=\"option.imagePath != null && option.imagePath != ''\">\r\n <div class=\"filter-option-image-div\" (click)=\"OpenPhoto(GetImagePath(option))\">\r\n <img src=\"{{ GetImagePath(option) }}\" class=\"filter-option-image\" />\r\n <img class=\"filter-option-image-zoom-in\" />\r\n </div>\r\n </ng-container>\r\n <button mat-raised-button (click)=\"SelectSteen(option)\" class=\"fab-picture-select-button\" [disabled]=\"IsDisabled(option)\">\r\n <span class=\"name-span\">{{ CutOffFormat(TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, option.id)) }}</span>\r\n </button>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".displayflex{display:flex}.steen-select{padding:30px}.fullwidth{width:100%}.first-row{width:300px}.component-block{padding:5px}.center-block{width:-moz-fit-content;width:fit-content;margin:auto;display:flex}.flexauto{flex:auto}.small-input{width:100px}.loader-card{margin:200px auto auto;width:300px}.loader-subtitle{text-align:center}.loader-spinner{margin:auto}.image{width:calc(100vW - 500px);max-width:600px}.image-row{padding:20px}.filter-option-div{border:2px solid #FFF}.steen-div{padding:10px 10px 10px 30px}.border-selected{border:2px solid #0F0}.filter-option-image{max-width:200px;max-height:200px}.filter-option-image-div{width:200px;height:200px;cursor:zoom-in}.main-window{display:flex;flex-wrap:wrap;padding:10px;gap:3px}.fab-picture-select-button{width:100%}\n"] }]
356
+ }], ctorParameters: function () { return [{ type: i1.MobileService }, { type: i2.FabrikantenService }, { type: i3.TranslateService }, { type: i4.ActivatedRoute }, { type: i5.MatLegacyDialog }, { type: i6.TextureApiClient }, { type: i0.ChangeDetectorRef }]; } });
357
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fab-texture-configurator.component.js","sourceRoot":"","sources":["../../../../../../../../src/app/modules/fabrikantencore/components/fab-texture-configurator/fab-texture-configurator.component.ts","../../../../../../../../src/app/modules/fabrikantencore/components/fab-texture-configurator/fab-texture-configurator.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, ElementRef, OnChanges, DoCheck, OnInit } from '@angular/core';\nimport { MatLegacyDialog as MatDialog } from '@angular/material/legacy-dialog';\r\nimport { ActivatedRoute } from '@angular/router';\nimport { FabrikantenService } from '../../services/fabrikanten.service';\nimport { MobileService } from '../../services/mobile.service';\nimport { TranslateService } from '../../services/translate.service';\nimport { TranslationCategory, TranslationSubCategory, FabrikantenTextureBaseViewModel, FabrikantenInputViewModel, FabrikantenProductViewModel, TextureApiClient, TextureRequestModel, TextureResponseModel, TextureMixResponseModel, TextureMixRequestModel, FabrikantenFilterOptionViewModel } from '../../swagger/SwaggerClient';\nimport { FabDisplayPhotoDialogComponent } from '../fab-display-photo-dialog/fab-display-photo-dialog.component';\r\n\n@Component({\n  selector: 'app-fab-texture-configurator',\n  templateUrl: './fab-texture-configurator.component.html',\n  styleUrls: ['./fab-texture-configurator.component.scss']\n})\nexport class FabTextureConfiguratorComponent implements OnInit, DoCheck {\n\n  public get TranslationCategory() {\n    return TranslationCategory;\n  }\n\n  public get TranslationSubCategory() {\n    return TranslationSubCategory;\n  }\n\n  public SelectedVerbandId: number = -1;\n  public SelectedVoegId: number = -1;\n  public Lintvoeg: string = \"12\";\n  public Stootvoeg: string = \"10\";\n\n  public Loading: boolean = false;\n  private mShowMix: boolean = false;\n\n  public TextureResponseModel: TextureResponseModel | null = null;\n  public TextureMixResponseModel: TextureMixResponseModel | null = null;\n\n  public Steen2: FabrikantenFilterOptionViewModel | null = null;\n  public Steen3: FabrikantenFilterOptionViewModel | null = null;\n  public Steen4: FabrikantenFilterOptionViewModel | null = null;\n  public Steen5: FabrikantenFilterOptionViewModel | null = null;\n\n  constructor(\n    public MobileService: MobileService,\n    public FabrikantenService: FabrikantenService,\n    public TranslateService: TranslateService,\n    private ActivatedRoute: ActivatedRoute,\n    public dialog: MatDialog,\n    private TextureApiClient: TextureApiClient,\n    private ChangeDetectorRef: ChangeDetectorRef\n  ) {\n    this.TranslateService.ProcessParameters(this.ActivatedRoute, this.ChangeDetectorRef);\n  }\n\n  ngDoCheck(): void {\r\n    this.SelectFirstChoices();\r\n    this.CleanChoices();\r\n  }\n\n  ngOnInit(): void {\n    this.FabrikantenService.LoadFabrikantenViewModel(this.ChangeDetectorRef, this.ActivatedRoute);\n  }\n\n  public SelectFirstChoices(): void {\n    if (this.SelectedVerbandId == -1) {\n      if (this.FabrikantenService.FabrikantenViewModel?.products != undefined && this.FabrikantenService.FabrikantenViewModel.products.length > 0) {\r\n        for (var i = 0; i < this.FabrikantenService.FabrikantenViewModel.products.length; i++) {\r\n          if (this.FabrikantenService.FabrikantenViewModel.products[i].id == 62) { // halfsteensverband\r\n            this.SelectedVerbandId = this.FabrikantenService.FabrikantenViewModel.products[i].id;\r\n          }\r\n        }\r\n\r\n        if (this.SelectedVerbandId == -1) {\r\n          this.SelectedVerbandId = this.FabrikantenService.FabrikantenViewModel.products[0].id;\r\n        }\r\n      }\r\n    }\r\n\r\n    if (this.SelectedVoegId == -1) {\n      var voeg = this.GetVoeg();\r\n\r\n      if (voeg?.filter?.options != undefined && voeg.filter.options.length > 0) {\r\n        this.SelectedVoegId = voeg.filter?.options[0].id;\r\n      }\r\n    }\r\n  }\n\n  public CleanChoices(): void {\n    if (!this.IsSteenSelected()) {\r\n      this.mShowMix = false;\r\n      this.TextureMixResponseModel = null;\r\n      this.TextureResponseModel = null;\r\n      this.Steen2 = null;\r\n      this.Steen3 = null;\r\n      this.Steen4 = null;\r\n      this.Steen5 = null;\r\n    }\r\n  }\n\n  public TextuurGenereren(): void {\n    this.mShowMix = false;\n    var steenid = this.GetSteen()?.filter?.selectedOption;\n    if (steenid != undefined) {\n      this.Loading = true;\n      var request = new TextureRequestModel();\r\n\r\n      request.verbandId = this.SelectedVerbandId;\r\n      request.steenId = steenid;\r\n      request.voegId = this.SelectedVoegId;\r\n\r\n      if (this.Steen2 == null) {\r\n        request.steen2Id = -1;\r\n      }\r\n      else {\r\n        request.steen2Id = this.Steen2.id;\r\n      }\r\n\r\n      if (this.Steen3 == null) {\r\n        request.steen3Id = -1;\r\n      }\r\n      else {\r\n        request.steen3Id = this.Steen3.id;\r\n      }\r\n\r\n      if (this.Steen4 == null) {\r\n        request.steen4Id = -1;\r\n      }\r\n      else {\r\n        request.steen4Id = this.Steen4.id;\r\n      }\r\n\r\n      if (this.Steen5 == null) {\r\n        request.steen5Id = -1;\r\n      }\r\n      else {\r\n        request.steen5Id = this.Steen5.id;\r\n      }\r\n\r\n      request.breedteStootvoeg = parseInt(this.Stootvoeg);\r\n      request.hoogteLintvoeg = parseInt(this.Lintvoeg);\r\n\r\n      this.TextureApiClient.getTexture(request).subscribe((model: TextureResponseModel) => {\r\n        this.TextureResponseModel = model;\r\n        this.Loading = false;\r\n      }, (error: Response) => {\r\n        if (error.status == 400)\r\n          console.log(error.json());\r\n        else {\r\n          console.log('An unexpected error occured');\r\n          console.log(error);\r\n        }\r\n\r\n        this.Loading = false;\r\n      });\r\n    }\r\n  }\n\n  public OpenMix(): void {\n    var steenid = this.GetSteen()?.filter?.selectedOption;\n    if (steenid != undefined) {\n      this.Loading = true;\n      var request = new TextureMixRequestModel();\r\n\r\n      request.steenId = steenid;\r\n\r\n      this.TextureApiClient.getTextureMix(request).subscribe((model: TextureMixResponseModel) => {\r\n        this.TextureMixResponseModel = model;\r\n        this.Loading = false;\r\n        this.mShowMix = true;\r\n      }, (error: Response) => {\r\n        if (error.status == 400)\r\n          console.log(error.json());\r\n        else {\r\n          console.log('An unexpected error occured');\r\n          console.log(error);\r\n        }\r\n\r\n        this.Loading = false;\r\n      });\r\n    }\r\n  }\n\n  public SelectSteen(steen: FabrikantenFilterOptionViewModel) {\n    var processed = false;\n\n    if (this.Steen2 == steen) {\r\n      this.Steen2 = null;\r\n      processed = true;\r\n    }\r\n\r\n    if (this.Steen3 == steen) {\r\n      this.Steen2 = null;\r\n      processed = true;\r\n    }\r\n\r\n    if (this.Steen4 == steen) {\r\n      this.Steen4 = null;\r\n      processed = true;\r\n    }\r\n\r\n    if (this.Steen5 == steen) {\r\n      this.Steen5 = null;\r\n      processed = true;\r\n    }\r\n\r\n    if (this.Steen3 != null && this.Steen2 == null) {\r\n      this.Steen2 = this.Steen3;\r\n      this.Steen3 = null;\r\n    }\r\n\r\n    if (this.Steen4 != null && this.Steen3 == null) {\r\n      this.Steen3 = this.Steen4;\r\n      this.Steen4 = null;\r\n    }\r\n\r\n    if (this.Steen5 != null && this.Steen4 == null) {\r\n      this.Steen4 = this.Steen5;\r\n      this.Steen5 = null;\r\n    }\r\n\r\n    if (!processed) {\r\n      if (this.Steen2 == null) {\r\n        this.Steen2 = steen;\r\n      }\r\n      else if (this.Steen3 == null) {\r\n        this.Steen3 = steen;\r\n      }\r\n      else if (this.Steen4 == null) {\r\n        this.Steen4 = steen;\r\n      }\r\n      else if (this.Steen5 == null) {\r\n        this.Steen5 = steen;\r\n      }\r\n    }\r\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 ShowTexture(): boolean {\n    if (this.mShowMix) {\n      return false;\r\n    }\n\n    if (this.TextureResponseModel != null) {\n      return true;\r\n    }\n\n    return false;\r\n  }\n\n  public ShowMix(): boolean {\n    if (!this.IsSteenSelected()) {\n      return false;\r\n    }\n\n    if (this.TextureMixResponseModel == null) {\n      return false;\r\n    }\n\n    if (this.mShowMix) {\n      return true;\r\n    }\n\n    return false;\r\n  }\n\n  public IsLoading(): boolean {\n    if (this.Loading) {\n      return true;\r\n    }\n\n    if (this.FabrikantenService.Loading) {\n      return true;\r\n    }\n\n    return false;\r\n  }\n\n  public IsSteenSelected(): boolean {\n    var steen = this.GetSteen();\n\n    if (steen?.filled == true) {\n      return true;\r\n    }\n\n    return false;\r\n  }\n\n  public IsSelected(steen: FabrikantenFilterOptionViewModel): boolean {\n\n    var steenfilter = this.GetSteen();\n\n    if (steenfilter?.filled == true) {\n      if (steenfilter.filter?.selectedOption == steen.id) {\r\n        return true;\r\n      }\r\n    }\n\n    if (this.Steen2 == steen) {\n      return true;\r\n    }\n\n    if (this.Steen3 == steen) {\n      return true;\r\n    }\n\n    if (this.Steen4 == steen) {\n      return true;\r\n    }\n\n    if (this.Steen5 == steen) {\n      return true;\r\n    }\n\n    return false;\r\n  }\n\n  public IsDisabled(steen: FabrikantenFilterOptionViewModel): boolean {\n\n    var steenfilter = this.GetSteen();\n\n    if (steenfilter?.filled == true) {\n      if (steenfilter.filter?.selectedOption == steen.id) {\r\n        return true;\r\n      }\r\n    }\n\n    if (this.Steen2 != null && this.Steen3 != null && this.Steen4 != null && this.Steen5 != null &&\n      this.Steen2 != steen && this.Steen3 != steen && this.Steen4 != steen && this.Steen5 != steen) {\n      return true;\r\n    }\n\n    return false;\r\n  }\n\n  public GetPatroonDownloadURL(): string {\n    return this.FabrikantenService.FabrikantenSettingsViewModel.bcbWebserviceURLBase + \"Download.aspx?file=\" + this.TextureResponseModel?.patroonURL + \"&doel=\" + this.GetActiveSteen() + \".png\";\r\n  }\n\n  public GetBumpDownloadURL(): string {\n    return this.FabrikantenService.FabrikantenSettingsViewModel.bcbWebserviceURLBase + \"Download.aspx?file=\" + this.TextureResponseModel?.bumpURL + \"&doel=\" + this.GetActiveSteen() + \"_bump.png\";\r\n  }\n\n  public CutOffFormat(name: string): string {\n    var posstart = name.indexOf('(');\n    var posend = name.indexOf(')');\n\n    var newnameafter = name.substring(posend + 1);\n    var newname = name.substring(0, posstart);\n\n    return newname + newnameafter;\r\n  }\n\n  public GetImagePath(option: FabrikantenFilterOptionViewModel): string {\n    var value = option.imagePath + \"\";\r\n\r\n    if (value.indexOf(\"#BCB#\") != -1) {\r\n      var bcburl = this.FabrikantenService.FabrikantenSettingsViewModel.bcbWebserviceURLBase + \"\";\r\n      bcburl = bcburl.substring(0, bcburl.length - 1);\r\n\r\n      value = value.replace(\"#BCB#\", bcburl);\r\n    }\r\n\r\n    return value;\r\n  }\n\n  public GetSteen(): FabrikantenInputViewModel | null {\n    if (this.FabrikantenService.FabrikantenViewModel?.inputs != undefined) {\n      for (var i = 0; i < this.FabrikantenService.FabrikantenViewModel.inputs.length; i++) {\r\n        if (this.FabrikantenService.FabrikantenViewModel.inputs[i].filter?.name == \"Steen 1\") {\r\n          return this.FabrikantenService.FabrikantenViewModel.inputs[i];\r\n        }\r\n      }\r\n    }\n\n    return null;\r\n  }\n\n  public GetActiveSteen(): string {\n    var steen = this.GetSteen();\n\n    if (steen?.filter?.options != undefined) {\n      for (var i = 0; i < steen.filter.options.length; i++) {\r\n        if (steen.filter.options[i].id == steen.filter.selectedOption) {\r\n          return steen.filter.options[i].urlName + \"\";\r\n        }\r\n      }\r\n    }\n\n    return \"\";\r\n  }\n\n  public GetVoeg(): FabrikantenInputViewModel | null {\n    if (this.FabrikantenService.FabrikantenViewModel?.inputs != undefined) {\n      for (var i = 0; i < this.FabrikantenService.FabrikantenViewModel.inputs.length; i++) {\r\n        if (this.FabrikantenService.FabrikantenViewModel.inputs[i].filter?.name == \"Voeg\") {\r\n          return this.FabrikantenService.FabrikantenViewModel.inputs[i];\r\n        }\r\n      }\r\n    }\n\n    return null;\r\n  }\n\n  public GetVerbanden(): FabrikantenProductViewModel[] {\n    if (this.FabrikantenService.FabrikantenViewModel?.products != undefined) {\n      return this.FabrikantenService.FabrikantenViewModel?.products;\r\n    }\n    else {\n      return new Array<FabrikantenProductViewModel>();\r\n    }\n\r\n  }\n}\n","<div *ngIf=\"IsLoading()\" class=\"loader\">\r\n  <mat-card class=\"loader-card\">\r\n    <mat-card-content>\r\n      <mat-spinner class=\"loader-spinner\" [diameter]=\"80\"></mat-spinner>\r\n    </mat-card-content>\r\n    <mat-card-subtitle class=\"loader-subtitle\" *ngIf=\"!FabrikantenService.IsStartingDownload()\">\r\n      {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.ProductsLoading) }}\r\n    </mat-card-subtitle>\r\n  </mat-card>\r\n</div>\r\n\r\n<div *ngIf=\"!IsLoading()\">\r\n  <div class=\"center-block\">\r\n    <div>\r\n      <div class=\"steen-select\">\r\n        <ng-container *ngIf=\"GetSteen() != null\">\r\n          <app-fab-input [input]=\"GetSteen()\"></app-fab-input>\r\n        </ng-container>\r\n      </div>\r\n\r\n      <div *ngIf=\"IsSteenSelected()\">\r\n        <div *ngIf=\"Steen2 != null\" class=\"steen-div\">\r\n          {{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, Steen2.id) }}\r\n        </div>\r\n\r\n        <div *ngIf=\"Steen3 != null\" class=\"steen-div\">\r\n          {{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, Steen3.id) }}\r\n        </div>\r\n\r\n        <div *ngIf=\"Steen4 != null\" class=\"steen-div\">\r\n          {{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, Steen4.id) }}\r\n        </div>\r\n\r\n        <div *ngIf=\"Steen5 != null\" class=\"steen-div\">\r\n          {{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, Steen5.id) }}\r\n        </div>\r\n\r\n        <div class=\"displayflex\">\r\n          <div class=\"component-block first-row\">\r\n            <mat-form-field appearance=\"fill\" class=\"fullwidth\">\r\n              <mat-label class=\"select-mat-label\">\r\n                {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.Verband) }}\r\n              </mat-label>\r\n              <mat-select [(ngModel)]=\"SelectedVerbandId\">\r\n                <ng-container *ngFor=\"let verband of GetVerbanden()\">\r\n                  <mat-option [value]=\"verband.id\" class=\"select-mat-option\">\r\n                    {{ TranslateService.GetActiveValue(TranslationCategory.Product, TranslationSubCategory.Name, verband.id) }}\r\n                  </mat-option>\r\n                </ng-container>\r\n              </mat-select>\r\n            </mat-form-field>\r\n          </div>\r\n          <div class=\"component-block\">\r\n            <mat-form-field appearance=\"fill\" class=\"small-input\">\r\n              <mat-label>\r\n                {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.Lintvoeg) }}\r\n              </mat-label>\r\n              <input matInput type=\"number\" min=\"6\" max=\"14\" [(ngModel)]=\"Lintvoeg\">\r\n              <!--<mat-error>error</mat-error>-->\r\n            </mat-form-field>\r\n          </div>\r\n        </div>\r\n        <div class=\"displayflex\">\r\n          <div class=\"component-block first-row\">\r\n            <ng-container *ngIf=\"GetVoeg() != null\">\r\n              <mat-form-field appearance=\"fill\" class=\"fullwidth\">\r\n                <mat-label class=\"select-mat-label\">\r\n                  {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.Voeg) }}\r\n                </mat-label>\r\n                <mat-select [(ngModel)]=\"SelectedVoegId\">\r\n                  <ng-container *ngFor=\"let voeg of GetVoeg().filter.options\">\r\n                    <mat-option [value]=\"voeg.id\" class=\"select-mat-option\">\r\n                      {{ TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, voeg.id) }}\r\n                    </mat-option>\r\n                  </ng-container>\r\n                </mat-select>\r\n              </mat-form-field>\r\n            </ng-container>\r\n          </div>\r\n          <div class=\"component-block\">\r\n            <mat-form-field appearance=\"fill\" class=\"small-input\">\r\n              <mat-label>\r\n                {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.Stootvoeg) }}\r\n              </mat-label>\r\n              <input matInput type=\"number\" min=\"6\" max=\"14\" [(ngModel)]=\"Stootvoeg\">\r\n              <!--<mat-error>error</mat-error>-->\r\n            </mat-form-field>\r\n          </div>\r\n        </div>\r\n\r\n        <div class=\"displayflex\">\r\n          <button mat-raised-button (click)=\"TextuurGenereren()\" class=\"link\">\r\n            Textuur genereren\r\n          </button>\r\n          <div class=\"flexauto\"></div>\r\n          <button mat-raised-button (click)=\"OpenMix()\" class=\"link\">\r\n            Mix\r\n          </button>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <div *ngIf=\"ShowTexture()\" class=\"main-window flex-col\">\r\n      <div class=\"image-row\">\r\n        <div>\r\n          <div>\r\n            <a href=\"{{ TextureResponseModel.patroonURL }}\" target=\"_blank\">\r\n              <img class=\"image image-patroon\" src=\"{{ TextureResponseModel.patroonURL }}\" />\r\n            </a>\r\n          </div>\r\n          <div>\r\n            <a href=\"{{ GetPatroonDownloadURL() }}\" target=\"_blank\">\r\n              {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.DownloadTexture) }}\r\n            </a>\r\n          </div>\r\n          <div>\r\n            <a href=\"{{ GetBumpDownloadURL() }}\" target=\"_blank\">\r\n              {{ TranslateService.GetActiveValue(TranslationCategory.Common, TranslationSubCategory.DownloadBump) }}\r\n            </a>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <div *ngIf=\"ShowMix()\">\r\n      <div class=\"main-window flex-col\">\r\n        <ng-container *ngFor=\"let option of TextureMixResponseModel.stones\">\r\n          <div class=\"filter-option-div\" [ngClass]=\"{'border-selected': IsSelected(option)}\">\r\n            <ng-container *ngIf=\"option.imagePath != null && option.imagePath != ''\">\r\n              <div class=\"filter-option-image-div\" (click)=\"OpenPhoto(GetImagePath(option))\">\r\n                <img src=\"{{ GetImagePath(option) }}\" class=\"filter-option-image\" />\r\n                <img class=\"filter-option-image-zoom-in\" />\r\n              </div>\r\n            </ng-container>\r\n            <button mat-raised-button (click)=\"SelectSteen(option)\" class=\"fab-picture-select-button\" [disabled]=\"IsDisabled(option)\">\r\n              <span class=\"name-span\">{{ CutOffFormat(TranslateService.GetActiveValue(TranslationCategory.FilterOption, TranslationSubCategory.Name, option.id)) }}</span>\r\n            </button>\r\n          </div>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}