fabrikantencore 2.3.14 → 2.3.19

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.
Files changed (19) hide show
  1. package/esm2020/src/app/modules/fabrikantencore/beheer/components/beheer-filter/beheer-filter.component.mjs +218 -0
  2. package/esm2020/src/app/modules/fabrikantencore/beheer/components/beheer-filters/beheer-filters.component.mjs +6 -166
  3. package/esm2020/src/app/modules/fabrikantencore/beheer/components/beheer-products/beheer-products-eigenschap/beheer-products-eigenschap.component.mjs +30 -41
  4. package/esm2020/src/app/modules/fabrikantencore/beheer/components/beheer-rangeinput/beheer-rangeinput.component.mjs +87 -0
  5. package/esm2020/src/app/modules/fabrikantencore/components/fab-actionmenu/fab-actionmenu.component.mjs +13 -5
  6. package/esm2020/src/app/modules/fabrikantencore/fabrikantencore.module.mjs +9 -3
  7. package/esm2020/src/app/modules/fabrikantencore/swagger/SwaggerClient.mjs +237 -1
  8. package/fesm2015/fabrikantencore.mjs +693 -341
  9. package/fesm2015/fabrikantencore.mjs.map +1 -1
  10. package/fesm2020/fabrikantencore.mjs +689 -333
  11. package/fesm2020/fabrikantencore.mjs.map +1 -1
  12. package/package.json +1 -1
  13. package/src/app/modules/fabrikantencore/beheer/components/beheer-filter/beheer-filter.component.d.ts +28 -0
  14. package/src/app/modules/fabrikantencore/beheer/components/beheer-filters/beheer-filters.component.d.ts +2 -10
  15. package/src/app/modules/fabrikantencore/beheer/components/beheer-products/beheer-products-eigenschap/beheer-products-eigenschap.component.d.ts +1 -0
  16. package/src/app/modules/fabrikantencore/beheer/components/beheer-rangeinput/beheer-rangeinput.component.d.ts +17 -0
  17. package/src/app/modules/fabrikantencore/components/fab-actionmenu/fab-actionmenu.component.d.ts +1 -0
  18. package/src/app/modules/fabrikantencore/fabrikantencore.module.d.ts +29 -27
  19. package/src/app/modules/fabrikantencore/swagger/SwaggerClient.d.ts +24 -0
