fabrikantencore 2.3.14 → 2.3.16

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.
@@ -1,8 +1,6 @@
1
1
  import { Component } from '@angular/core';
2
- import { MoveFilterRequest, MoveFilterOptionRequest, SetFilterRequiredRequest, SetFilterOptionRequiredRequest } from '../../../swagger/SwaggerClient';
2
+ import { MoveFilterOptionRequest } from '../../../swagger/SwaggerClient';
3
3
  import { moveItemInArray } from '@angular/cdk/drag-drop';
4
- import { BeheerSelectFilterDialogComponent } from '../beheer-select-filter-dialog/beheer-select-filter-dialog.component';
5
- import { BeheerSelectFilteroptionDialogComponent } from '../beheer-select-filteroption-dialog/beheer-select-filteroption-dialog.component';
6
4
  import * as i0 from "@angular/core";
7
5
  import * as i1 from "../../../swagger/SwaggerClient";
8
6
  import * as i2 from "@angular/material/dialog";
@@ -12,6 +10,8 @@ import * as i5 from "@angular/material/card";
12
10
  import * as i6 from "@angular/cdk/drag-drop";
13
11
  import * as i7 from "../beheer-nav/beheer-nav.component";
14
12
  import * as i8 from "../../../components/fab-loader/fab-loader.component";