@@ -0,0 +1,218 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { MoveFilterRequest, SetFilterOptionRequiredRequest, SetFilterRequiredRequest } from '../../../swagger/SwaggerClient';
3
+ import { BeheerSelectFilterDialogComponent } from '../beheer-select-filter-dialog/beheer-select-filter-dialog.component';
4
+ import { BeheerSelectFilteroptionDialogComponent } from '../beheer-select-filteroption-dialog/beheer-select-filteroption-dialog.component';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "../../../swagger/SwaggerClient";
7
+ import * as i2 from "@angular/material/dialog";
8
+ import * as i3 from "@angular/common";
9
+ import * as i4 from "@angular/material/form-field";
10
+ import * as i5 from "@angular/material/input";
11
+ import * as i6 from "@angular/forms";
12
+ import * as i7 from "@angular/material/button";
13
+ import * as i8 from "@angular/material/card";
14
+ import * as i9 from "@angular/cdk/drag-drop";
15
+ export class BeheerFilterComponent {
16
+ constructor(FiltersApiClient, dialog, ChangeDetectorRef) {
17
+ this.FiltersApiClient = FiltersApiClient;
18
+ this.dialog = dialog;
19
+ this.ChangeDetectorRef = ChangeDetectorRef;
20
+ this.reload = new EventEmitter();
21
+ this.FilterOptionViewModel = null;
22
+ }
23
+ drop(event) {
24
+ //if (this.InputsViewModel.inputs != null) {
25
+ // moveItemInArray(this.InputsViewModel.inputs, event.previousIndex, event.currentIndex);
26
+ // this.SaveInputs();
27
+ //}
28
+ }
29
+ Open(option) {
30
+ this.FilterOptionViewModel = option;
31
+ }
32
+ Sort() {
33
+ if (this.filter != null) {
34
+ var request = new MoveFilterRequest();
35
+ request.filterId = this.filter.id;
36
+ this.FiltersApiClient.sortFilter(request).subscribe(() => {
37
+ this.reload.emit();
38
+ }, (error) => {
39
+ if (error.status == 400)
40
+ console.log(error.json());
41
+ else {
42
+ console.log('An unexpected error occured');
43
+ console.log(error);
44
+ }
45
+ });
46
+ }
47
+ }
48
+ RequireFilter() {
49
+ var dialogRef = this.dialog.open(BeheerSelectFilterDialogComponent);
50
+ dialogRef.afterClosed().subscribe((result) => {
51
+ if (result?.filter != null && this.filter != null) {
52
+ if (result.filter > 0) {
53
+ if (confirm("Weet je het zeker?")) {
54
+ this.ChangeDetectorRef.detectChanges();
55
+ var request = new SetFilterRequiredRequest();
56
+ request.filterAffectsId = this.filter.id;
57
+ request.filterRequiredId = result.filter;
58
+ this.FiltersApiClient.setFilterRequired(request).subscribe(() => {
59
+ this.reload.emit();
60
+ }, (error) => {
61
+ if (error.status == 400)
62
+ console.log(error.json());
63
+ else {
64
+ console.log('An unexpected error occured');
65
+ console.log(error);
66
+ }
67
+ });
68
+ }
69
+ }
70
+ }
71
+ });
72
+ }
73
+ RequireFilterOption() {
74
+ var dialogRef = this.dialog.open(BeheerSelectFilteroptionDialogComponent);
75
+ dialogRef.afterClosed().subscribe((result) => {
76
+ if (result?.filteroption != null && this.filter) {
77
+ if (result.filteroption > 0) {
78
+ if (confirm("Weet je het zeker?")) {
79
+ this.ChangeDetectorRef.detectChanges();
80
+ var request = new SetFilterOptionRequiredRequest();
81
+ request.filterId = this.filter.id;
82
+ request.rangeInputId = 0;
83
+ request.filterOptionId = result.filteroption;
84
+ this.FiltersApiClient.setFilterOptionRequired(request).subscribe(() => {
85
+ this.reload.emit();
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
+ });
94
+ }
95
+ }
96
+ }
97
+ });
98
+ }
99
+ RequireFilterOptionFilterOption() {
100
+ var dialogRef = this.dialog.open(BeheerSelectFilteroptionDialogComponent);
101
+ dialogRef.afterClosed().subscribe((result) => {
102
+ if (result?.filteroption != null && this.filter) {
103
+ if (result.filteroption > 0) {
104
+ if (confirm("Weet je het zeker?")) {
105
+ this.ChangeDetectorRef.detectChanges();
106
+ //var request = new SetFilterOptionRequiredRequest();
107
+ //request.filterId = this.filter.id;
108
+ //request.rangeInputId = 0;
109
+ //request.filterOptionId = result.filteroption;
110
+ //this.FiltersApiClient.setFilterOptionRequired(request).subscribe(() => {
111
+ // this.reload.emit();
112
+ //}, (error: Response) => {
113
+ // if (error.status == 400)
114
+ // console.log(error.json());
115
+ // else {
116
+ // console.log('An unexpected error occured');
117
+ // console.log(error);
118
+ // }
119
+ //});
120
+ }
121
+ }
122
+ }
123
+ });
124
+ }
125
+ RemoveRequireFilterOption(require) {
126
+ if (confirm("Weet je het zeker?")) {
127
+ this.ChangeDetectorRef.detectChanges();
128
+ var request = new SetFilterOptionRequiredRequest();
129
+ request.filterId = require.affectedFilterId;
130
+ request.rangeInputId = 0;
131
+ request.filterOptionId = require.requiredFilterOptionId;
132
+ this.FiltersApiClient.removeFilterOptionRequired(request).subscribe(() => {
133
+ this.reload.emit();
134
+ }, (error) => {
135
+ if (error.status == 400)
136
+ console.log(error.json());
137
+ else {
138
+ console.log('An unexpected error occured');
139
+ console.log(error);
140
+ }
141
+ });
142
+ }
143
+ }
144
+ RemoveRequireFilterOptionFilterOption(require) {
145
+ if (confirm("Weet je het zeker?")) {
146
+ this.ChangeDetectorRef.detectChanges();
147
+ //var request = new SetFilterOptionRequiredRequest();
148
+ //request.filterId = require.affectedFilterId;
149
+ //request.rangeInputId = 0;
150
+ //request.filterOptionId = require.requiredFilterOptionId;
151
+ //this.FiltersApiClient.removeFilterOptionRequired(request).subscribe(() => {
152
+ // this.reload.emit();
153
+ //}, (error: Response) => {
154
+ // if (error.status == 400)
155
+ // console.log(error.json());
156
+ // else {
157
+ // console.log('An unexpected error occured');
158
+ // console.log(error);
159
+ // }
160
+ //});
161
+ }
162
+ }
163
+ RemoveFilterOption(option) {
164
+ this.FiltersApiClient.removeFilterOption(option).subscribe(() => {
165
+ this.reload.emit();
166
+ }, (error) => {
167
+ if (error.status == 400)
168
+ console.log(error.json());
169
+ else {
170
+ console.log('An unexpected error occured');
171
+ console.log(error);
172
+ }
173
+ });
174
+ }
175
+ SaveFilterOption(option) {
176
+ this.FiltersApiClient.saveFilterOption(option).subscribe(() => {
177
+ this.reload.emit();
178
+ }, (error) => {
179
+ if (error.status == 400)
180
+ console.log(error.json());
181
+ else {
182
+ console.log('An unexpected error occured');
183
+ console.log(error);
184
+ }
185
+ });
186
+ }
187
+ GetFilterOptions() {
188
+ if (this.filter?.filterOptionViewModels != undefined) {
189
+ return this.filter.filterOptionViewModels;
190
+ }
191
+ else {
192
+ return new Array();
193
+ }
194
+ }
195
+ Save() {
196
+ this.FiltersApiClient.saveFilterViewModel(this.filter).subscribe(() => {
197
+ this.reload.emit();
198
+ }, (error) => {
199
+ if (error.status == 400)
200
+ console.log(error.json());
201
+ else {
202
+ console.log('An unexpected error occured');
203
+ console.log(error);
204
+ }
205
+ });
206
+ }
207
+ }
208
+ BeheerFilterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: BeheerFilterComponent, deps: [{ token: i1.FiltersApiClient }, { token: i2.MatDialog }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
209
+ BeheerFilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: BeheerFilterComponent, selector: "app-beheer-filter", inputs: { filter: "filter" }, 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)]=\"filter.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)=\"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 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 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>\r\n <button mat-raised-button (click)=\"Sort()\">Sort</button>\r\n</div>\r\n<div class=\"filter-options-container\">\r\n <div cdkDropList class=\"input-list\" (cdkDropListDropped)=\"drop($event)\">\r\n <div class=\"input-item\" *ngFor=\"let option of GetFilterOptions()\" cdkDrag>\r\n <span [ngClass]=\"{'selected': option.id == FilterOptionViewModel?.id }\">\r\n {{ option.name }}\r\n </span>\r\n\r\n <button (click)=\"Open(option)\">Select</button>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<mat-card *ngIf=\"FilterOptionViewModel != null\">\r\n <mat-card-content>\r\n <div class=\"displayflex\">\r\n <div class=\"filter-option-name flexauto\">\r\n <mat-form-field appearance=\"fill\" class=\"full-width\">\r\n <mat-label>Name (#{{ FilterOptionViewModel.id }})</mat-label>\r\n <input matInput [(ngModel)]=\"FilterOptionViewModel.name\">\r\n </mat-form-field>\r\n </div>\r\n <button mat-raised-button (click)=\"SaveFilterOption(FilterOptionViewModel)\">Save</button>\r\n <button mat-raised-button (click)=\"RemoveFilterOption(FilterOptionViewModel)\">Remove</button>\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)=\"RequireFilterOptionFilterOption()\">FilterOption</button>\r\n </div>\r\n\r\n <div *ngFor=\"let option of FilterOptionViewModel.required\" class=\"required-option\">\r\n {{ option.filterName }}: {{ option.filterOptionName }}\r\n <button mat-raised-button (click)=\"RemoveRequireFilterOptionFilterOption(option)\">Remove</button>\r\n </div>\r\n </div>\r\n </mat-card-content>\r\n</mat-card>\r\n\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}.input-list{border:solid 1px #ccc;display:block;background:white;border-radius:4px}.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.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"] }, { kind: "component", type: i8.MatCard, selector: "mat-card", exportAs: ["matCard"] }, { kind: "directive", type: i8.MatCardContent, selector: "mat-card-content, [mat-card-content], [matCardContent]" }, { kind: "directive", type: i9.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: i9.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }] });
210
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: BeheerFilterComponent, decorators: [{
211
+ type: Component,
212
+ args: [{ selector: 'app-beheer-filter', 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)]=\"filter.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)=\"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 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 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>\r\n <button mat-raised-button (click)=\"Sort()\">Sort</button>\r\n</div>\r\n<div class=\"filter-options-container\">\r\n <div cdkDropList class=\"input-list\" (cdkDropListDropped)=\"drop($event)\">\r\n <div class=\"input-item\" *ngFor=\"let option of GetFilterOptions()\" cdkDrag>\r\n <span [ngClass]=\"{'selected': option.id == FilterOptionViewModel?.id }\">\r\n {{ option.name }}\r\n </span>\r\n\r\n <button (click)=\"Open(option)\">Select</button>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<mat-card *ngIf=\"FilterOptionViewModel != null\">\r\n <mat-card-content>\r\n <div class=\"displayflex\">\r\n <div class=\"filter-option-name flexauto\">\r\n <mat-form-field appearance=\"fill\" class=\"full-width\">\r\n <mat-label>Name (#{{ FilterOptionViewModel.id }})</mat-label>\r\n <input matInput [(ngModel)]=\"FilterOptionViewModel.name\">\r\n </mat-form-field>\r\n </div>\r\n <button mat-raised-button (click)=\"SaveFilterOption(FilterOptionViewModel)\">Save</button>\r\n <button mat-raised-button (click)=\"RemoveFilterOption(FilterOptionViewModel)\">Remove</button>\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)=\"RequireFilterOptionFilterOption()\">FilterOption</button>\r\n </div>\r\n\r\n <div *ngFor=\"let option of FilterOptionViewModel.required\" class=\"required-option\">\r\n {{ option.filterName }}: {{ option.filterOptionName }}\r\n <button mat-raised-button (click)=\"RemoveRequireFilterOptionFilterOption(option)\">Remove</button>\r\n </div>\r\n </div>\r\n </mat-card-content>\r\n</mat-card>\r\n\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}.input-list{border:solid 1px #ccc;display:block;background:white;border-radius:4px}.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"] }]
213
+ }], ctorParameters: function () { return [{ type: i1.FiltersApiClient }, { type: i2.MatDialog }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { filter: [{
214
+ type: Input
215
+ }], reload: [{
216
+ type: Output
217
+ }] } });
218
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"beheer-filter.component.js","sourceRoot":"","sources":["../../../../../../../../../src/app/modules/fabrikantencore/beheer/components/beheer-filter/beheer-filter.component.ts","../../../../../../../../../src/app/modules/fabrikantencore/beheer/components/beheer-filter/beheer-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop } from '@angular/cdk/drag-drop';\r\nimport { ChangeDetectorRef, Component, EventEmitter, Input, Output } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { FilterOptionFilterOptionRequiredViewModel, FilterOptionRequiredViewModel, FilterOptionViewModel, FiltersApiClient, FilterViewModel, MoveFilterRequest, SetFilterOptionRequiredRequest, SetFilterRequiredRequest } from '../../../swagger/SwaggerClient';\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-filter',\n  templateUrl: './beheer-filter.component.html',\n  styleUrls: ['./beheer-filter.component.scss']\n})\nexport class BeheerFilterComponent {\n  @Input() filter: FilterViewModel;\n\n  @Output() reload: EventEmitter<void> = new EventEmitter<void>();\n\n  public FilterOptionViewModel: FilterOptionViewModel | null = null;\n\n  constructor(private FiltersApiClient: FiltersApiClient,\n    public dialog: MatDialog,\r\n    private ChangeDetectorRef: ChangeDetectorRef) { }\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 Open(option: FilterOptionViewModel) {\n    this.FilterOptionViewModel = option;\r\n  }\n\n  public Sort(): void {\n    if (this.filter != null) {\n      var request = new MoveFilterRequest();\n\n      request.filterId = this.filter.id;\n\n      this.FiltersApiClient.sortFilter(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 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.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.filter.id;\r\n            request.filterRequiredId = result.filter;\r\n\r\n            this.FiltersApiClient.setFilterRequired(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 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.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.filter.id;\r\n            request.rangeInputId = 0;\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 RequireFilterOptionFilterOption(): void {\n    var dialogRef = this.dialog.open(BeheerSelectFilteroptionDialogComponent);\r\n\r\n    dialogRef.afterClosed().subscribe((result: any) => {\r\n      if (result?.filteroption != null && this.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.filter.id;\r\n            //request.rangeInputId = 0;\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 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.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 RemoveRequireFilterOptionFilterOption(require: FilterOptionFilterOptionRequiredViewModel): 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.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 RemoveFilterOption(option: FilterOptionViewModel): void {\n    this.FiltersApiClient.removeFilterOption(option).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  public SaveFilterOption(option: FilterOptionViewModel): void {\n    this.FiltersApiClient.saveFilterOption(option).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  public GetFilterOptions(): FilterOptionViewModel[] {\n    if (this.filter?.filterOptionViewModels != undefined) {\n      return this.filter.filterOptionViewModels;\r\n    }\r\n    else {\r\n      return new Array<FilterOptionViewModel>();\r\n    }\r\n  }\n\n  public Save(): void {\n    this.FiltersApiClient.saveFilterViewModel(this.filter).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)]=\"filter.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)=\"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 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 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>\r\n  <button mat-raised-button (click)=\"Sort()\">Sort</button>\r\n</div>\r\n<div class=\"filter-options-container\">\r\n  <div cdkDropList class=\"input-list\" (cdkDropListDropped)=\"drop($event)\">\r\n    <div class=\"input-item\" *ngFor=\"let option of GetFilterOptions()\" cdkDrag>\r\n      <span [ngClass]=\"{'selected': option.id == FilterOptionViewModel?.id }\">\r\n        {{ option.name }}\r\n      </span>\r\n\r\n      <button (click)=\"Open(option)\">Select</button>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<mat-card *ngIf=\"FilterOptionViewModel != null\">\r\n  <mat-card-content>\r\n    <div class=\"displayflex\">\r\n      <div class=\"filter-option-name flexauto\">\r\n        <mat-form-field appearance=\"fill\" class=\"full-width\">\r\n          <mat-label>Name (#{{ FilterOptionViewModel.id }})</mat-label>\r\n          <input matInput [(ngModel)]=\"FilterOptionViewModel.name\">\r\n        </mat-form-field>\r\n      </div>\r\n      <button mat-raised-button (click)=\"SaveFilterOption(FilterOptionViewModel)\">Save</button>\r\n      <button mat-raised-button (click)=\"RemoveFilterOption(FilterOptionViewModel)\">Remove</button>\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)=\"RequireFilterOptionFilterOption()\">FilterOption</button>\r\n      </div>\r\n\r\n      <div *ngFor=\"let option of FilterOptionViewModel.required\" class=\"required-option\">\r\n        {{ option.filterName }}: {{ option.filterOptionName }}\r\n        <button mat-raised-button (click)=\"RemoveRequireFilterOptionFilterOption(option)\">Remove</button>\r\n      </div>\r\n    </div>\r\n  </mat-card-content>\r\n</mat-card>\r\n\r\n"]}