13
+ import * as i9 from "../beheer-filter/beheer-filter.component";
14
+ import * as i10 from "../beheer-rangeinput/beheer-rangeinput.component";
15
15
  export class BeheerFiltersComponent {
16
16
  constructor(FiltersApiClient, dialog, ChangeDetectorRef) {
17
17
  this.FiltersApiClient = FiltersApiClient;
@@ -29,14 +29,6 @@ export class BeheerFiltersComponent {
29
29
  this.SaveInputs();
30
30
  }
31
31
  }
32
- GetFilterOptions() {
33
- if (this.InputViewModel?.filter?.filterOptionViewModels != undefined) {
34
- return this.InputViewModel.filter.filterOptionViewModels;
35
- }
36
- else {
37
- return new Array();
38
- }
39
- }
40
32
  MoveUpOption(option) {
41
33
  this.Loading = true;
42
34
  var request = new MoveFilterOptionRequest();
@@ -76,158 +68,6 @@ export class BeheerFiltersComponent {
76
68
  }
77
69
  AddCategory() {
78
70
  }
79
- Sort() {
80
- if (this.InputViewModel?.filter != null) {
81
- this.Loading = true;
82
- var request = new MoveFilterRequest();
83
- request.filterId = this.InputViewModel.filter.id;
84
- this.FiltersApiClient.sortFilter(request).subscribe(() => {
85
- this.LoadInputs();
86
- }, (error) => {
87
- if (error.status == 400)
88
- console.log(error.json());
89
- else {
90
- console.log('An unexpected error occured');
91
- console.log(error);
92
- }
93
- this.Loading = false;
94
- });
95
- }
96
- }
97
- RequireFilter() {
98
- var dialogRef = this.dialog.open(BeheerSelectFilterDialogComponent);
99
- dialogRef.afterClosed().subscribe((result) => {
100
- if (result?.filter != null && this.InputViewModel?.filter != null) {
101
- if (result.filter > 0) {
102
- if (confirm("Weet je het zeker?")) {
103
- this.ChangeDetectorRef.detectChanges();
104
- var request = new SetFilterRequiredRequest();
105
- request.filterAffectsId = this.InputViewModel?.filter.id;
106
- request.filterRequiredId = result.filter;
107
- this.FiltersApiClient.setFilterRequired(request).subscribe(() => {
108
- this.LoadInputs();
109
- }, (error) => {
110
- if (error.status == 400)
111
- console.log(error.json());
112
- else {
113
- console.log('An unexpected error occured');
114
- console.log(error);
115
- }
116
- this.Loading = false;
117
- });
118
- }
119
- }
120
- }
121
- });
122
- }
123
- RequireFilterOption() {
124
- var dialogRef = this.dialog.open(BeheerSelectFilteroptionDialogComponent);
125
- dialogRef.afterClosed().subscribe((result) => {
126
- if (result?.filteroption != null && this.InputViewModel?.filter) {
127
- if (result.filteroption > 0) {
128
- if (confirm("Weet je het zeker?")) {
129
- this.ChangeDetectorRef.detectChanges();
130
- var request = new SetFilterOptionRequiredRequest();
131
- request.filterId = this.InputViewModel.filter.id;
132
- request.rangeInputId = 0;
133
- request.filterOptionId = result.filteroption;
134
- this.FiltersApiClient.setFilterOptionRequired(request).subscribe(() => {
135
- this.LoadInputs();
136
- }, (error) => {
137
- if (error.status == 400)
138
- console.log(error.json());
139
- else {
140
- console.log('An unexpected error occured');
141
- console.log(error);
142
- }
143
- this.Loading = false;
144
- });
145
- }
146
- }
147
- }
148
- });
149
- }
150
- RemoveRequireFilterOption(require) {
151
- if (confirm("Weet je het zeker?")) {
152
- this.ChangeDetectorRef.detectChanges();
153
- var request = new SetFilterOptionRequiredRequest();
154
- request.filterId = require.affectedFilterId;
155
- request.rangeInputId = 0;
156
- request.filterOptionId = require.requiredFilterOptionId;
157
- this.FiltersApiClient.removeFilterOptionRequired(request).subscribe(() => {
158
- this.LoadInputs();
159
- }, (error) => {
160
- if (error.status == 400)
161
- console.log(error.json());
162
- else {
163
- console.log('An unexpected error occured');
164
- console.log(error);
165
- }
166
- this.Loading = false;
167
- });
168
- }
169
- }
170
- RequireRangeInputFilterOption() {
171
- var dialogRef = this.dialog.open(BeheerSelectFilteroptionDialogComponent);
172
- dialogRef.afterClosed().subscribe((result) => {
173
- if (result?.filteroption != null && this.InputViewModel?.range) {
174
- if (result.filteroption > 0) {
175
- if (confirm("Weet je het zeker?")) {
176
- this.ChangeDetectorRef.detectChanges();
177
- var request = new SetFilterOptionRequiredRequest();
178
- request.filterId = 0;
179
- request.rangeInputId = this.InputViewModel.range.id;
180
- request.filterOptionId = result.filteroption;
181
- this.FiltersApiClient.setFilterOptionRequired(request).subscribe(() => {
182
- this.LoadInputs();
183
- }, (error) => {
184
- if (error.status == 400)
185
- console.log(error.json());
186
- else {
187
- console.log('An unexpected error occured');
188
- console.log(error);
189
- }
190
- this.Loading = false;
191
- });
192
- }
193
- }
194
- }
195
- });
196
- }
197
- RemoveRequireRangeInputFilterOption(require) {
198
- if (confirm("Weet je het zeker?")) {
199
- this.ChangeDetectorRef.detectChanges();
200
- var request = new SetFilterOptionRequiredRequest();
201
- request.filterId = 0;
202
- request.rangeInputId = require.affectedRangeInputId;
203
- request.filterOptionId = require.requiredFilterOptionId;
204
- this.FiltersApiClient.removeFilterOptionRequired(request).subscribe(() => {
205
- this.LoadInputs();
206
- }, (error) => {
207
- if (error.status == 400)
208
- console.log(error.json());
209
- else {
210
- console.log('An unexpected error occured');
211
- console.log(error);
212
- }
213
- this.Loading = false;
214
- });
215
- }
216
- }
217
- RemoveFilterOption(option) {
218
- this.Loading = true;
219
- this.FiltersApiClient.removeFilterOption(option).subscribe(() => {
220
- this.LoadInputs();
221
- }, (error) => {
222
- if (error.status == 400)
223
- console.log(error.json());
224
- else {
225
- console.log('An unexpected error occured');
226
- console.log(error);
227
- }
228
- this.Loading = false;
229
- });
230
- }
231
71
  LoadInputs() {
232
72
  this.Loading = true;
233
73
  this.FiltersApiClient.getInputsViewModel().subscribe((model) => {
@@ -272,9 +112,9 @@ export class BeheerFiltersComponent {
272
112
  }
273
113
  }
274
114
  BeheerFiltersComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: BeheerFiltersComponent, deps: [{ token: i1.FiltersApiClient }, { token: i2.MatDialog }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
275
- BeheerFiltersComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: BeheerFiltersComponent, selector: "app-beheer-filters", ngImport: i0, template: "<app-beheer-nav></app-beheer-nav>\r\n\r\n<div *ngIf=\"Loading\">\r\n <app-fab-loader></app-fab-loader>\r\n</div>\r\n\r\n<div *ngIf=\"!Loading\" class=\"main-content\">\r\n <mat-card>\r\n <mat-card-content>\r\n <button mat-raised-button (click)=\"AddCategory()\">Categorie toevoegen</button>\r\n </mat-card-content>\r\n </mat-card>\r\n <br />\r\n <div class=\"displayflex\">\r\n <div>\r\n <mat-card>\r\n <mat-card-content>\r\n <div cdkDropList class=\"input-list\" (cdkDropListDropped)=\"drop($event)\">\r\n <div class=\"input-item\" *ngFor=\"let input of InputsViewModel.inputs\" cdkDrag>\r\n <ng-container *ngIf=\"input.filter\">\r\n <span [ngClass]=\"{'selected': input.filter?.id == InputViewModel?.filter?.id }\">\r\n {{ input.filter.name }} (#{{ input.filter.id }})\r\n </span>\r\n </ng-container>\r\n <ng-container *ngIf=\"input.range\">\r\n <span [ngClass]=\"{'selected': input.range?.id == InputViewModel?.range?.id }\">\r\n {{ input.range.name }} (#{{ input.range.id }})\r\n </span>\r\n \r\n </ng-container>\r\n <button (click)=\"Open(input)\">Select</button>\r\n </div>\r\n </div>\r\n </mat-card-content>\r\n </mat-card>\r\n </div>\r\n <div class=\"flexauto\">\r\n <mat-card>\r\n <mat-card-content>\r\n <div *ngIf=\"InputViewModel != undefined\">\r\n <ng-container *ngIf=\"InputViewModel.filter\">\r\n <div class=\"filter-name\">\r\n <div class=\"flexauto\">\r\n Name: {{ InputViewModel.filter.name }}\r\n </div>\r\n <div>\r\n <button mat-raised-button (click)=\"Sort()\">Sort</button>\r\n </div>\r\n </div>\r\n <div>\r\n <div class=\"filter-name\">\r\n <div class=\"flexauto\">\r\n Requires\r\n </div>\r\n <button mat-raised-button (click)=\"RequireFilter()\">Filter</button>\r\n <button mat-raised-button (click)=\"RequireFilterOption()\">FilterOption</button>\r\n </div>\r\n\r\n <div *ngFor=\"let option of InputViewModel.filter.requiresFilterOptions\" class=\"required-option\" [ngClass]=\"{ 'AND': option.filterOptionRequiredType == 0, 'OR': option.filterOptionRequiredType == 1 }\">\r\n {{ option.requiredFilterName }}: {{ option.requiredFilterOptionName }}\r\n <button mat-raised-button (click)=\"RemoveRequireFilterOption(option)\">Remove</button>\r\n </div>\r\n <div *ngFor=\"let filter of InputViewModel.filter.requiresFilters\" class=\"required-option\">\r\n {{ filter.requiredFilterName }}\r\n <button mat-raised-button>Remove</button>\r\n </div>\r\n </div>\r\n <div class=\"filter-options-container\">\r\n <div *ngFor=\"let option of GetFilterOptions(); let i = index;\" class=\"filter-option\">\r\n <div class=\"filter-option-name\">\r\n {{ option.name }}\r\n </div>\r\n <button mat-raised-button (click)=\"RemoveFilterOption(option)\">Remove</button>\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"InputViewModel.range\">\r\n <div class=\"filter-name\">\r\n <div class=\"flexauto\">\r\n Name: {{ InputViewModel.range.name }}\r\n </div>\r\n </div>\r\n <div>\r\n <div class=\"filter-name\">\r\n <div class=\"flexauto\">\r\n Requires\r\n </div>\r\n <button mat-raised-button (click)=\"RequireRangeInputFilterOption()\">FilterOption</button>\r\n </div>\r\n\r\n <div *ngFor=\"let option of InputViewModel.range.requiresRangeInputFilterOptions\" class=\"required-option\" [ngClass]=\"{ 'AND': option.filterOptionRequiredType == 0, 'OR': option.filterOptionRequiredType == 1 }\">\r\n {{ option.requiredFilterName }}: {{ option.requiredFilterOptionName }}\r\n <button mat-raised-button (click)=\"RemoveRequireRangeInputFilterOption(option)\">Remove</button>\r\n </div>\r\n </div>\r\n </ng-container>\r\n \r\n </div>\r\n </mat-card-content>\r\n </mat-card>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n", styles: [".displayflex{display:flex;gap:10px}.required-option{border:1px solid #000;border-radius:2px;padding:2px;margin:2px}.AND{border-color:red}.OR{border-color:#0f0}.filter-row{font-size:20px;line-height:30px;margin-bottom:10px}.flexauto{flex:auto}.main-content{padding:10px}.filter-name{font-size:20px;padding:10px;border-bottom:1px solid #000;display:flex}.filter-option:hover{background-color:gray}.filter-options-container{border:1px solid #000;padding:10px;margin:10px}.filter-option{padding:5px;border-bottom:1px solid #000;display:flex;gap:5px}.filter-option-name{flex:auto;line-height:30px;font-size:20px}.selected{font-weight:700}.input-list{max-width:100%;border:solid 1px #ccc;min-height:60px;display:block;background:white;border-radius:4px;overflow-y:scroll;height:calc(100vH - 188px)}.input-item{padding:5px 10px;border-bottom:solid 1px #ccc;color:#000000de;display:flex;flex-direction:row;align-items:center;justify-content:space-between;box-sizing:border-box;cursor:move;background:white;font-size:14px}.cdk-drag-preview{box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.input-item:last-child{border:none}.input-list.cdk-drop-list-dragging .example-box:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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.MatButton, 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: i5.MatCard, selector: "mat-card", exportAs: ["matCard"] }, { kind: "directive", type: i5.MatCardContent, selector: "mat-card-content, [mat-card-content], [matCardContent]" }, { kind: "directive", type: i6.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i6.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "component", type: i7.BeheerNavComponent, selector: "app-beheer-nav" }, { kind: "component", type: i8.FabLoaderComponent, selector: "app-fab-loader" }] });
115
+ BeheerFiltersComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: BeheerFiltersComponent, selector: "app-beheer-filters", ngImport: i0, template: "<app-beheer-nav></app-beheer-nav>\r\n\r\n<div *ngIf=\"Loading\">\r\n <app-fab-loader></app-fab-loader>\r\n</div>\r\n\r\n<div *ngIf=\"!Loading\" class=\"main-content\">\r\n <mat-card>\r\n <mat-card-content>\r\n <button mat-raised-button (click)=\"AddCategory()\">Categorie toevoegen</button>\r\n </mat-card-content>\r\n </mat-card>\r\n <br />\r\n <div class=\"displayflex\">\r\n <div>\r\n <mat-card>\r\n <mat-card-content>\r\n <div cdkDropList class=\"input-list\" (cdkDropListDropped)=\"drop($event)\">\r\n <div class=\"input-item\" *ngFor=\"let input of InputsViewModel.inputs\" cdkDrag>\r\n <ng-container *ngIf=\"input.filter\">\r\n <span [ngClass]=\"{'selected': input.filter?.id == InputViewModel?.filter?.id }\">\r\n {{ input.filter.name }} (#{{ input.filter.id }})\r\n </span>\r\n </ng-container>\r\n <ng-container *ngIf=\"input.range\">\r\n <span [ngClass]=\"{'selected': input.range?.id == InputViewModel?.range?.id }\">\r\n {{ input.range.name }} (#{{ input.range.id }})\r\n </span>\r\n \r\n </ng-container>\r\n <button (click)=\"Open(input)\">Select</button>\r\n </div>\r\n </div>\r\n </mat-card-content>\r\n </mat-card>\r\n </div>\r\n <div class=\"flexauto\">\r\n <mat-card>\r\n <mat-card-content>\r\n <div *ngIf=\"InputViewModel != undefined\">\r\n <ng-container *ngIf=\"InputViewModel.filter\">\r\n <app-beheer-filter [filter]=\"InputViewModel.filter\" (reload)=\"LoadInputs()\"></app-beheer-filter>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"InputViewModel.range\">\r\n <app-beheer-rangeinput [rangeinput]=\"InputViewModel.range\" (reload)=\"LoadInputs()\"></app-beheer-rangeinput>\r\n </ng-container>\r\n </div>\r\n </mat-card-content>\r\n </mat-card>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n", styles: [".displayflex{display:flex;gap:10px}.required-option{border:1px solid #000;border-radius:2px;padding:2px;margin:2px}.AND{border-color:red}.OR{border-color:#0f0}.filter-row{font-size:20px;line-height:30px;margin-bottom:10px}.flexauto{flex:auto}.main-content{padding:10px}.filter-name{font-size:20px;padding:10px;border-bottom:1px solid #000;display:flex}.filter-option:hover{background-color:gray}.filter-options-container{border:1px solid #000;padding:10px;margin:10px}.filter-option{padding:5px;border-bottom:1px solid #000;display:flex;gap:5px}.filter-option-name{flex:auto;line-height:30px;font-size:20px}.selected{font-weight:700}.input-list{max-width:100%;border:solid 1px #ccc;min-height:60px;display:block;background:white;border-radius:4px;overflow-y:scroll;height:calc(100vH - 188px)}.input-item{padding:5px 10px;border-bottom:solid 1px #ccc;color:#000000de;display:flex;flex-direction:row;align-items:center;justify-content:space-between;box-sizing:border-box;cursor:move;background:white;font-size:14px}.cdk-drag-preview{box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.input-item:last-child{border:none}.input-list.cdk-drop-list-dragging .example-box:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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.MatButton, 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: i5.MatCard, selector: "mat-card", exportAs: ["matCard"] }, { kind: "directive", type: i5.MatCardContent, selector: "mat-card-content, [mat-card-content], [matCardContent]" }, { kind: "directive", type: i6.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i6.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "component", type: i7.BeheerNavComponent, selector: "app-beheer-nav" }, { kind: "component", type: i8.FabLoaderComponent, selector: "app-fab-loader" }, { kind: "component", type: i9.BeheerFilterComponent, selector: "app-beheer-filter", inputs: ["filter"], outputs: ["reload"] }, { kind: "component", type: i10.BeheerRangeinputComponent, selector: "app-beheer-rangeinput", inputs: ["rangeinput"], outputs: ["reload"] }] });
276
116
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: BeheerFiltersComponent, decorators: [{
277
117
  type: Component,
278
- args: [{ selector: 'app-beheer-filters', template: "<app-beheer-nav></app-beheer-nav>\r\n\r\n<div *ngIf=\"Loading\">\r\n <app-fab-loader></app-fab-loader>\r\n</div>\r\n\r\n<div *ngIf=\"!Loading\" class=\"main-content\">\r\n <mat-card>\r\n <mat-card-content>\r\n <button mat-raised-button (click)=\"AddCategory()\">Categorie toevoegen</button>\r\n </mat-card-content>\r\n </mat-card>\r\n <br />\r\n <div class=\"displayflex\">\r\n <div>\r\n <mat-card>\r\n <mat-card-content>\r\n <div cdkDropList class=\"input-list\" (cdkDropListDropped)=\"drop($event)\">\r\n <div class=\"input-item\" *ngFor=\"let input of InputsViewModel.inputs\" cdkDrag>\r\n <ng-container *ngIf=\"input.filter\">\r\n <span [ngClass]=\"{'selected': input.filter?.id == InputViewModel?.filter?.id }\">\r\n {{ input.filter.name }} (#{{ input.filter.id }})\r\n </span>\r\n </ng-container>\r\n <ng-container *ngIf=\"input.range\">\r\n <span [ngClass]=\"{'selected': input.range?.id == InputViewModel?.range?.id }\">\r\n {{ input.range.name }} (#{{ input.range.id }})\r\n </span>\r\n \r\n </ng-container>\r\n <button (click)=\"Open(input)\">Select</button>\r\n </div>\r\n </div>\r\n </mat-card-content>\r\n </mat-card>\r\n </div>\r\n <div class=\"flexauto\">\r\n <mat-card>\r\n <mat-card-content>\r\n <div *ngIf=\"InputViewModel != undefined\">\r\n <ng-container *ngIf=\"InputViewModel.filter\">\r\n <div class=\"filter-name\">\r\n <div class=\"flexauto\">\r\n Name: {{ InputViewModel.filter.name }}\r\n </div>\r\n <div>\r\n <button mat-raised-button (click)=\"Sort()\">Sort</button>\r\n </div>\r\n </div>\r\n <div>\r\n <div class=\"filter-name\">\r\n <div class=\"flexauto\">\r\n Requires\r\n </div>\r\n <button mat-raised-button (click)=\"RequireFilter()\">Filter</button>\r\n <button mat-raised-button (click)=\"RequireFilterOption()\">FilterOption</button>\r\n </div>\r\n\r\n <div *ngFor=\"let option of InputViewModel.filter.requiresFilterOptions\" class=\"required-option\" [ngClass]=\"{ 'AND': option.filterOptionRequiredType == 0, 'OR': option.filterOptionRequiredType == 1 }\">\r\n {{ option.requiredFilterName }}: {{ option.requiredFilterOptionName }}\r\n <button mat-raised-button (click)=\"RemoveRequireFilterOption(option)\">Remove</button>\r\n </div>\r\n <div *ngFor=\"let filter of InputViewModel.filter.requiresFilters\" class=\"required-option\">\r\n {{ filter.requiredFilterName }}\r\n <button mat-raised-button>Remove</button>\r\n </div>\r\n </div>\r\n <div class=\"filter-options-container\">\r\n <div *ngFor=\"let option of GetFilterOptions(); let i = index;\" class=\"filter-option\">\r\n <div class=\"filter-option-name\">\r\n {{ option.name }}\r\n </div>\r\n <button mat-raised-button (click)=\"RemoveFilterOption(option)\">Remove</button>\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"InputViewModel.range\">\r\n <div class=\"filter-name\">\r\n <div class=\"flexauto\">\r\n Name: {{ InputViewModel.range.name }}\r\n </div>\r\n </div>\r\n <div>\r\n <div class=\"filter-name\">\r\n <div class=\"flexauto\">\r\n Requires\r\n </div>\r\n <button mat-raised-button (click)=\"RequireRangeInputFilterOption()\">FilterOption</button>\r\n </div>\r\n\r\n <div *ngFor=\"let option of InputViewModel.range.requiresRangeInputFilterOptions\" class=\"required-option\" [ngClass]=\"{ 'AND': option.filterOptionRequiredType == 0, 'OR': option.filterOptionRequiredType == 1 }\">\r\n {{ option.requiredFilterName }}: {{ option.requiredFilterOptionName }}\r\n <button mat-raised-button (click)=\"RemoveRequireRangeInputFilterOption(option)\">Remove</button>\r\n </div>\r\n </div>\r\n </ng-container>\r\n \r\n </div>\r\n </mat-card-content>\r\n </mat-card>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n", styles: [".displayflex{display:flex;gap:10px}.required-option{border:1px solid #000;border-radius:2px;padding:2px;margin:2px}.AND{border-color:red}.OR{border-color:#0f0}.filter-row{font-size:20px;line-height:30px;margin-bottom:10px}.flexauto{flex:auto}.main-content{padding:10px}.filter-name{font-size:20px;padding:10px;border-bottom:1px solid #000;display:flex}.filter-option:hover{background-color:gray}.filter-options-container{border:1px solid #000;padding:10px;margin:10px}.filter-option{padding:5px;border-bottom:1px solid #000;display:flex;gap:5px}.filter-option-name{flex:auto;line-height:30px;font-size:20px}.selected{font-weight:700}.input-list{max-width:100%;border:solid 1px #ccc;min-height:60px;display:block;background:white;border-radius:4px;overflow-y:scroll;height:calc(100vH - 188px)}.input-item{padding:5px 10px;border-bottom:solid 1px #ccc;color:#000000de;display:flex;flex-direction:row;align-items:center;justify-content:space-between;box-sizing:border-box;cursor:move;background:white;font-size:14px}.cdk-drag-preview{box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.input-item:last-child{border:none}.input-list.cdk-drop-list-dragging .example-box:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}\n"] }]
118
+ args: [{ selector: 'app-beheer-filters', template: "<app-beheer-nav></app-beheer-nav>\r\n\r\n<div *ngIf=\"Loading\">\r\n <app-fab-loader></app-fab-loader>\r\n</div>\r\n\r\n<div *ngIf=\"!Loading\" class=\"main-content\">\r\n <mat-card>\r\n <mat-card-content>\r\n <button mat-raised-button (click)=\"AddCategory()\">Categorie toevoegen</button>\r\n </mat-card-content>\r\n </mat-card>\r\n <br />\r\n <div class=\"displayflex\">\r\n <div>\r\n <mat-card>\r\n <mat-card-content>\r\n <div cdkDropList class=\"input-list\" (cdkDropListDropped)=\"drop($event)\">\r\n <div class=\"input-item\" *ngFor=\"let input of InputsViewModel.inputs\" cdkDrag>\r\n <ng-container *ngIf=\"input.filter\">\r\n <span [ngClass]=\"{'selected': input.filter?.id == InputViewModel?.filter?.id }\">\r\n {{ input.filter.name }} (#{{ input.filter.id }})\r\n </span>\r\n </ng-container>\r\n <ng-container *ngIf=\"input.range\">\r\n <span [ngClass]=\"{'selected': input.range?.id == InputViewModel?.range?.id }\">\r\n {{ input.range.name }} (#{{ input.range.id }})\r\n </span>\r\n \r\n </ng-container>\r\n <button (click)=\"Open(input)\">Select</button>\r\n </div>\r\n </div>\r\n </mat-card-content>\r\n </mat-card>\r\n </div>\r\n <div class=\"flexauto\">\r\n <mat-card>\r\n <mat-card-content>\r\n <div *ngIf=\"InputViewModel != undefined\">\r\n <ng-container *ngIf=\"InputViewModel.filter\">\r\n <app-beheer-filter [filter]=\"InputViewModel.filter\" (reload)=\"LoadInputs()\"></app-beheer-filter>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"InputViewModel.range\">\r\n <app-beheer-rangeinput [rangeinput]=\"InputViewModel.range\" (reload)=\"LoadInputs()\"></app-beheer-rangeinput>\r\n </ng-container>\r\n </div>\r\n </mat-card-content>\r\n </mat-card>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n", styles: [".displayflex{display:flex;gap:10px}.required-option{border:1px solid #000;border-radius:2px;padding:2px;margin:2px}.AND{border-color:red}.OR{border-color:#0f0}.filter-row{font-size:20px;line-height:30px;margin-bottom:10px}.flexauto{flex:auto}.main-content{padding:10px}.filter-name{font-size:20px;padding:10px;border-bottom:1px solid #000;display:flex}.filter-option:hover{background-color:gray}.filter-options-container{border:1px solid #000;padding:10px;margin:10px}.filter-option{padding:5px;border-bottom:1px solid #000;display:flex;gap:5px}.filter-option-name{flex:auto;line-height:30px;font-size:20px}.selected{font-weight:700}.input-list{max-width:100%;border:solid 1px #ccc;min-height:60px;display:block;background:white;border-radius:4px;overflow-y:scroll;height:calc(100vH - 188px)}.input-item{padding:5px 10px;border-bottom:solid 1px #ccc;color:#000000de;display:flex;flex-direction:row;align-items:center;justify-content:space-between;box-sizing:border-box;cursor:move;background:white;font-size:14px}.cdk-drag-preview{box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.input-item:last-child{border:none}.input-list.cdk-drop-list-dragging .example-box:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}\n"] }]
279
119
  }], ctorParameters: function () { return [{ type: i1.FiltersApiClient }, { type: i2.MatDialog }, { type: i0.ChangeDetectorRef }]; } });
280
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"beheer-filters.component.js","sourceRoot":"","sources":["../../../../../../../../../src/app/modules/fabrikantencore/beheer/components/beheer-filters/beheer-filters.component.ts","../../../../../../../../../src/app/modules/fabrikantencore/beheer/components/beheer-filters/beheer-filters.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, OnInit } from '@angular/core';\nimport { FiltersApiClient, InputsViewModel, FilterOptionRequiredViewModel, RangeInputFilterOptionRequiredViewModel, InputViewModel, MoveFilterRequest, MoveFilterOptionRequest, FilterOptionViewModel, SetFilterRequiredRequest, SetFilterOptionRequiredRequest } from '../../../swagger/SwaggerClient';\r\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { BeheerSelectFilterDialogComponent } from '../beheer-select-filter-dialog/beheer-select-filter-dialog.component';\r\nimport { BeheerSelectFilteroptionDialogComponent } from '../beheer-select-filteroption-dialog/beheer-select-filteroption-dialog.component';\r\n\n@Component({\n  selector: 'app-beheer-filters',\n  templateUrl: './beheer-filters.component.html',\n  styleUrls: ['./beheer-filters.component.scss']\n})\nexport class BeheerFiltersComponent implements OnInit {\n\n  public Loading: boolean = true;\n\n  public InputsViewModel: InputsViewModel;\n\n  public InputViewModel: InputViewModel | undefined = undefined;\n\n  constructor(private FiltersApiClient: FiltersApiClient,\n    public dialog: MatDialog,\r\n    private ChangeDetectorRef: ChangeDetectorRef) { }\n\n  ngOnInit(): void {\n    this.LoadInputs();\n  }\n\n  drop(event: CdkDragDrop<string[]>) {\r\n    if (this.InputsViewModel.inputs != null) {\r\n      moveItemInArray(this.InputsViewModel.inputs, event.previousIndex, event.currentIndex);\r\n\r\n      this.SaveInputs();\r\n    }\r\n  }\n\n  public GetFilterOptions(): FilterOptionViewModel[] {\n    if (this.InputViewModel?.filter?.filterOptionViewModels != undefined) {\n      return this.InputViewModel.filter.filterOptionViewModels;\r\n    }\r\n    else {\r\n      return new Array<FilterOptionViewModel>();\r\n    }\r\n  }\n\n  public MoveUpOption(option: FilterOptionViewModel) {\n    this.Loading = true;\n\n    var request = new MoveFilterOptionRequest();\n\n    request.filterOptionId = option.id;\n    request.up = true;\n\n    this.FiltersApiClient.moveFilterOption(request).subscribe(() => {\n      this.LoadInputs();\n    }, (error: Response) => {\n      if (error.status == 400)\n        console.log(error.json());\n      else {\n        console.log('An unexpected error occured');\n        console.log(error);\n      }\n\n      this.Loading = false;\n    });\r\n  }\n\n  public MoveDownOption(option: FilterOptionViewModel) {\n    this.Loading = true;\n\n    var request = new MoveFilterOptionRequest();\n\n    request.filterOptionId = option.id;\n    request.up = false;\n\n    this.FiltersApiClient.moveFilterOption(request).subscribe(() => {\n      this.LoadInputs();\n    }, (error: Response) => {\n      if (error.status == 400)\n        console.log(error.json());\n      else {\n        console.log('An unexpected error occured');\n        console.log(error);\n      }\n\n      this.Loading = false;\n    });\r\n  }\n\n  public Open(input: InputViewModel) {\n    this.InputViewModel = input;\r\n  }\n\n  public AddCategory(): void {\n\r\n  }\n\n  public Sort(): void {\n    if (this.InputViewModel?.filter != null) {\n      this.Loading = true;\n\n      var request = new MoveFilterRequest();\n\n      request.filterId = this.InputViewModel.filter.id;\n\n      this.FiltersApiClient.sortFilter(request).subscribe(() => {\n        this.LoadInputs();\n      }, (error: Response) => {\n        if (error.status == 400)\n          console.log(error.json());\n        else {\n          console.log('An unexpected error occured');\n          console.log(error);\n        }\n\n        this.Loading = false;\n      });\r\n    }\r\n  }\n\n  public RequireFilter(): void {\n    var dialogRef = this.dialog.open(BeheerSelectFilterDialogComponent);\r\n\r\n    dialogRef.afterClosed().subscribe((result: any) => {\r\n      if (result?.filter != null && this.InputViewModel?.filter != null) {\r\n        if (result.filter > 0) {\r\n          if (confirm(\"Weet je het zeker?\")) {\r\n\r\n            this.ChangeDetectorRef.detectChanges();\r\n\r\n            var request = new SetFilterRequiredRequest();\r\n\r\n            request.filterAffectsId = this.InputViewModel?.filter.id;\r\n            request.filterRequiredId = result.filter;\r\n\r\n            this.FiltersApiClient.setFilterRequired(request).subscribe(() => {\n              this.LoadInputs();\n            }, (error: Response) => {\n              if (error.status == 400)\n                console.log(error.json());\n              else {\n                console.log('An unexpected error occured');\n                console.log(error);\n              }\n\n              this.Loading = false;\n            });\r\n          }\r\n        }\r\n      }\r\n    });\r\n  }\n\n  public RequireFilterOption(): void {\n    var dialogRef = this.dialog.open(BeheerSelectFilteroptionDialogComponent);\r\n\r\n    dialogRef.afterClosed().subscribe((result: any) => {\r\n      if (result?.filteroption != null && this.InputViewModel?.filter) {\r\n        if (result.filteroption > 0) {\r\n          if (confirm(\"Weet je het zeker?\")) {\r\n\r\n            this.ChangeDetectorRef.detectChanges();\r\n\r\n            var request = new SetFilterOptionRequiredRequest();\r\n\r\n            request.filterId = this.InputViewModel.filter.id;\r\n            request.rangeInputId = 0;\r\n            request.filterOptionId = result.filteroption;\r\n\r\n            this.FiltersApiClient.setFilterOptionRequired(request).subscribe(() => {\n              this.LoadInputs();\n            }, (error: Response) => {\n              if (error.status == 400)\n                console.log(error.json());\n              else {\n                console.log('An unexpected error occured');\n                console.log(error);\n              }\n\n              this.Loading = false;\n            });\r\n          }\r\n        }\r\n      }\r\n    });\r\n  }\n\n  public RemoveRequireFilterOption(require: FilterOptionRequiredViewModel): void {\n    if (confirm(\"Weet je het zeker?\")) {\r\n\r\n      this.ChangeDetectorRef.detectChanges();\r\n\r\n      var request = new SetFilterOptionRequiredRequest();\r\n\r\n      request.filterId = require.affectedFilterId;\r\n      request.rangeInputId = 0;\r\n      request.filterOptionId = require.requiredFilterOptionId;\r\n\r\n      this.FiltersApiClient.removeFilterOptionRequired(request).subscribe(() => {\n        this.LoadInputs();\n      }, (error: Response) => {\n        if (error.status == 400)\n          console.log(error.json());\n        else {\n          console.log('An unexpected error occured');\n          console.log(error);\n        }\n\n        this.Loading = false;\n      });\r\n    }\r\n  }\n\n  public RequireRangeInputFilterOption(): void {\n    var dialogRef = this.dialog.open(BeheerSelectFilteroptionDialogComponent);\r\n\r\n    dialogRef.afterClosed().subscribe((result: any) => {\r\n      if (result?.filteroption != null && this.InputViewModel?.range) {\r\n        if (result.filteroption > 0) {\r\n          if (confirm(\"Weet je het zeker?\")) {\r\n\r\n            this.ChangeDetectorRef.detectChanges();\r\n\r\n            var request = new SetFilterOptionRequiredRequest();\r\n\r\n            request.filterId = 0;\r\n            request.rangeInputId = this.InputViewModel.range.id;\r\n            request.filterOptionId = result.filteroption;\r\n\r\n            this.FiltersApiClient.setFilterOptionRequired(request).subscribe(() => {\n              this.LoadInputs();\n            }, (error: Response) => {\n              if (error.status == 400)\n                console.log(error.json());\n              else {\n                console.log('An unexpected error occured');\n                console.log(error);\n              }\n\n              this.Loading = false;\n            });\r\n          }\r\n        }\r\n      }\r\n    });\r\n  }\n\n  public RemoveRequireRangeInputFilterOption(require: RangeInputFilterOptionRequiredViewModel): void {\n    if (confirm(\"Weet je het zeker?\")) {\r\n\r\n      this.ChangeDetectorRef.detectChanges();\r\n\r\n      var request = new SetFilterOptionRequiredRequest();\r\n\r\n      request.filterId = 0;\r\n      request.rangeInputId = require.affectedRangeInputId;\r\n      request.filterOptionId = require.requiredFilterOptionId;\r\n\r\n      this.FiltersApiClient.removeFilterOptionRequired(request).subscribe(() => {\n        this.LoadInputs();\n      }, (error: Response) => {\n        if (error.status == 400)\n          console.log(error.json());\n        else {\n          console.log('An unexpected error occured');\n          console.log(error);\n        }\n\n        this.Loading = false;\n      });\r\n    }\r\n  }\n\n  public RemoveFilterOption(option: FilterOptionViewModel): void {\n    this.Loading = true;\n\n    this.FiltersApiClient.removeFilterOption(option).subscribe(() => {\n      this.LoadInputs();\n    }, (error: Response) => {\n      if (error.status == 400)\n        console.log(error.json());\n      else {\n        console.log('An unexpected error occured');\n        console.log(error);\n      }\n\n      this.Loading = false;\n    });\r\n  }\n\n  private LoadInputs(): void {\n    this.Loading = true;\n\n    this.FiltersApiClient.getInputsViewModel().subscribe((model: InputsViewModel) => {\n      this.InputsViewModel = model;\n\n      if (this.InputViewModel != null && this.InputsViewModel.inputs != null) {\n        for (var i = 0; i < this.InputsViewModel.inputs.length; i++) {\r\n          if ((this.InputViewModel.filter?.id == this.InputsViewModel.inputs[i].filter?.id) &&\r\n            (this.InputViewModel.range?.id == this.InputsViewModel.inputs[i].range?.id)) {\r\n            this.InputViewModel = this.InputsViewModel.inputs[i];\r\n          }\r\n        }\r\n      }\n\n      this.Loading = false;\n    }, (error: Response) => {\n      if (error.status == 400)\n        console.log(error.json());\n      else {\n        console.log('An unexpected error occured');\n        console.log(error);\n      }\n\n      this.Loading = false;\n    });\n  }\n\n  private SaveInputs(): void {\n    if (this.InputsViewModel.inputs != null) {\n      this.Loading = true;\n\n      for (var i = 0; i < this.InputsViewModel.inputs.length; i++) {\n        this.InputsViewModel.inputs[i].position = i;\r\n      }\n\n      this.FiltersApiClient.saveInputsViewModel(this.InputsViewModel).subscribe(() => {\n        this.LoadInputs();\n      }, (error: Response) => {\n        if (error.status == 400)\n          console.log(error.json());\n        else {\n          console.log('An unexpected error occured');\n          console.log(error);\n        }\n\n        this.Loading = false;\n      });\r\n    }\r\n  }\n}\n","<app-beheer-nav></app-beheer-nav>\r\n\r\n<div *ngIf=\"Loading\">\r\n  <app-fab-loader></app-fab-loader>\r\n</div>\r\n\r\n<div *ngIf=\"!Loading\" class=\"main-content\">\r\n  <mat-card>\r\n    <mat-card-content>\r\n      <button mat-raised-button (click)=\"AddCategory()\">Categorie toevoegen</button>\r\n    </mat-card-content>\r\n  </mat-card>\r\n  <br />\r\n  <div class=\"displayflex\">\r\n    <div>\r\n      <mat-card>\r\n        <mat-card-content>\r\n          <div cdkDropList class=\"input-list\" (cdkDropListDropped)=\"drop($event)\">\r\n            <div class=\"input-item\" *ngFor=\"let input of InputsViewModel.inputs\" cdkDrag>\r\n              <ng-container *ngIf=\"input.filter\">\r\n                <span [ngClass]=\"{'selected': input.filter?.id == InputViewModel?.filter?.id }\">\r\n                  {{ input.filter.name }} (#{{ input.filter.id }})\r\n                </span>\r\n              </ng-container>\r\n              <ng-container *ngIf=\"input.range\">\r\n                <span [ngClass]=\"{'selected': input.range?.id == InputViewModel?.range?.id }\">\r\n                  {{ input.range.name }} (#{{ input.range.id }})\r\n                </span>\r\n                \r\n              </ng-container>\r\n              <button (click)=\"Open(input)\">Select</button>\r\n            </div>\r\n          </div>\r\n        </mat-card-content>\r\n      </mat-card>\r\n    </div>\r\n    <div class=\"flexauto\">\r\n      <mat-card>\r\n        <mat-card-content>\r\n         <div *ngIf=\"InputViewModel != undefined\">\r\n           <ng-container *ngIf=\"InputViewModel.filter\">\r\n             <div class=\"filter-name\">\r\n               <div class=\"flexauto\">\r\n                 Name: {{ InputViewModel.filter.name }}\r\n               </div>\r\n               <div>\r\n                 <button mat-raised-button (click)=\"Sort()\">Sort</button>\r\n               </div>\r\n             </div>\r\n             <div>\r\n               <div class=\"filter-name\">\r\n                 <div class=\"flexauto\">\r\n                   Requires\r\n                 </div>\r\n                 <button mat-raised-button (click)=\"RequireFilter()\">Filter</button>\r\n                 <button mat-raised-button (click)=\"RequireFilterOption()\">FilterOption</button>\r\n               </div>\r\n\r\n               <div *ngFor=\"let option of InputViewModel.filter.requiresFilterOptions\" class=\"required-option\" [ngClass]=\"{ 'AND': option.filterOptionRequiredType == 0, 'OR': option.filterOptionRequiredType == 1 }\">\r\n                 {{ option.requiredFilterName }}: {{ option.requiredFilterOptionName }}\r\n                 <button mat-raised-button (click)=\"RemoveRequireFilterOption(option)\">Remove</button>\r\n               </div>\r\n               <div *ngFor=\"let filter of InputViewModel.filter.requiresFilters\" class=\"required-option\">\r\n                 {{ filter.requiredFilterName }}\r\n                 <button mat-raised-button>Remove</button>\r\n               </div>\r\n             </div>\r\n             <div class=\"filter-options-container\">\r\n               <div *ngFor=\"let option of GetFilterOptions(); let i = index;\" class=\"filter-option\">\r\n                 <div class=\"filter-option-name\">\r\n                   {{ option.name }}\r\n                 </div>\r\n                 <button mat-raised-button (click)=\"RemoveFilterOption(option)\">Remove</button>\r\n               </div>\r\n             </div>\r\n           </ng-container>\r\n\r\n           <ng-container *ngIf=\"InputViewModel.range\">\r\n             <div class=\"filter-name\">\r\n               <div class=\"flexauto\">\r\n                 Name: {{ InputViewModel.range.name }}\r\n               </div>\r\n             </div>\r\n             <div>\r\n               <div class=\"filter-name\">\r\n                 <div class=\"flexauto\">\r\n                   Requires\r\n                 </div>\r\n                 <button mat-raised-button (click)=\"RequireRangeInputFilterOption()\">FilterOption</button>\r\n               </div>\r\n\r\n               <div *ngFor=\"let option of InputViewModel.range.requiresRangeInputFilterOptions\" class=\"required-option\" [ngClass]=\"{ 'AND': option.filterOptionRequiredType == 0, 'OR': option.filterOptionRequiredType == 1 }\">\r\n                 {{ option.requiredFilterName }}: {{ option.requiredFilterOptionName }}\r\n                 <button mat-raised-button (click)=\"RemoveRequireRangeInputFilterOption(option)\">Remove</button>\r\n               </div>\r\n             </div>\r\n           </ng-container>\r\n           \r\n         </div>\r\n        </mat-card-content>\r\n      </mat-card>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n"]}
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"beheer-filters.component.js","sourceRoot":"","sources":["../../../../../../../../../src/app/modules/fabrikantencore/beheer/components/beheer-filters/beheer-filters.component.ts","../../../../../../../../../src/app/modules/fabrikantencore/beheer/components/beheer-filters/beheer-filters.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAqB,SAAS,EAAU,MAAM,eAAe,CAAC;AACrE,OAAO,EAAgJ,uBAAuB,EAAmF,MAAM,gCAAgC,CAAC;AACxS,OAAO,EAAe,eAAe,EAAE,MAAM,wBAAwB,CAAC;;;;;;;;;;;;AAUtE,MAAM,OAAO,sBAAsB;IAQjC,YAAoB,gBAAkC,EAC7C,MAAiB,EAChB,iBAAoC;QAF1B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAC7C,WAAM,GAAN,MAAM,CAAW;QAChB,sBAAiB,GAAjB,iBAAiB,CAAmB;QARvC,YAAO,GAAY,IAAI,CAAC;QAIxB,mBAAc,GAA+B,SAAS,CAAC;IAIZ,CAAC;IAEnD,QAAQ;QACN,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED,IAAI,CAAC,KAA4B;QAC/B,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,IAAI,IAAI,EAAE;YACvC,eAAe,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,YAAY,CAAC,CAAC;YAEtF,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;IACH,CAAC;IAEM,YAAY,CAAC,MAA6B;QAC/C,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QAEpB,IAAI,OAAO,GAAG,IAAI,uBAAuB,EAAE,CAAC;QAE5C,OAAO,CAAC,cAAc,GAAG,MAAM,CAAC,EAAE,CAAC;QACnC,OAAO,CAAC,EAAE,GAAG,IAAI,CAAC;QAElB,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC7D,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC,EAAE,CAAC,KAAe,EAAE,EAAE;YACrB,IAAI,KAAK,CAAC,MAAM,IAAI,GAAG;gBACrB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;iBACvB;gBACH,OAAO,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC;gBAC3C,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;aACpB;YAED,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACvB,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,cAAc,CAAC,MAA6B;QACjD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QAEpB,IAAI,OAAO,GAAG,IAAI,uBAAuB,EAAE,CAAC;QAE5C,OAAO,CAAC,cAAc,GAAG,MAAM,CAAC,EAAE,CAAC;QACnC,OAAO,CAAC,EAAE,GAAG,KAAK,CAAC;QAEnB,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC7D,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC,EAAE,CAAC,KAAe,EAAE,EAAE;YACrB,IAAI,KAAK,CAAC,MAAM,IAAI,GAAG;gBACrB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;iBACvB;gBACH,OAAO,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC;gBAC3C,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;aACpB;YAED,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACvB,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,IAAI,CAAC,KAAqB;QAC/B,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;IAC9B,CAAC;IAEM,WAAW;IAElB,CAAC;IAEM,UAAU;QACf,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QAEpB,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,EAAE,CAAC,SAAS,CAAC,CAAC,KAAsB,EAAE,EAAE;YAC9E,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;YAE7B,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,IAAI,IAAI,EAAE;gBACtE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBAC3D,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,EAAE,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC;wBAC/E,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,EAAE,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,EAAE;wBAC7E,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;qBACtD;iBACF;aACF;YAED,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACvB,CAAC,EAAE,CAAC,KAAe,EAAE,EAAE;YACrB,IAAI,KAAK,CAAC,MAAM,IAAI,GAAG;gBACrB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;iBACvB;gBACH,OAAO,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC;gBAC3C,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;aACpB;YAED,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACvB,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,UAAU;QAChB,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,IAAI,IAAI,EAAE;YACvC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YAEpB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC3D,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC;aAC7C;YAED,IAAI,CAAC,gBAAgB,CAAC,mBAAmB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;gBAC7E,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,CAAC,EAAE,CAAC,KAAe,EAAE,EAAE;gBACrB,IAAI,KAAK,CAAC,MAAM,IAAI,GAAG;oBACrB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;qBACvB;oBACH,OAAO,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC;oBAC3C,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;iBACpB;gBAED,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACvB,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;;mHA7HU,sBAAsB;uGAAtB,sBAAsB,0DCZnC,qiEAsDA;2FD1Ca,sBAAsB;kBALlC,SAAS;+BACE,oBAAoB","sourcesContent":["import { ChangeDetectorRef, Component, OnInit } from '@angular/core';\nimport { FiltersApiClient, InputsViewModel, FilterOptionRequiredViewModel, RangeInputFilterOptionRequiredViewModel, InputViewModel, MoveFilterRequest, MoveFilterOptionRequest, FilterOptionViewModel, SetFilterRequiredRequest, SetFilterOptionRequiredRequest } from '../../../swagger/SwaggerClient';\r\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { BeheerSelectFilterDialogComponent } from '../beheer-select-filter-dialog/beheer-select-filter-dialog.component';\r\nimport { BeheerSelectFilteroptionDialogComponent } from '../beheer-select-filteroption-dialog/beheer-select-filteroption-dialog.component';\r\n\n@Component({\n  selector: 'app-beheer-filters',\n  templateUrl: './beheer-filters.component.html',\n  styleUrls: ['./beheer-filters.component.scss']\n})\nexport class BeheerFiltersComponent implements OnInit {\n\n  public Loading: boolean = true;\n\n  public InputsViewModel: InputsViewModel;\n\n  public InputViewModel: InputViewModel | undefined = undefined;\n\n  constructor(private FiltersApiClient: FiltersApiClient,\n    public dialog: MatDialog,\r\n    private ChangeDetectorRef: ChangeDetectorRef) { }\n\n  ngOnInit(): void {\n    this.LoadInputs();\n  }\n\n  drop(event: CdkDragDrop<string[]>) {\r\n    if (this.InputsViewModel.inputs != null) {\r\n      moveItemInArray(this.InputsViewModel.inputs, event.previousIndex, event.currentIndex);\r\n\r\n      this.SaveInputs();\r\n    }\r\n  }\n\n  public MoveUpOption(option: FilterOptionViewModel) {\n    this.Loading = true;\n\n    var request = new MoveFilterOptionRequest();\n\n    request.filterOptionId = option.id;\n    request.up = true;\n\n    this.FiltersApiClient.moveFilterOption(request).subscribe(() => {\n      this.LoadInputs();\n    }, (error: Response) => {\n      if (error.status == 400)\n        console.log(error.json());\n      else {\n        console.log('An unexpected error occured');\n        console.log(error);\n      }\n\n      this.Loading = false;\n    });\r\n  }\n\n  public MoveDownOption(option: FilterOptionViewModel) {\n    this.Loading = true;\n\n    var request = new MoveFilterOptionRequest();\n\n    request.filterOptionId = option.id;\n    request.up = false;\n\n    this.FiltersApiClient.moveFilterOption(request).subscribe(() => {\n      this.LoadInputs();\n    }, (error: Response) => {\n      if (error.status == 400)\n        console.log(error.json());\n      else {\n        console.log('An unexpected error occured');\n        console.log(error);\n      }\n\n      this.Loading = false;\n    });\r\n  }\n\n  public Open(input: InputViewModel) {\n    this.InputViewModel = input;\r\n  }\n\n  public AddCategory(): void {\n\r\n  }\n\n  public LoadInputs(): void {\n    this.Loading = true;\n\n    this.FiltersApiClient.getInputsViewModel().subscribe((model: InputsViewModel) => {\n      this.InputsViewModel = model;\n\n      if (this.InputViewModel != null && this.InputsViewModel.inputs != null) {\n        for (var i = 0; i < this.InputsViewModel.inputs.length; i++) {\r\n          if ((this.InputViewModel.filter?.id == this.InputsViewModel.inputs[i].filter?.id) &&\r\n            (this.InputViewModel.range?.id == this.InputsViewModel.inputs[i].range?.id)) {\r\n            this.InputViewModel = this.InputsViewModel.inputs[i];\r\n          }\r\n        }\r\n      }\n\n      this.Loading = false;\n    }, (error: Response) => {\n      if (error.status == 400)\n        console.log(error.json());\n      else {\n        console.log('An unexpected error occured');\n        console.log(error);\n      }\n\n      this.Loading = false;\n    });\n  }\n\n  private SaveInputs(): void {\n    if (this.InputsViewModel.inputs != null) {\n      this.Loading = true;\n\n      for (var i = 0; i < this.InputsViewModel.inputs.length; i++) {\n        this.InputsViewModel.inputs[i].position = i;\r\n      }\n\n      this.FiltersApiClient.saveInputsViewModel(this.InputsViewModel).subscribe(() => {\n        this.LoadInputs();\n      }, (error: Response) => {\n        if (error.status == 400)\n          console.log(error.json());\n        else {\n          console.log('An unexpected error occured');\n          console.log(error);\n        }\n\n        this.Loading = false;\n      });\r\n    }\r\n  }\n}\n","<app-beheer-nav></app-beheer-nav>\r\n\r\n<div *ngIf=\"Loading\">\r\n  <app-fab-loader></app-fab-loader>\r\n</div>\r\n\r\n<div *ngIf=\"!Loading\" class=\"main-content\">\r\n  <mat-card>\r\n    <mat-card-content>\r\n      <button mat-raised-button (click)=\"AddCategory()\">Categorie toevoegen</button>\r\n    </mat-card-content>\r\n  </mat-card>\r\n  <br />\r\n  <div class=\"displayflex\">\r\n    <div>\r\n      <mat-card>\r\n        <mat-card-content>\r\n          <div cdkDropList class=\"input-list\" (cdkDropListDropped)=\"drop($event)\">\r\n            <div class=\"input-item\" *ngFor=\"let input of InputsViewModel.inputs\" cdkDrag>\r\n              <ng-container *ngIf=\"input.filter\">\r\n                <span [ngClass]=\"{'selected': input.filter?.id == InputViewModel?.filter?.id }\">\r\n                  {{ input.filter.name }} (#{{ input.filter.id }})\r\n                </span>\r\n              </ng-container>\r\n              <ng-container *ngIf=\"input.range\">\r\n                <span [ngClass]=\"{'selected': input.range?.id == InputViewModel?.range?.id }\">\r\n                  {{ input.range.name }} (#{{ input.range.id }})\r\n                </span>\r\n                \r\n              </ng-container>\r\n              <button (click)=\"Open(input)\">Select</button>\r\n            </div>\r\n          </div>\r\n        </mat-card-content>\r\n      </mat-card>\r\n    </div>\r\n    <div class=\"flexauto\">\r\n      <mat-card>\r\n        <mat-card-content>\r\n         <div *ngIf=\"InputViewModel != undefined\">\r\n           <ng-container *ngIf=\"InputViewModel.filter\">\r\n             <app-beheer-filter [filter]=\"InputViewModel.filter\" (reload)=\"LoadInputs()\"></app-beheer-filter>\r\n           </ng-container>\r\n\r\n           <ng-container *ngIf=\"InputViewModel.range\">\r\n            <app-beheer-rangeinput [rangeinput]=\"InputViewModel.range\" (reload)=\"LoadInputs()\"></app-beheer-rangeinput>\r\n           </ng-container>\r\n         </div>\r\n        </mat-card-content>\r\n      </mat-card>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n"]}
@@ -0,0 +1,87 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { SetFilterOptionRequiredRequest } from '../../../swagger/SwaggerClient';
3
+ import { BeheerSelectFilteroptionDialogComponent } from '../beheer-select-filteroption-dialog/beheer-select-filteroption-dialog.component';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../../../swagger/SwaggerClient";
6
+ import * as i2 from "@angular/material/dialog";
7
+ import * as i3 from "@angular/common";
8
+ import * as i4 from "@angular/material/form-field";
9
+ import * as i5 from "@angular/material/input";
10
+ import * as i6 from "@angular/forms";
11
+ import * as i7 from "@angular/material/button";
12
+ export class BeheerRangeinputComponent {
13
+ constructor(FiltersApiClient, dialog, ChangeDetectorRef) {
14
+ this.FiltersApiClient = FiltersApiClient;
15
+ this.dialog = dialog;
16
+ this.ChangeDetectorRef = ChangeDetectorRef;
17
+ this.reload = new EventEmitter();
18
+ }
19
+ RequireRangeInputFilterOption() {
20
+ var dialogRef = this.dialog.open(BeheerSelectFilteroptionDialogComponent);
21
+ dialogRef.afterClosed().subscribe((result) => {
22
+ if (result?.filteroption != null && this.rangeinput) {
23
+ if (result.filteroption > 0) {
24
+ if (confirm("Weet je het zeker?")) {
25
+ this.ChangeDetectorRef.detectChanges();
26
+ var request = new SetFilterOptionRequiredRequest();
27
+ request.filterId = 0;
28
+ request.rangeInputId = this.rangeinput.id;
29
+ request.filterOptionId = result.filteroption;
30
+ this.FiltersApiClient.setFilterOptionRequired(request).subscribe(() => {
31
+ this.reload.emit();
32
+ }, (error) => {
33
+ if (error.status == 400)
34
+ console.log(error.json());
35
+ else {
36
+ console.log('An unexpected error occured');
37
+ console.log(error);
38
+ }
39
+ });
40
+ }
41
+ }
42
+ }
43
+ });
44
+ }
45
+ RemoveRequireRangeInputFilterOption(require) {
46
+ if (confirm("Weet je het zeker?")) {
47
+ this.ChangeDetectorRef.detectChanges();
48
+ var request = new SetFilterOptionRequiredRequest();
49
+ request.filterId = 0;
50
+ request.rangeInputId = require.affectedRangeInputId;
51
+ request.filterOptionId = require.requiredFilterOptionId;
52
+ this.FiltersApiClient.removeFilterOptionRequired(request).subscribe(() => {
53
+ this.reload.emit();
54
+ }, (error) => {
55
+ if (error.status == 400)
56
+ console.log(error.json());
57
+ else {
58
+ console.log('An unexpected error occured');
59
+ console.log(error);
60
+ }
61
+ });
62
+ }
63
+ }
64
+ Save() {
65
+ this.FiltersApiClient.saveRangeInputViewModel(this.rangeinput).subscribe(() => {
66
+ this.reload.emit();
67
+ }, (error) => {
68
+ if (error.status == 400)
69
+ console.log(error.json());
70
+ else {
71
+ console.log('An unexpected error occured');
72
+ console.log(error);
73
+ }
74
+ });
75
+ }
76
+ }
77
+ BeheerRangeinputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: BeheerRangeinputComponent, deps: [{ token: i1.FiltersApiClient }, { token: i2.MatDialog }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
78
+ BeheerRangeinputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: BeheerRangeinputComponent, selector: "app-beheer-rangeinput", inputs: { rangeinput: "rangeinput" }, outputs: { reload: "reload" }, ngImport: i0, template: "<div class=\"filter-name\">\r\n <div class=\"flexauto\">\r\n <mat-form-field appearance=\"fill\" class=\"full-width\">\r\n <mat-label>Name</mat-label>\r\n <input matInput [(ngModel)]=\"rangeinput.name\">\r\n </mat-form-field>\r\n </div>\r\n <div class=\"save-div\">\r\n <button mat-raised-button (click)=\"Save()\">Save</button>\r\n </div>\r\n</div>\r\n<div>\r\n <div class=\"filter-name\">\r\n <div class=\"flexauto\">\r\n Requires\r\n </div>\r\n <button mat-raised-button (click)=\"RequireRangeInputFilterOption()\">FilterOption</button>\r\n </div>\r\n\r\n <div *ngFor=\"let option of rangeinput.requiresRangeInputFilterOptions\" class=\"required-option\" [ngClass]=\"{ 'AND': option.filterOptionRequiredType == 0, 'OR': option.filterOptionRequiredType == 1 }\">\r\n {{ option.requiredFilterName }}: {{ option.requiredFilterOptionName }}\r\n <button mat-raised-button (click)=\"RemoveRequireRangeInputFilterOption(option)\">Remove</button>\r\n </div>\r\n</div>\r\n", styles: [".displayflex{display:flex;gap:10px}.save-div{padding-left:10px}.required-option{border:1px solid #000;border-radius:2px;padding:2px;margin:2px}.AND{border-color:red}.OR{border-color:#0f0}.filter-row{font-size:20px;line-height:30px;margin-bottom:10px}.flexauto{flex:auto}.main-content{padding:10px}.filter-name{font-size:20px;padding:10px;border-bottom:1px solid #000;display:flex}.filter-option:hover{background-color:gray}.filter-options-container{border:1px solid #000;padding:10px;margin:10px}.filter-option{padding:5px;border-bottom:1px solid #000;display:flex;gap:5px}.filter-option-name{flex:auto;line-height:30px;font-size:20px}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i5.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i6.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: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i7.MatButton, 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"] }] });
79
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: BeheerRangeinputComponent, decorators: [{
80
+ type: Component,
81
+ args: [{ selector: 'app-beheer-rangeinput', template: "<div class=\"filter-name\">\r\n <div class=\"flexauto\">\r\n <mat-form-field appearance=\"fill\" class=\"full-width\">\r\n <mat-label>Name</mat-label>\r\n <input matInput [(ngModel)]=\"rangeinput.name\">\r\n </mat-form-field>\r\n </div>\r\n <div class=\"save-div\">\r\n <button mat-raised-button (click)=\"Save()\">Save</button>\r\n </div>\r\n</div>\r\n<div>\r\n <div class=\"filter-name\">\r\n <div class=\"flexauto\">\r\n Requires\r\n </div>\r\n <button mat-raised-button (click)=\"RequireRangeInputFilterOption()\">FilterOption</button>\r\n </div>\r\n\r\n <div *ngFor=\"let option of rangeinput.requiresRangeInputFilterOptions\" class=\"required-option\" [ngClass]=\"{ 'AND': option.filterOptionRequiredType == 0, 'OR': option.filterOptionRequiredType == 1 }\">\r\n {{ option.requiredFilterName }}: {{ option.requiredFilterOptionName }}\r\n <button mat-raised-button (click)=\"RemoveRequireRangeInputFilterOption(option)\">Remove</button>\r\n </div>\r\n</div>\r\n", styles: [".displayflex{display:flex;gap:10px}.save-div{padding-left:10px}.required-option{border:1px solid #000;border-radius:2px;padding:2px;margin:2px}.AND{border-color:red}.OR{border-color:#0f0}.filter-row{font-size:20px;line-height:30px;margin-bottom:10px}.flexauto{flex:auto}.main-content{padding:10px}.filter-name{font-size:20px;padding:10px;border-bottom:1px solid #000;display:flex}.filter-option:hover{background-color:gray}.filter-options-container{border:1px solid #000;padding:10px;margin:10px}.filter-option{padding:5px;border-bottom:1px solid #000;display:flex;gap:5px}.filter-option-name{flex:auto;line-height:30px;font-size:20px}\n"] }]
82
+ }], ctorParameters: function () { return [{ type: i1.FiltersApiClient }, { type: i2.MatDialog }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { rangeinput: [{
83
+ type: Input
84
+ }], reload: [{
85
+ type: Output
86
+ }] } });
87
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"beheer-rangeinput.component.js","sourceRoot":"","sources":["../../../../../../../../../src/app/modules/fabrikantencore/beheer/components/beheer-rangeinput/beheer-rangeinput.component.ts","../../../../../../../../../src/app/modules/fabrikantencore/beheer/components/beheer-rangeinput/beheer-rangeinput.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, Output } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { FiltersApiClient, RangeInputFilterOptionRequiredViewModel, RangeInputViewModel, SetFilterOptionRequiredRequest } from '../../../swagger/SwaggerClient';\r\nimport { BeheerSelectFilteroptionDialogComponent } from '../beheer-select-filteroption-dialog/beheer-select-filteroption-dialog.component';\r\n\n@Component({\n  selector: 'app-beheer-rangeinput',\n  templateUrl: './beheer-rangeinput.component.html',\n  styleUrls: ['./beheer-rangeinput.component.scss']\n})\nexport class BeheerRangeinputComponent {\n  @Input() rangeinput: RangeInputViewModel;\n\n  @Output() reload: EventEmitter<void> = new EventEmitter<void>();\n\n  constructor(private FiltersApiClient: FiltersApiClient,\n    public dialog: MatDialog,\r\n    private ChangeDetectorRef: ChangeDetectorRef) { }\n\n  public RequireRangeInputFilterOption(): void {\n    var dialogRef = this.dialog.open(BeheerSelectFilteroptionDialogComponent);\r\n\r\n    dialogRef.afterClosed().subscribe((result: any) => {\r\n      if (result?.filteroption != null && this.rangeinput) {\r\n        if (result.filteroption > 0) {\r\n          if (confirm(\"Weet je het zeker?\")) {\r\n\r\n            this.ChangeDetectorRef.detectChanges();\r\n\r\n            var request = new SetFilterOptionRequiredRequest();\r\n\r\n            request.filterId = 0;\r\n            request.rangeInputId = this.rangeinput.id;\r\n            request.filterOptionId = result.filteroption;\r\n\r\n            this.FiltersApiClient.setFilterOptionRequired(request).subscribe(() => {\n              this.reload.emit();\n            }, (error: Response) => {\n              if (error.status == 400)\n                console.log(error.json());\n              else {\n                console.log('An unexpected error occured');\n                console.log(error);\n              }\n            });\r\n          }\r\n        }\r\n      }\r\n    });\r\n  }\n\n  public RemoveRequireRangeInputFilterOption(require: RangeInputFilterOptionRequiredViewModel): void {\n    if (confirm(\"Weet je het zeker?\")) {\r\n\r\n      this.ChangeDetectorRef.detectChanges();\r\n\r\n      var request = new SetFilterOptionRequiredRequest();\r\n\r\n      request.filterId = 0;\r\n      request.rangeInputId = require.affectedRangeInputId;\r\n      request.filterOptionId = require.requiredFilterOptionId;\r\n\r\n      this.FiltersApiClient.removeFilterOptionRequired(request).subscribe(() => {\n        this.reload.emit();\n      }, (error: Response) => {\n        if (error.status == 400)\n          console.log(error.json());\n        else {\n          console.log('An unexpected error occured');\n          console.log(error);\n        }\n      });\r\n    }\r\n  }\n\n  public Save(): void {\n    this.FiltersApiClient.saveRangeInputViewModel(this.rangeinput).subscribe(() => {\n      this.reload.emit();\n    }, (error: Response) => {\n      if (error.status == 400)\n        console.log(error.json());\n      else {\n        console.log('An unexpected error occured');\n        console.log(error);\n      }\n    });\r\n  }\n}\n","<div class=\"filter-name\">\r\n  <div class=\"flexauto\">\r\n    <mat-form-field appearance=\"fill\" class=\"full-width\">\r\n      <mat-label>Name</mat-label>\r\n      <input matInput [(ngModel)]=\"rangeinput.name\">\r\n    </mat-form-field>\r\n  </div>\r\n  <div class=\"save-div\">\r\n    <button mat-raised-button (click)=\"Save()\">Save</button>\r\n  </div>\r\n</div>\r\n<div>\r\n  <div class=\"filter-name\">\r\n    <div class=\"flexauto\">\r\n      Requires\r\n    </div>\r\n    <button mat-raised-button (click)=\"RequireRangeInputFilterOption()\">FilterOption</button>\r\n  </div>\r\n\r\n  <div *ngFor=\"let option of rangeinput.requiresRangeInputFilterOptions\" class=\"required-option\" [ngClass]=\"{ 'AND': option.filterOptionRequiredType == 0, 'OR': option.filterOptionRequiredType == 1 }\">\r\n    {{ option.requiredFilterName }}: {{ option.requiredFilterOptionName }}\r\n    <button mat-raised-button (click)=\"RemoveRequireRangeInputFilterOption(option)\">Remove</button>\r\n  </div>\r\n</div>\r\n"]}