onshore-forms 0.0.25 → 0.0.27

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.
@@ -3,20 +3,19 @@ import { OnshoreFormTemplateLayout } from '../../enums/form.enums';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/forms";
5
5
  import * as i2 from "primeng/dynamicdialog";
6
- import * as i3 from "@ngx-translate/core";
7
- import * as i4 from "@angular/common";
8
- import * as i5 from "primeng/button";
9
- import * as i6 from "primeng/dialog";
10
- import * as i7 from "../image-placeholder/image-placeholder.component";
11
- import * as i8 from "../form-item-container/form-item-container.component";
12
- import * as i9 from "../image-chooser/image-chooser.component";
13
- import * as i10 from "../webcam/webcam.component";
6
+ import * as i3 from "@angular/common";
7
+ import * as i4 from "primeng/button";
8
+ import * as i5 from "primeng/dialog";
9
+ import * as i6 from "../image-placeholder/image-placeholder.component";
10
+ import * as i7 from "../form-item-container/form-item-container.component";
11
+ import * as i8 from "../image-chooser/image-chooser.component";
12
+ import * as i9 from "../webcam/webcam.component";
13
+ import * as i10 from "@ngx-translate/core";
14
14
  export class OnshoreFormImageItemComponent {
15
- constructor(cdr, ngControl, dialogService, translate) {
15
+ constructor(cdr, ngControl, dialogService) {
16
16
  this.cdr = cdr;
17
17
  this.ngControl = ngControl;
18
18
  this.dialogService = dialogService;
19
- this.translate = translate;
20
19
  this.imageDeleted = new EventEmitter();
21
20
  this.imageCleared = new EventEmitter();
22
21
  this.imageReady = new EventEmitter();
@@ -59,10 +58,10 @@ export class OnshoreFormImageItemComponent {
59
58
  if (image) {
60
59
  this.image = image;
61
60
  setTimeout(() => {
62
- this.cdr.markForCheck();
63
61
  this.ngControl?.control?.setValue(this.image);
64
62
  this.ngControl?.control?.markAsDirty();
65
63
  this.imageReady.emit(this.image);
64
+ this.cdr.markForCheck();
66
65
  }, 500);
67
66
  }
68
67
  }
@@ -71,10 +70,10 @@ export class OnshoreFormImageItemComponent {
71
70
  if (image) {
72
71
  this.image = image;
73
72
  setTimeout(() => {
74
- this.cdr.markForCheck();
75
73
  this.ngControl?.control?.setValue(this.image);
76
74
  this.ngControl?.control?.markAsDirty();
77
75
  this.imageReady.emit(this.image);
76
+ this.cdr.markForCheck();
78
77
  }, 500);
79
78
  }
80
79
  }
@@ -86,8 +85,8 @@ export class OnshoreFormImageItemComponent {
86
85
  this.imageCleared.emit();
87
86
  }
88
87
  this.ngControl?.control?.setValue(null);
89
- this.ngControl?.control?.markAsDirty();
90
88
  this.image = '';
89
+ this.cdr.markForCheck();
91
90
  }
92
91
  writeValue(obj) {
93
92
  if (obj && !obj.includes('base64')) {
@@ -125,64 +124,22 @@ export class OnshoreFormImageItemComponent {
125
124
  }
126
125
  ngOnChanges(changes) {
127
126
  const imageSettings = changes['imageSettings']?.currentValue;
128
- if (imageSettings) {
129
- if (!imageSettings.imageWidth || !imageSettings.imageHeight) {
130
- this.imageSettings.imageWidth = this.defaultImageSettings.imageWidth;
131
- this.imageSettings.imageHeight = this.defaultImageSettings.imageHeight;
132
- }
133
- if (!imageSettings.placeholderIcon && !imageSettings.placeholderImage)
134
- this.imageSettings.placeholderIcon = this.defaultImageSettings.placeholderIcon;
135
- if (!imageSettings.aspectRatio)
136
- this.imageSettings.aspectRatio = this.defaultImageSettings.aspectRatio;
137
- if (!imageSettings.containWithinAspectRatio)
138
- this.imageSettings.containWithinAspectRatio = this.defaultImageSettings.containWithinAspectRatio;
139
- if (imageSettings.imageSelectionEnabled == null)
140
- this.imageSettings.imageSelectionEnabled = this.defaultImageSettings.imageSelectionEnabled;
141
- if (imageSettings.mediaSelectionEnabled == null)
142
- this.imageSettings.mediaSelectionEnabled = this.defaultImageSettings.mediaSelectionEnabled;
143
- if (imageSettings.webcamSelectionEnabled == null)
144
- this.imageSettings.webcamSelectionEnabled = this.defaultImageSettings.webcamSelectionEnabled;
145
- if (imageSettings.deleteEnabled == null)
146
- this.imageSettings.deleteEnabled = this.defaultImageSettings.deleteEnabled;
147
- if (imageSettings.containerWidth == null)
148
- this.imageSettings.containerWidth = this.defaultImageSettings.containerWidth;
149
- if (imageSettings.containerHeight == null)
150
- this.imageSettings.containerHeight = this.defaultImageSettings.containerHeight;
151
- if (imageSettings.imageQuality == null)
152
- this.imageSettings.imageQuality = this.defaultImageSettings.imageQuality;
153
- if (imageSettings.format == null)
154
- this.imageSettings.format = this.defaultImageSettings.format;
155
- if (imageSettings.alignImage == null)
156
- this.imageSettings.alignImage = this.defaultImageSettings.alignImage;
157
- if (imageSettings.cropperPreviewWidth == null)
158
- this.imageSettings.cropperPreviewWidth = this.defaultImageSettings.cropperPreviewWidth;
159
- if (imageSettings.cropperPreviewHeight == null)
160
- this.imageSettings.cropperPreviewHeight = this.defaultImageSettings.cropperPreviewHeight;
161
- if (imageSettings.circleCropper == null)
162
- this.imageSettings.circleCropper = this.defaultImageSettings.circleCropper;
163
- if (imageSettings.maxFileSize == null)
164
- this.imageSettings.maxFileSize = this.defaultImageSettings.maxFileSize;
165
- if (imageSettings.backgroundColor == null)
166
- this.imageSettings.backgroundColor = this.defaultImageSettings.backgroundColor;
167
- if (imageSettings.webcamWidth == null)
168
- this.imageSettings.webcamWidth = this.defaultImageSettings.webcamWidth;
169
- if (imageSettings.webcamHeight == null)
170
- this.imageSettings.webcamHeight = this.defaultImageSettings.webcamHeight;
171
- }
127
+ this.imageSettings = { ...this.defaultImageSettings, ...imageSettings };
128
+ console.log("imageSettings", changes['imageSettings'], this.imageSettings);
172
129
  this.removeImage();
173
130
  this.cdr.markForCheck();
174
131
  }
175
132
  }
176
- OnshoreFormImageItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: OnshoreFormImageItemComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.NgControl, optional: true, self: true }, { token: i2.DialogService }, { token: i3.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
177
- OnshoreFormImageItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: OnshoreFormImageItemComponent, selector: "onshore-form-image-item", inputs: { formTemplate: "formTemplate", imageSettings: "imageSettings" }, outputs: { imageDeleted: "imageDeleted", imageCleared: "imageCleared", imageReady: "imageReady", selectFromMedia: "selectFromMedia", isLoading: "isLoading" }, usesOnChanges: true, ngImport: i0, template: "<onshore-form-item-container [formTemplate]=\"formTemplate\" [ngControl]=\"ngControl\">\n <div class=\"w-full flex align-items-center flex-wrap\" [class.flex-column]=\"formTemplate.layout === OnshoreFormTemplateLayout.vertical\">\n\n <div class=\"position-relative flex justify-content-center align-items-center onshore-border-gray-4 border-solid border-1\" style=\"background-color: white\">\n <onshore-image-placeholder\n class=\"w-full\"\n [image]=\"image\"\n [imageStyle]=\"'position: absolut; width: ' + imageSettings.containerWidth + 'px; height: ' + imageSettings.containerHeight + 'px'\"\n [placeholderIcon]=\"imageSettings.placeholderIcon\"\n [placeholderImage]=\"imageSettings.placeholderImage\"\n [placeholderStyle]=\"'width: ' + imageSettings.containerWidth + 'px; height: ' + imageSettings.containerHeight + 'px'\">\n </onshore-image-placeholder>\n </div>\n\n <div class=\"flex flex-column m-4\">\n <button pButton\n type=\"button\"\n *ngIf=\"imageSettings.imageSelectionEnabled\"\n icon=\"fa fa-image\"\n [label]=\"'form.imageControl.uploadImageButton' | translate\"\n class=\"onshore-button-primary mb-2\"\n [disabled]=\"disabled\"\n (click)=\"imageChooserDialogVisible = true; cdr.detectChanges()\">\n </button>\n\n <button pButton\n type=\"button\"\n *ngIf=\"imageSettings.webcamSelectionEnabled\"\n icon=\"fa fa-camera\"\n [label]=\"'form.imageControl.webcamImageButton' | translate\"\n class=\"onshore-button-light mb-2\"\n [disabled]=\"disabled\"\n (click)=\"webcamDialogVisible = true\">\n </button>\n\n <button pButton\n type=\"button\"\n *ngIf=\"imageSettings.mediaSelectionEnabled\"\n icon=\"fa fa-photo-video\"\n [label]=\"'form.imageControl.mediaImageButton' | translate\"\n class=\"onshore-button-light mb-2\"\n [disabled]=\"disabled\"\n (click)=\"selectFromMedia.emit()\">\n </button>\n\n <button pButton\n type=\"button\"\n *ngIf=\"imageSettings.deleteEnabled\"\n icon=\"fa fa-eraser\"\n [label]=\"'form.imageControl.removeImageButton' | translate\"\n class=\"onshore-button-light\"\n (click)=\"removeImage()\"\n [disabled]=\"!image || disabled\">\n </button>\n\n </div>\n\n </div>\n</onshore-form-item-container>\n\n<p-dialog [header]=\"'form.imageControl.uploadImageTitle' | translate\" [(visible)]=\"imageChooserDialogVisible\" [modal]=\"true\" [style]=\"{'max-width': '50vw'}\" >\n <onshore-image-chooser\n (choosen)=\"getFileImage($event)\"\n (canceled)=\"imageChooserDialogVisible = false\"\n [imageSettings]=\"imageSettings\">\n </onshore-image-chooser>\n</p-dialog>\n\n<p-dialog [header]=\"'form.imageControl.webacmImageTitle' | translate\" [(visible)]=\"webcamDialogVisible\" [modal]=\"true\" [style]=\"{'max-width': '50vw'}\">\n <onshore-webcam\n *ngIf=\"webcamDialogVisible\"\n (shot)=\"getWebcamImage($event)\"\n (canceled)=\"webcamDialogVisible = false\"\n [imageSettings]=\"imageSettings\"></onshore-webcam>\n</p-dialog>\n", dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "component", type: i6.Dialog, selector: "p-dialog", inputs: ["header", "draggable", "resizable", "positionLeft", "positionTop", "contentStyle", "contentStyleClass", "modal", "closeOnEscape", "dismissableMask", "rtl", "closable", "responsive", "appendTo", "breakpoints", "styleClass", "maskStyleClass", "showHeader", "breakpoint", "blockScroll", "autoZIndex", "baseZIndex", "minX", "minY", "focusOnShow", "maximizable", "keepInViewport", "focusTrap", "transitionOptions", "closeIcon", "closeAriaLabel", "closeTabindex", "minimizeIcon", "maximizeIcon", "visible", "style", "position"], outputs: ["onShow", "onHide", "visibleChange", "onResizeInit", "onResizeEnd", "onDragEnd", "onMaximize"] }, { kind: "component", type: i7.OnshoreImagePlaceholderComponent, selector: "onshore-image-placeholder", inputs: ["placeholderIcon", "placeholderImage", "image", "imageStyle", "placeholderStyle", "showLoader"] }, { kind: "component", type: i8.OnshoreFormItemContainer, selector: "onshore-form-item-container", inputs: ["formTemplate", "ngControl"] }, { kind: "component", type: i9.OnshoreImageChooserComponent, selector: "onshore-image-chooser", inputs: ["imageSettings"], outputs: ["choosen", "canceled"] }, { kind: "component", type: i10.WebcamComponent, selector: "onshore-webcam", inputs: ["imageSettings"], outputs: ["shot", "canceled"] }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
133
+ OnshoreFormImageItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: OnshoreFormImageItemComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.NgControl, optional: true, self: true }, { token: i2.DialogService }], target: i0.ɵɵFactoryTarget.Component });
134
+ OnshoreFormImageItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: OnshoreFormImageItemComponent, selector: "onshore-form-image-item", inputs: { formTemplate: "formTemplate", imageSettings: "imageSettings" }, outputs: { imageDeleted: "imageDeleted", imageCleared: "imageCleared", imageReady: "imageReady", selectFromMedia: "selectFromMedia", isLoading: "isLoading" }, usesOnChanges: true, ngImport: i0, template: "<onshore-form-item-container [formTemplate]=\"formTemplate\" [ngControl]=\"ngControl\">\n <div class=\"w-full flex align-items-center flex-wrap\" [class.flex-column]=\"formTemplate.layout === OnshoreFormTemplateLayout.vertical\">\n\n <div class=\"onshore-border-gray-4 border-solid border-1 overflow-hidden\"\n [style]=\"'background-color: white; width: ' + imageSettings.containerWidth + 'px; height: ' + imageSettings.containerHeight + 'px'\">\n <onshore-image-placeholder\n class=\"w-full\"\n [image]=\"image\"\n [imageStyle]=\"'width: 100%; height: 100%'\"\n [placeholderIcon]=\"imageSettings.placeholderIcon\"\n [placeholderImage]=\"imageSettings.placeholderImage\"\n [placeholderStyle]=\"'width: 100%; height: 100%'\">\n </onshore-image-placeholder>\n </div>\n\n <div class=\"flex flex-column m-4\">\n <button pButton\n type=\"button\"\n *ngIf=\"imageSettings.imageSelectionEnabled\"\n icon=\"fa fa-image\"\n [label]=\"'form.imageControl.uploadImageButton' | translate\"\n class=\"onshore-button-primary mb-2\"\n [disabled]=\"disabled\"\n (click)=\"imageChooserDialogVisible = true; cdr.detectChanges()\">\n </button>\n\n <button pButton\n type=\"button\"\n *ngIf=\"imageSettings.webcamSelectionEnabled\"\n icon=\"fa fa-camera\"\n [label]=\"'form.imageControl.webcamImageButton' | translate\"\n class=\"onshore-button-light mb-2\"\n [disabled]=\"disabled\"\n (click)=\"webcamDialogVisible = true\">\n </button>\n\n <button pButton\n type=\"button\"\n *ngIf=\"imageSettings.mediaSelectionEnabled\"\n icon=\"fa fa-photo-video\"\n [label]=\"'form.imageControl.mediaImageButton' | translate\"\n class=\"onshore-button-light mb-2\"\n [disabled]=\"disabled\"\n (click)=\"selectFromMedia.emit()\">\n </button>\n\n <button pButton\n type=\"button\"\n *ngIf=\"imageSettings.deleteEnabled\"\n icon=\"fa fa-eraser\"\n [label]=\"'form.imageControl.removeImageButton' | translate\"\n class=\"onshore-button-light\"\n (click)=\"removeImage()\"\n [disabled]=\"!image || disabled\">\n </button>\n\n </div>\n\n </div>\n</onshore-form-item-container>\n\n<p-dialog [header]=\"'form.imageControl.uploadImageTitle' | translate\" [(visible)]=\"imageChooserDialogVisible\" [modal]=\"true\" [style]=\"{'max-width': '50vw'}\" >\n <onshore-image-chooser\n (choosen)=\"getFileImage($event)\"\n (canceled)=\"imageChooserDialogVisible = false\"\n [imageSettings]=\"imageSettings\">\n </onshore-image-chooser>\n</p-dialog>\n\n<p-dialog [header]=\"'form.imageControl.webacmImageTitle' | translate\" [(visible)]=\"webcamDialogVisible\" [modal]=\"true\" [style]=\"{'max-width': '50vw'}\">\n <onshore-webcam\n *ngIf=\"webcamDialogVisible\"\n (shot)=\"getWebcamImage($event)\"\n (canceled)=\"webcamDialogVisible = false\"\n [imageSettings]=\"imageSettings\"></onshore-webcam>\n</p-dialog>\n", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "component", type: i5.Dialog, selector: "p-dialog", inputs: ["header", "draggable", "resizable", "positionLeft", "positionTop", "contentStyle", "contentStyleClass", "modal", "closeOnEscape", "dismissableMask", "rtl", "closable", "responsive", "appendTo", "breakpoints", "styleClass", "maskStyleClass", "showHeader", "breakpoint", "blockScroll", "autoZIndex", "baseZIndex", "minX", "minY", "focusOnShow", "maximizable", "keepInViewport", "focusTrap", "transitionOptions", "closeIcon", "closeAriaLabel", "closeTabindex", "minimizeIcon", "maximizeIcon", "visible", "style", "position"], outputs: ["onShow", "onHide", "visibleChange", "onResizeInit", "onResizeEnd", "onDragEnd", "onMaximize"] }, { kind: "component", type: i6.OnshoreImagePlaceholderComponent, selector: "onshore-image-placeholder", inputs: ["placeholderIcon", "placeholderImage", "image", "imageStyle", "placeholderStyle", "showLoader"] }, { kind: "component", type: i7.OnshoreFormItemContainer, selector: "onshore-form-item-container", inputs: ["formTemplate", "ngControl"] }, { kind: "component", type: i8.OnshoreImageChooserComponent, selector: "onshore-image-chooser", inputs: ["imageSettings"], outputs: ["choosen", "canceled"] }, { kind: "component", type: i9.WebcamComponent, selector: "onshore-webcam", inputs: ["imageSettings"], outputs: ["shot", "canceled"] }, { kind: "pipe", type: i10.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
178
135
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: OnshoreFormImageItemComponent, decorators: [{
179
136
  type: Component,
180
- args: [{ selector: 'onshore-form-image-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<onshore-form-item-container [formTemplate]=\"formTemplate\" [ngControl]=\"ngControl\">\n <div class=\"w-full flex align-items-center flex-wrap\" [class.flex-column]=\"formTemplate.layout === OnshoreFormTemplateLayout.vertical\">\n\n <div class=\"position-relative flex justify-content-center align-items-center onshore-border-gray-4 border-solid border-1\" style=\"background-color: white\">\n <onshore-image-placeholder\n class=\"w-full\"\n [image]=\"image\"\n [imageStyle]=\"'position: absolut; width: ' + imageSettings.containerWidth + 'px; height: ' + imageSettings.containerHeight + 'px'\"\n [placeholderIcon]=\"imageSettings.placeholderIcon\"\n [placeholderImage]=\"imageSettings.placeholderImage\"\n [placeholderStyle]=\"'width: ' + imageSettings.containerWidth + 'px; height: ' + imageSettings.containerHeight + 'px'\">\n </onshore-image-placeholder>\n </div>\n\n <div class=\"flex flex-column m-4\">\n <button pButton\n type=\"button\"\n *ngIf=\"imageSettings.imageSelectionEnabled\"\n icon=\"fa fa-image\"\n [label]=\"'form.imageControl.uploadImageButton' | translate\"\n class=\"onshore-button-primary mb-2\"\n [disabled]=\"disabled\"\n (click)=\"imageChooserDialogVisible = true; cdr.detectChanges()\">\n </button>\n\n <button pButton\n type=\"button\"\n *ngIf=\"imageSettings.webcamSelectionEnabled\"\n icon=\"fa fa-camera\"\n [label]=\"'form.imageControl.webcamImageButton' | translate\"\n class=\"onshore-button-light mb-2\"\n [disabled]=\"disabled\"\n (click)=\"webcamDialogVisible = true\">\n </button>\n\n <button pButton\n type=\"button\"\n *ngIf=\"imageSettings.mediaSelectionEnabled\"\n icon=\"fa fa-photo-video\"\n [label]=\"'form.imageControl.mediaImageButton' | translate\"\n class=\"onshore-button-light mb-2\"\n [disabled]=\"disabled\"\n (click)=\"selectFromMedia.emit()\">\n </button>\n\n <button pButton\n type=\"button\"\n *ngIf=\"imageSettings.deleteEnabled\"\n icon=\"fa fa-eraser\"\n [label]=\"'form.imageControl.removeImageButton' | translate\"\n class=\"onshore-button-light\"\n (click)=\"removeImage()\"\n [disabled]=\"!image || disabled\">\n </button>\n\n </div>\n\n </div>\n</onshore-form-item-container>\n\n<p-dialog [header]=\"'form.imageControl.uploadImageTitle' | translate\" [(visible)]=\"imageChooserDialogVisible\" [modal]=\"true\" [style]=\"{'max-width': '50vw'}\" >\n <onshore-image-chooser\n (choosen)=\"getFileImage($event)\"\n (canceled)=\"imageChooserDialogVisible = false\"\n [imageSettings]=\"imageSettings\">\n </onshore-image-chooser>\n</p-dialog>\n\n<p-dialog [header]=\"'form.imageControl.webacmImageTitle' | translate\" [(visible)]=\"webcamDialogVisible\" [modal]=\"true\" [style]=\"{'max-width': '50vw'}\">\n <onshore-webcam\n *ngIf=\"webcamDialogVisible\"\n (shot)=\"getWebcamImage($event)\"\n (canceled)=\"webcamDialogVisible = false\"\n [imageSettings]=\"imageSettings\"></onshore-webcam>\n</p-dialog>\n" }]
137
+ args: [{ selector: 'onshore-form-image-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<onshore-form-item-container [formTemplate]=\"formTemplate\" [ngControl]=\"ngControl\">\n <div class=\"w-full flex align-items-center flex-wrap\" [class.flex-column]=\"formTemplate.layout === OnshoreFormTemplateLayout.vertical\">\n\n <div class=\"onshore-border-gray-4 border-solid border-1 overflow-hidden\"\n [style]=\"'background-color: white; width: ' + imageSettings.containerWidth + 'px; height: ' + imageSettings.containerHeight + 'px'\">\n <onshore-image-placeholder\n class=\"w-full\"\n [image]=\"image\"\n [imageStyle]=\"'width: 100%; height: 100%'\"\n [placeholderIcon]=\"imageSettings.placeholderIcon\"\n [placeholderImage]=\"imageSettings.placeholderImage\"\n [placeholderStyle]=\"'width: 100%; height: 100%'\">\n </onshore-image-placeholder>\n </div>\n\n <div class=\"flex flex-column m-4\">\n <button pButton\n type=\"button\"\n *ngIf=\"imageSettings.imageSelectionEnabled\"\n icon=\"fa fa-image\"\n [label]=\"'form.imageControl.uploadImageButton' | translate\"\n class=\"onshore-button-primary mb-2\"\n [disabled]=\"disabled\"\n (click)=\"imageChooserDialogVisible = true; cdr.detectChanges()\">\n </button>\n\n <button pButton\n type=\"button\"\n *ngIf=\"imageSettings.webcamSelectionEnabled\"\n icon=\"fa fa-camera\"\n [label]=\"'form.imageControl.webcamImageButton' | translate\"\n class=\"onshore-button-light mb-2\"\n [disabled]=\"disabled\"\n (click)=\"webcamDialogVisible = true\">\n </button>\n\n <button pButton\n type=\"button\"\n *ngIf=\"imageSettings.mediaSelectionEnabled\"\n icon=\"fa fa-photo-video\"\n [label]=\"'form.imageControl.mediaImageButton' | translate\"\n class=\"onshore-button-light mb-2\"\n [disabled]=\"disabled\"\n (click)=\"selectFromMedia.emit()\">\n </button>\n\n <button pButton\n type=\"button\"\n *ngIf=\"imageSettings.deleteEnabled\"\n icon=\"fa fa-eraser\"\n [label]=\"'form.imageControl.removeImageButton' | translate\"\n class=\"onshore-button-light\"\n (click)=\"removeImage()\"\n [disabled]=\"!image || disabled\">\n </button>\n\n </div>\n\n </div>\n</onshore-form-item-container>\n\n<p-dialog [header]=\"'form.imageControl.uploadImageTitle' | translate\" [(visible)]=\"imageChooserDialogVisible\" [modal]=\"true\" [style]=\"{'max-width': '50vw'}\" >\n <onshore-image-chooser\n (choosen)=\"getFileImage($event)\"\n (canceled)=\"imageChooserDialogVisible = false\"\n [imageSettings]=\"imageSettings\">\n </onshore-image-chooser>\n</p-dialog>\n\n<p-dialog [header]=\"'form.imageControl.webacmImageTitle' | translate\" [(visible)]=\"webcamDialogVisible\" [modal]=\"true\" [style]=\"{'max-width': '50vw'}\">\n <onshore-webcam\n *ngIf=\"webcamDialogVisible\"\n (shot)=\"getWebcamImage($event)\"\n (canceled)=\"webcamDialogVisible = false\"\n [imageSettings]=\"imageSettings\"></onshore-webcam>\n</p-dialog>\n" }]
181
138
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.NgControl, decorators: [{
182
139
  type: Self
183
140
  }, {
184
141
  type: Optional
185
- }] }, { type: i2.DialogService }, { type: i3.TranslateService }]; }, propDecorators: { formTemplate: [{
142
+ }] }, { type: i2.DialogService }]; }, propDecorators: { formTemplate: [{
186
143
  type: Input
187
144
  }], imageSettings: [{
188
145
  type: Input
@@ -197,4 +154,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
197
154
  }], isLoading: [{
198
155
  type: Output
199
156
  }] } });
200
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-image-item.component.js","sourceRoot":"","sources":["../../../../../../projects/onshore-forms/src/lib/components/form-image-item/form-image-item.component.ts","../../../../../../projects/onshore-forms/src/lib/components/form-image-item/form-image-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component, EventEmitter, Input, OnChanges, OnDestroy, OnInit,\n  Optional, Output,\n  Self, SimpleChanges\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { DialogService } from 'primeng/dynamicdialog';\nimport { TranslateService } from '@ngx-translate/core';\nimport { OnshoreFormImageSettings, OnshoreFormTemplateItem } from '../../models/form.models';\nimport { OnshoreFormTemplateLayout } from '../../enums/form.enums';\n\n@Component({\n  selector: 'onshore-form-image-item',\n  templateUrl: './form-image-item.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class OnshoreFormImageItemComponent implements ControlValueAccessor, OnInit, OnDestroy, OnChanges {\n  @Input() formTemplate!: OnshoreFormTemplateItem;\n  @Input() imageSettings: OnshoreFormImageSettings;\n\n  @Output() imageDeleted: EventEmitter<string> = new EventEmitter();\n  @Output() imageCleared: EventEmitter<any> = new EventEmitter();\n  @Output() imageReady: EventEmitter<string> = new EventEmitter();\n  @Output() selectFromMedia: EventEmitter<any> = new EventEmitter();\n  @Output() isLoading: EventEmitter<boolean> = new EventEmitter();\n\n  OnshoreFormTemplateLayout = OnshoreFormTemplateLayout;\n\n  defaultImageSettings: OnshoreFormImageSettings = {\n    imageWidth: 400,\n    imageHeight: 400,\n    containWithinAspectRatio: false,\n    aspectRatio: 1 / 1,\n    imageSelectionEnabled: true,\n    webcamSelectionEnabled: true,\n    mediaSelectionEnabled: true,\n    deleteEnabled: true,\n    placeholderImage: '',\n    placeholderIcon: 'fa fa-image fa-10x',\n    containerWidth: 250,\n    containerHeight: 250,\n    imageQuality: 100,\n    format: 'png',\n    alignImage: 'center',\n    cropperPreviewWidth: 400,\n    cropperPreviewHeight: 400,\n    webcamWidth: 400,\n    webcamHeight: 400,\n    circleCropper: false,\n    maxFileSize: 6400000,\n    backgroundColor: 'white'\n  };\n\n  image: string | null = '';\n  disabled = false;\n  webcamDialogVisible: boolean = false;\n  imageChooserDialogVisible: boolean = false;\n\n  subscriptions: Array<Subscription> = [];\n\n  getFileImage(image: any) {\n    this.imageChooserDialogVisible = false;\n    if(image) {\n      this.image = image;\n      setTimeout(() => {\n        this.cdr.markForCheck();\n        this.ngControl?.control?.setValue(this.image);\n        this.ngControl?.control?.markAsDirty();\n        this.imageReady.emit(this.image);\n      }, 500);\n    }\n  }\n\n  getWebcamImage(image: any) {\n    this.webcamDialogVisible = false;\n    if(image) {\n      this.image = image;\n      setTimeout(() => {\n        this.cdr.markForCheck();\n        this.ngControl?.control?.setValue(this.image);\n        this.ngControl?.control?.markAsDirty();\n        this.imageReady.emit(this.image);\n      }, 500);\n    }\n  }\n\n  removeImage() {\n    if(this.image && !this.image.includes('base64')) {\n      this.imageDeleted.emit(this.image);\n    } else {\n      this.imageCleared.emit();\n    }\n\n    this.ngControl?.control?.setValue(null);\n    this.ngControl?.control?.markAsDirty();\n    this.image = '';\n  }\n\n  public writeValue(obj: any): void {\n    if(obj && !obj.includes('base64')) {\n      this.image = obj;\n    }\n    if(obj == null) {\n      this.image = '';\n    }\n\n    this.imageReady.emit(this.image);\n    this.cdr.markForCheck();\n  }\n\n  public registerOnChange(fn: any): void {\n    if(this.ngControl.value) {\n      this.image = this.ngControl.value;\n      this.cdr.markForCheck();\n    }\n  }\n\n  public registerOnTouched(fn: any): void {}\n\n  public setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this.cdr.markForCheck();\n  }\n\n  ngOnInit(): void {\n    if(this.ngControl?.control?.value == '' && this.formTemplate.default != undefined) {\n      this.ngControl?.control?.setValue(this.formTemplate.default);\n      this.cdr.markForCheck();\n    }\n  }\n\n  ngOnDestroy() {\n    this.subscriptions.forEach((subscription: Subscription) => {\n      subscription.unsubscribe();\n    });\n    this.ngControl?.control?.disable();\n    this.image = null;\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const imageSettings: OnshoreFormImageSettings = changes['imageSettings']?.currentValue;\n    if(imageSettings) {\n      if(!imageSettings.imageWidth || !imageSettings.imageHeight) {\n        this.imageSettings.imageWidth = this.defaultImageSettings.imageWidth;\n        this.imageSettings.imageHeight = this.defaultImageSettings.imageHeight;\n      }\n      if(!imageSettings.placeholderIcon && !imageSettings.placeholderImage) this.imageSettings.placeholderIcon = this.defaultImageSettings.placeholderIcon;\n      if(!imageSettings.aspectRatio) this.imageSettings.aspectRatio = this.defaultImageSettings.aspectRatio;\n      if(!imageSettings.containWithinAspectRatio) this.imageSettings.containWithinAspectRatio = this.defaultImageSettings.containWithinAspectRatio;\n      if(imageSettings.imageSelectionEnabled == null) this.imageSettings.imageSelectionEnabled = this.defaultImageSettings.imageSelectionEnabled;\n      if(imageSettings.mediaSelectionEnabled == null) this.imageSettings.mediaSelectionEnabled = this.defaultImageSettings.mediaSelectionEnabled;\n      if(imageSettings.webcamSelectionEnabled == null) this.imageSettings.webcamSelectionEnabled = this.defaultImageSettings.webcamSelectionEnabled;\n      if(imageSettings.deleteEnabled == null) this.imageSettings.deleteEnabled = this.defaultImageSettings.deleteEnabled;\n      if(imageSettings.containerWidth == null) this.imageSettings.containerWidth = this.defaultImageSettings.containerWidth;\n      if(imageSettings.containerHeight == null) this.imageSettings.containerHeight = this.defaultImageSettings.containerHeight;\n      if(imageSettings.imageQuality == null) this.imageSettings.imageQuality = this.defaultImageSettings.imageQuality;\n      if(imageSettings.format == null) this.imageSettings.format = this.defaultImageSettings.format;\n      if(imageSettings.alignImage == null) this.imageSettings.alignImage = this.defaultImageSettings.alignImage;\n      if(imageSettings.cropperPreviewWidth == null) this.imageSettings.cropperPreviewWidth = this.defaultImageSettings.cropperPreviewWidth;\n      if(imageSettings.cropperPreviewHeight == null) this.imageSettings.cropperPreviewHeight = this.defaultImageSettings.cropperPreviewHeight;\n      if(imageSettings.circleCropper == null) this.imageSettings.circleCropper = this.defaultImageSettings.circleCropper;\n      if(imageSettings.maxFileSize == null) this.imageSettings.maxFileSize = this.defaultImageSettings.maxFileSize;\n      if(imageSettings.backgroundColor == null) this.imageSettings.backgroundColor = this.defaultImageSettings.backgroundColor;\n      if(imageSettings.webcamWidth == null) this.imageSettings.webcamWidth = this.defaultImageSettings.webcamWidth;\n      if(imageSettings.webcamHeight == null) this.imageSettings.webcamHeight = this.defaultImageSettings.webcamHeight;\n    }\n    this.removeImage();\n    this.cdr.markForCheck();\n  }\n\n  constructor(public cdr: ChangeDetectorRef,\n              @Self() @Optional() public ngControl: NgControl,\n              public dialogService: DialogService,\n              private translate: TranslateService) {\n    this.ngControl.valueAccessor = this;\n  }\n}\n","<onshore-form-item-container [formTemplate]=\"formTemplate\" [ngControl]=\"ngControl\">\n  <div class=\"w-full flex align-items-center flex-wrap\" [class.flex-column]=\"formTemplate.layout === OnshoreFormTemplateLayout.vertical\">\n\n    <div class=\"position-relative flex justify-content-center align-items-center onshore-border-gray-4 border-solid border-1\" style=\"background-color: white\">\n      <onshore-image-placeholder\n        class=\"w-full\"\n        [image]=\"image\"\n        [imageStyle]=\"'position: absolut; width: ' + imageSettings.containerWidth + 'px; height: ' + imageSettings.containerHeight + 'px'\"\n        [placeholderIcon]=\"imageSettings.placeholderIcon\"\n        [placeholderImage]=\"imageSettings.placeholderImage\"\n        [placeholderStyle]=\"'width: ' + imageSettings.containerWidth + 'px; height: ' + imageSettings.containerHeight + 'px'\">\n      </onshore-image-placeholder>\n    </div>\n\n    <div class=\"flex flex-column m-4\">\n      <button pButton\n              type=\"button\"\n              *ngIf=\"imageSettings.imageSelectionEnabled\"\n              icon=\"fa fa-image\"\n              [label]=\"'form.imageControl.uploadImageButton' | translate\"\n              class=\"onshore-button-primary mb-2\"\n              [disabled]=\"disabled\"\n              (click)=\"imageChooserDialogVisible = true; cdr.detectChanges()\">\n      </button>\n\n      <button pButton\n              type=\"button\"\n              *ngIf=\"imageSettings.webcamSelectionEnabled\"\n              icon=\"fa fa-camera\"\n              [label]=\"'form.imageControl.webcamImageButton' | translate\"\n              class=\"onshore-button-light mb-2\"\n              [disabled]=\"disabled\"\n              (click)=\"webcamDialogVisible = true\">\n      </button>\n\n      <button pButton\n              type=\"button\"\n              *ngIf=\"imageSettings.mediaSelectionEnabled\"\n              icon=\"fa fa-photo-video\"\n              [label]=\"'form.imageControl.mediaImageButton' | translate\"\n              class=\"onshore-button-light mb-2\"\n              [disabled]=\"disabled\"\n              (click)=\"selectFromMedia.emit()\">\n      </button>\n\n      <button pButton\n              type=\"button\"\n              *ngIf=\"imageSettings.deleteEnabled\"\n              icon=\"fa fa-eraser\"\n              [label]=\"'form.imageControl.removeImageButton' | translate\"\n              class=\"onshore-button-light\"\n              (click)=\"removeImage()\"\n              [disabled]=\"!image || disabled\">\n      </button>\n\n    </div>\n\n  </div>\n</onshore-form-item-container>\n\n<p-dialog [header]=\"'form.imageControl.uploadImageTitle' | translate\" [(visible)]=\"imageChooserDialogVisible\" [modal]=\"true\" [style]=\"{'max-width': '50vw'}\" >\n  <onshore-image-chooser\n                     (choosen)=\"getFileImage($event)\"\n                     (canceled)=\"imageChooserDialogVisible = false\"\n                     [imageSettings]=\"imageSettings\">\n  </onshore-image-chooser>\n</p-dialog>\n\n<p-dialog [header]=\"'form.imageControl.webacmImageTitle' | translate\" [(visible)]=\"webcamDialogVisible\" [modal]=\"true\" [style]=\"{'max-width': '50vw'}\">\n  <onshore-webcam\n    *ngIf=\"webcamDialogVisible\"\n    (shot)=\"getWebcamImage($event)\"\n    (canceled)=\"webcamDialogVisible = false\"\n    [imageSettings]=\"imageSettings\"></onshore-webcam>\n</p-dialog>\n"]}
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-image-item.component.js","sourceRoot":"","sources":["../../../../../../projects/onshore-forms/src/lib/components/form-image-item/form-image-item.component.ts","../../../../../../projects/onshore-forms/src/lib/components/form-image-item/form-image-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component, EventEmitter, Input, OnChanges, OnDestroy, OnInit,\n  Optional, Output,\n  Self, SimpleChanges\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { DialogService } from 'primeng/dynamicdialog';\nimport { TranslateService } from '@ngx-translate/core';\nimport { OnshoreFormImageSettings, OnshoreFormTemplateItem } from '../../models/form.models';\nimport { OnshoreFormTemplateLayout } from '../../enums/form.enums';\n\n@Component({\n  selector: 'onshore-form-image-item',\n  templateUrl: './form-image-item.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class OnshoreFormImageItemComponent implements ControlValueAccessor, OnInit, OnDestroy, OnChanges {\n  @Input() formTemplate!: OnshoreFormTemplateItem;\n  @Input() imageSettings: OnshoreFormImageSettings;\n\n  @Output() imageDeleted: EventEmitter<string> = new EventEmitter();\n  @Output() imageCleared: EventEmitter<any> = new EventEmitter();\n  @Output() imageReady: EventEmitter<string> = new EventEmitter();\n  @Output() selectFromMedia: EventEmitter<any> = new EventEmitter();\n  @Output() isLoading: EventEmitter<boolean> = new EventEmitter();\n\n  OnshoreFormTemplateLayout = OnshoreFormTemplateLayout;\n\n  defaultImageSettings: OnshoreFormImageSettings = {\n    imageWidth: 400,\n    imageHeight: 400,\n    containWithinAspectRatio: false,\n    aspectRatio: 1 / 1,\n    imageSelectionEnabled: true,\n    webcamSelectionEnabled: true,\n    mediaSelectionEnabled: true,\n    deleteEnabled: true,\n    placeholderImage: '',\n    placeholderIcon: 'fa fa-image fa-10x',\n    containerWidth: 250,\n    containerHeight: 250,\n    imageQuality: 100,\n    format: 'png',\n    alignImage: 'center',\n    cropperPreviewWidth: 400,\n    cropperPreviewHeight: 400,\n    webcamWidth: 400,\n    webcamHeight: 400,\n    circleCropper: false,\n    maxFileSize: 6400000,\n    backgroundColor: 'white'\n  };\n\n  image: string | null = '';\n  disabled = false;\n  webcamDialogVisible: boolean = false;\n  imageChooserDialogVisible: boolean = false;\n\n  subscriptions: Array<Subscription> = [];\n\n  getFileImage(image: any) {\n    this.imageChooserDialogVisible = false;\n    if(image) {\n      this.image = image;\n      setTimeout(() => {\n        this.ngControl?.control?.setValue(this.image);\n        this.ngControl?.control?.markAsDirty();\n        this.imageReady.emit(this.image);\n        this.cdr.markForCheck();\n      }, 500);\n    }\n  }\n\n  getWebcamImage(image: any) {\n    this.webcamDialogVisible = false;\n    if(image) {\n      this.image = image;\n      setTimeout(() => {\n        this.ngControl?.control?.setValue(this.image);\n        this.ngControl?.control?.markAsDirty();\n        this.imageReady.emit(this.image);\n        this.cdr.markForCheck();\n      }, 500);\n    }\n  }\n\n  removeImage() {\n    if(this.image && !this.image.includes('base64')) {\n      this.imageDeleted.emit(this.image);\n    } else {\n      this.imageCleared.emit();\n    }\n\n    this.ngControl?.control?.setValue(null);\n    this.image = '';\n    this.cdr.markForCheck();\n  }\n\n  public writeValue(obj: any): void {\n    if(obj && !obj.includes('base64')) {\n      this.image = obj;\n    }\n    if(obj == null) {\n      this.image = '';\n    }\n\n    this.imageReady.emit(this.image);\n    this.cdr.markForCheck();\n  }\n\n  public registerOnChange(fn: any): void {\n    if(this.ngControl.value) {\n      this.image = this.ngControl.value;\n      this.cdr.markForCheck();\n    }\n  }\n\n  public registerOnTouched(fn: any): void {}\n\n  public setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this.cdr.markForCheck();\n  }\n\n  ngOnInit(): void {\n    if(this.ngControl?.control?.value == '' && this.formTemplate.default != undefined) {\n      this.ngControl?.control?.setValue(this.formTemplate.default);\n      this.cdr.markForCheck();\n    }\n  }\n\n  ngOnDestroy() {\n    this.subscriptions.forEach((subscription: Subscription) => {\n      subscription.unsubscribe();\n    });\n    this.ngControl?.control?.disable();\n    this.image = null;\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const imageSettings: OnshoreFormImageSettings = changes['imageSettings']?.currentValue;\n\n    this.imageSettings = { ...this.defaultImageSettings, ...imageSettings };\n    console.log(\"imageSettings\", changes['imageSettings'], this.imageSettings);\n\n    this.removeImage();\n    this.cdr.markForCheck();\n  }\n\n  constructor(public cdr: ChangeDetectorRef,\n              @Self() @Optional() public ngControl: NgControl,\n              public dialogService: DialogService) {\n    this.ngControl.valueAccessor = this;\n  }\n}\n","<onshore-form-item-container [formTemplate]=\"formTemplate\" [ngControl]=\"ngControl\">\n  <div class=\"w-full flex align-items-center flex-wrap\" [class.flex-column]=\"formTemplate.layout === OnshoreFormTemplateLayout.vertical\">\n\n    <div class=\"onshore-border-gray-4 border-solid border-1 overflow-hidden\"\n         [style]=\"'background-color: white; width: ' + imageSettings.containerWidth + 'px; height: ' + imageSettings.containerHeight + 'px'\">\n      <onshore-image-placeholder\n        class=\"w-full\"\n        [image]=\"image\"\n        [imageStyle]=\"'width: 100%; height: 100%'\"\n        [placeholderIcon]=\"imageSettings.placeholderIcon\"\n        [placeholderImage]=\"imageSettings.placeholderImage\"\n        [placeholderStyle]=\"'width: 100%; height: 100%'\">\n      </onshore-image-placeholder>\n    </div>\n\n    <div class=\"flex flex-column m-4\">\n      <button pButton\n              type=\"button\"\n              *ngIf=\"imageSettings.imageSelectionEnabled\"\n              icon=\"fa fa-image\"\n              [label]=\"'form.imageControl.uploadImageButton' | translate\"\n              class=\"onshore-button-primary mb-2\"\n              [disabled]=\"disabled\"\n              (click)=\"imageChooserDialogVisible = true; cdr.detectChanges()\">\n      </button>\n\n      <button pButton\n              type=\"button\"\n              *ngIf=\"imageSettings.webcamSelectionEnabled\"\n              icon=\"fa fa-camera\"\n              [label]=\"'form.imageControl.webcamImageButton' | translate\"\n              class=\"onshore-button-light mb-2\"\n              [disabled]=\"disabled\"\n              (click)=\"webcamDialogVisible = true\">\n      </button>\n\n      <button pButton\n              type=\"button\"\n              *ngIf=\"imageSettings.mediaSelectionEnabled\"\n              icon=\"fa fa-photo-video\"\n              [label]=\"'form.imageControl.mediaImageButton' | translate\"\n              class=\"onshore-button-light mb-2\"\n              [disabled]=\"disabled\"\n              (click)=\"selectFromMedia.emit()\">\n      </button>\n\n      <button pButton\n              type=\"button\"\n              *ngIf=\"imageSettings.deleteEnabled\"\n              icon=\"fa fa-eraser\"\n              [label]=\"'form.imageControl.removeImageButton' | translate\"\n              class=\"onshore-button-light\"\n              (click)=\"removeImage()\"\n              [disabled]=\"!image || disabled\">\n      </button>\n\n    </div>\n\n  </div>\n</onshore-form-item-container>\n\n<p-dialog [header]=\"'form.imageControl.uploadImageTitle' | translate\" [(visible)]=\"imageChooserDialogVisible\" [modal]=\"true\" [style]=\"{'max-width': '50vw'}\" >\n  <onshore-image-chooser\n                     (choosen)=\"getFileImage($event)\"\n                     (canceled)=\"imageChooserDialogVisible = false\"\n                     [imageSettings]=\"imageSettings\">\n  </onshore-image-chooser>\n</p-dialog>\n\n<p-dialog [header]=\"'form.imageControl.webacmImageTitle' | translate\" [(visible)]=\"webcamDialogVisible\" [modal]=\"true\" [style]=\"{'max-width': '50vw'}\">\n  <onshore-webcam\n    *ngIf=\"webcamDialogVisible\"\n    (shot)=\"getWebcamImage($event)\"\n    (canceled)=\"webcamDialogVisible = false\"\n    [imageSettings]=\"imageSettings\"></onshore-webcam>\n</p-dialog>\n"]}
@@ -43,10 +43,10 @@ export class OnshoreFormItemContainer {
43
43
  }
44
44
  }
45
45
  ngOnInit() {
46
- this.ngControl?.control?.valueChanges.subscribe(() => {
46
+ this.ngControl?.control?.valueChanges.subscribe(value => {
47
47
  this.cdr.markForCheck();
48
48
  });
49
- this.ngControl?.control?.statusChanges.subscribe(() => {
49
+ this.ngControl?.control?.statusChanges.subscribe(status => {
50
50
  this.cdr.markForCheck();
51
51
  });
52
52
  this.enabled(this.formTemplate.enabled);
@@ -80,10 +80,10 @@ export class OnshoreFormItemContainer {
80
80
  }
81
81
  }
82
82
  OnshoreFormItemContainer.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: OnshoreFormItemContainer, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
83
- OnshoreFormItemContainer.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: OnshoreFormItemContainer, selector: "onshore-form-item-container", inputs: { formTemplate: "formTemplate", ngControl: "ngControl" }, host: { listeners: { "window:resize": "onWindowResize($event)" } }, viewQueries: [{ propertyName: "formContainer", first: true, predicate: ["formContainer"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"mb-4\" #formContainer>\n <div class=\"flex w-full\"\n [class.flex-column]=\"layout == OnshoreFormTemplateLayout.vertical\"\n [class.flex-row]=\"layout == OnshoreFormTemplateLayout.horizontal\"\n [class.justify-content-between]=\"layout == OnshoreFormTemplateLayout.horizontal\">\n\n <div #formLabel\n class=\"flex justify-content-between\"\n [style]=\"formTemplate.labelStyle ?? 'min-width: 200px'\">\n\n <b [class.mr-2]=\"layout == OnshoreFormTemplateLayout.horizontal\"\n [class.mb-2]=\"layout == OnshoreFormTemplateLayout.vertical\">\n {{formTemplate.label}}\n <small *ngIf=\"formTemplate.required\" class=\"onshore-color-danger\">*</small>\n </b>\n\n <div *ngIf=\"formTemplate.tooltip && layout == OnshoreFormTemplateLayout.vertical\" [pTooltip]=\"formTemplate.tooltip\" [escape]=\"false\" appendTo=\"body\"><i class=\"fa fa-circle-question onshore-color-gray-5\"></i></div>\n\n </div>\n\n <div class=\"flex w-full\">\n <p-toggleButton\n *ngIf=\"formTemplate.locked\"\n (onChange)=\"lockChanged($event.checked)\"\n onIcon=\"fa fa-lock-open\"\n offIcon=\"fa fa-lock\"\n class=\"mr-2\"\n [style]=\"{height: '36px'}\"\n [disabled]=\"!formTemplate.enabled\">\n </p-toggleButton>\n\n <ng-content></ng-content>\n </div>\n\n <div *ngIf=\"formTemplate.tooltip && layout == OnshoreFormTemplateLayout.horizontal\" class=\"ml-2 align-self-center\" [pTooltip]=\"formTemplate.tooltip\" [escape]=\"false\"><i class=\"fa fa-circle-question onshore-color-gray-5\"></i></div>\n </div>\n\n <div *ngIf=\"ngControl.control.dirty\" [style]=\"{'margin-left': layout == OnshoreFormTemplateLayout.horizontal ? formLabel.clientWidth + 'px' : '0px'}\">\n <onshore-form-validation-output\n [validationItems]=\"formTemplate.validationItems\"\n [validationErrors]=\"ngControl.control.errors\">\n </onshore-form-validation-output>\n </div>\n\n <div [style]=\"{'margin-left': layout == OnshoreFormTemplateLayout.horizontal ? formLabel.clientWidth + 'px' : '0px'}\">\n <small *ngIf=\"formTemplate.description\" class=\"mt-2 onshore-color-gray-5\"><i class=\"fa fa-info-circle\"></i> {{formTemplate.description}}</small>\n </div>\n\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "fitContent", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "component", type: i3.ToggleButton, selector: "p-toggleButton", inputs: ["onLabel", "offLabel", "onIcon", "offIcon", "ariaLabelledBy", "disabled", "style", "styleClass", "inputId", "tabindex", "iconPos"], outputs: ["onChange"] }, { kind: "component", type: i4.OnshoreFormValidationOutputComponent, selector: "onshore-form-validation-output", inputs: ["validationErrors", "validationItems"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
83
+ OnshoreFormItemContainer.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: OnshoreFormItemContainer, selector: "onshore-form-item-container", inputs: { formTemplate: "formTemplate", ngControl: "ngControl" }, host: { listeners: { "window:resize": "onWindowResize($event)" } }, viewQueries: [{ propertyName: "formContainer", first: true, predicate: ["formContainer"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"mb-4\" #formContainer>\n <div class=\"flex w-full\"\n [class.flex-column]=\"layout == OnshoreFormTemplateLayout.vertical\"\n [class.flex-row]=\"layout == OnshoreFormTemplateLayout.horizontal\"\n [class.justify-content-between]=\"layout == OnshoreFormTemplateLayout.horizontal\">\n\n <div #formLabel\n class=\"flex justify-content-between\"\n [style]=\"formTemplate.labelStyle ?? 'min-width: 200px'\">\n\n <b [class.mr-2]=\"layout == OnshoreFormTemplateLayout.horizontal\"\n [class.mb-2]=\"layout == OnshoreFormTemplateLayout.vertical\">\n {{formTemplate.label}}\n <small *ngIf=\"formTemplate.required\" class=\"onshore-color-danger\">*</small>\n </b>\n\n <div *ngIf=\"formTemplate.tooltip && layout == OnshoreFormTemplateLayout.vertical\" [pTooltip]=\"formTemplate.tooltip\" [escape]=\"false\" appendTo=\"body\"><i class=\"fa fa-circle-question onshore-color-gray-5\"></i></div>\n\n </div>\n\n <div class=\"flex w-full\">\n <p-toggleButton\n *ngIf=\"formTemplate.locked\"\n (onChange)=\"lockChanged($event.checked)\"\n onIcon=\"fa fa-lock-open\"\n offIcon=\"fa fa-lock\"\n class=\"mr-2\"\n [style]=\"{height: '36px'}\"\n [disabled]=\"!formTemplate.enabled\">\n </p-toggleButton>\n\n <ng-content></ng-content>\n </div>\n\n <div *ngIf=\"formTemplate.tooltip && layout == OnshoreFormTemplateLayout.horizontal\" class=\"ml-2 align-self-center\" [pTooltip]=\"formTemplate.tooltip\" [escape]=\"false\"><i class=\"fa fa-circle-question onshore-color-gray-5\"></i></div>\n </div>\n\n <div *ngIf=\"ngControl.control.touched || ngControl.control.dirty\" [style]=\"{'margin-left': layout == OnshoreFormTemplateLayout.horizontal ? formLabel.clientWidth + 'px' : '0px'}\">\n <onshore-form-validation-output\n [validationItems]=\"formTemplate.validationItems\"\n [validationErrors]=\"ngControl.control.errors\">\n </onshore-form-validation-output>\n </div>\n\n <div [style]=\"{'margin-left': layout == OnshoreFormTemplateLayout.horizontal ? formLabel.clientWidth + 'px' : '0px'}\">\n <small *ngIf=\"formTemplate.description\" class=\"mt-2 onshore-color-gray-5\"><i class=\"fa fa-info-circle\"></i> {{formTemplate.description}}</small>\n </div>\n\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "fitContent", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "component", type: i3.ToggleButton, selector: "p-toggleButton", inputs: ["onLabel", "offLabel", "onIcon", "offIcon", "ariaLabelledBy", "disabled", "style", "styleClass", "inputId", "tabindex", "iconPos"], outputs: ["onChange"] }, { kind: "component", type: i4.OnshoreFormValidationOutputComponent, selector: "onshore-form-validation-output", inputs: ["validationErrors", "validationItems"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
84
84
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: OnshoreFormItemContainer, decorators: [{
85
85
  type: Component,
86
- args: [{ selector: 'onshore-form-item-container', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"mb-4\" #formContainer>\n <div class=\"flex w-full\"\n [class.flex-column]=\"layout == OnshoreFormTemplateLayout.vertical\"\n [class.flex-row]=\"layout == OnshoreFormTemplateLayout.horizontal\"\n [class.justify-content-between]=\"layout == OnshoreFormTemplateLayout.horizontal\">\n\n <div #formLabel\n class=\"flex justify-content-between\"\n [style]=\"formTemplate.labelStyle ?? 'min-width: 200px'\">\n\n <b [class.mr-2]=\"layout == OnshoreFormTemplateLayout.horizontal\"\n [class.mb-2]=\"layout == OnshoreFormTemplateLayout.vertical\">\n {{formTemplate.label}}\n <small *ngIf=\"formTemplate.required\" class=\"onshore-color-danger\">*</small>\n </b>\n\n <div *ngIf=\"formTemplate.tooltip && layout == OnshoreFormTemplateLayout.vertical\" [pTooltip]=\"formTemplate.tooltip\" [escape]=\"false\" appendTo=\"body\"><i class=\"fa fa-circle-question onshore-color-gray-5\"></i></div>\n\n </div>\n\n <div class=\"flex w-full\">\n <p-toggleButton\n *ngIf=\"formTemplate.locked\"\n (onChange)=\"lockChanged($event.checked)\"\n onIcon=\"fa fa-lock-open\"\n offIcon=\"fa fa-lock\"\n class=\"mr-2\"\n [style]=\"{height: '36px'}\"\n [disabled]=\"!formTemplate.enabled\">\n </p-toggleButton>\n\n <ng-content></ng-content>\n </div>\n\n <div *ngIf=\"formTemplate.tooltip && layout == OnshoreFormTemplateLayout.horizontal\" class=\"ml-2 align-self-center\" [pTooltip]=\"formTemplate.tooltip\" [escape]=\"false\"><i class=\"fa fa-circle-question onshore-color-gray-5\"></i></div>\n </div>\n\n <div *ngIf=\"ngControl.control.dirty\" [style]=\"{'margin-left': layout == OnshoreFormTemplateLayout.horizontal ? formLabel.clientWidth + 'px' : '0px'}\">\n <onshore-form-validation-output\n [validationItems]=\"formTemplate.validationItems\"\n [validationErrors]=\"ngControl.control.errors\">\n </onshore-form-validation-output>\n </div>\n\n <div [style]=\"{'margin-left': layout == OnshoreFormTemplateLayout.horizontal ? formLabel.clientWidth + 'px' : '0px'}\">\n <small *ngIf=\"formTemplate.description\" class=\"mt-2 onshore-color-gray-5\"><i class=\"fa fa-info-circle\"></i> {{formTemplate.description}}</small>\n </div>\n\n</div>\n" }]
86
+ args: [{ selector: 'onshore-form-item-container', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"mb-4\" #formContainer>\n <div class=\"flex w-full\"\n [class.flex-column]=\"layout == OnshoreFormTemplateLayout.vertical\"\n [class.flex-row]=\"layout == OnshoreFormTemplateLayout.horizontal\"\n [class.justify-content-between]=\"layout == OnshoreFormTemplateLayout.horizontal\">\n\n <div #formLabel\n class=\"flex justify-content-between\"\n [style]=\"formTemplate.labelStyle ?? 'min-width: 200px'\">\n\n <b [class.mr-2]=\"layout == OnshoreFormTemplateLayout.horizontal\"\n [class.mb-2]=\"layout == OnshoreFormTemplateLayout.vertical\">\n {{formTemplate.label}}\n <small *ngIf=\"formTemplate.required\" class=\"onshore-color-danger\">*</small>\n </b>\n\n <div *ngIf=\"formTemplate.tooltip && layout == OnshoreFormTemplateLayout.vertical\" [pTooltip]=\"formTemplate.tooltip\" [escape]=\"false\" appendTo=\"body\"><i class=\"fa fa-circle-question onshore-color-gray-5\"></i></div>\n\n </div>\n\n <div class=\"flex w-full\">\n <p-toggleButton\n *ngIf=\"formTemplate.locked\"\n (onChange)=\"lockChanged($event.checked)\"\n onIcon=\"fa fa-lock-open\"\n offIcon=\"fa fa-lock\"\n class=\"mr-2\"\n [style]=\"{height: '36px'}\"\n [disabled]=\"!formTemplate.enabled\">\n </p-toggleButton>\n\n <ng-content></ng-content>\n </div>\n\n <div *ngIf=\"formTemplate.tooltip && layout == OnshoreFormTemplateLayout.horizontal\" class=\"ml-2 align-self-center\" [pTooltip]=\"formTemplate.tooltip\" [escape]=\"false\"><i class=\"fa fa-circle-question onshore-color-gray-5\"></i></div>\n </div>\n\n <div *ngIf=\"ngControl.control.touched || ngControl.control.dirty\" [style]=\"{'margin-left': layout == OnshoreFormTemplateLayout.horizontal ? formLabel.clientWidth + 'px' : '0px'}\">\n <onshore-form-validation-output\n [validationItems]=\"formTemplate.validationItems\"\n [validationErrors]=\"ngControl.control.errors\">\n </onshore-form-validation-output>\n </div>\n\n <div [style]=\"{'margin-left': layout == OnshoreFormTemplateLayout.horizontal ? formLabel.clientWidth + 'px' : '0px'}\">\n <small *ngIf=\"formTemplate.description\" class=\"mt-2 onshore-color-gray-5\"><i class=\"fa fa-info-circle\"></i> {{formTemplate.description}}</small>\n </div>\n\n</div>\n" }]
87
87
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { formTemplate: [{
88
88
  type: Input
89
89
  }], ngControl: [{
@@ -95,4 +95,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
95
95
  type: HostListener,
96
96
  args: ['window:resize', ['$event']]
97
97
  }] } });
98
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-item-container.component.js","sourceRoot":"","sources":["../../../../../../projects/onshore-forms/src/lib/components/form-item-container/form-item-container.component.ts","../../../../../../projects/onshore-forms/src/lib/components/form-item-container/form-item-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component, ElementRef,\n  HostListener,\n  Input,\n  OnChanges,\n  OnInit,\n  SimpleChanges, ViewChild\n} from '@angular/core';\nimport { OnshoreFormTemplateItem } from '../../models/form.models';\nimport { OnshoreFormTemplateLayout } from '../../enums/form.enums';\nimport { NgControl } from '@angular/forms';\n\n@Component({\n  selector: 'onshore-form-item-container',\n  templateUrl: './form-item-container.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class OnshoreFormItemContainer implements OnInit, OnChanges {\n  @Input() formTemplate!: OnshoreFormTemplateItem;\n  @Input() ngControl!: NgControl;\n\n  @ViewChild('formContainer') formContainer!: ElementRef;\n\n  OnshoreFormTemplateLayout = OnshoreFormTemplateLayout;\n\n  layout: OnshoreFormTemplateLayout = OnshoreFormTemplateLayout.auto;\n\n  enabled(enable: boolean) {\n    setTimeout(() => {\n        if(enable) {\n          this.ngControl?.control.enable();\n        } else {\n          this.ngControl?.control.disable();\n        }\n        this.cdr.markForCheck();\n    }, 100);\n  }\n\n  lockChanged(unlocked: boolean) {\n    if(unlocked && this.formTemplate.enabled) {\n      this.enabled(true);\n    } else {\n      this.enabled(false);\n    }\n    this.cdr.markForCheck();\n  }\n\n  @HostListener('window:resize', ['$event'])\n  onWindowResize() {\n    const conatinerWidth = this.formContainer?.nativeElement.offsetWidth;\n    if(conatinerWidth > 500 && this.formTemplate.layout === OnshoreFormTemplateLayout.auto && this.layout !== OnshoreFormTemplateLayout.horizontal) {\n      this.layout = OnshoreFormTemplateLayout.horizontal;\n      this.cdr.markForCheck();\n    }\n    if(conatinerWidth <= 500 && this.formTemplate.layout === OnshoreFormTemplateLayout.auto && this.layout !== OnshoreFormTemplateLayout.vertical) {\n      this.layout = OnshoreFormTemplateLayout.vertical;\n      this.cdr.markForCheck();\n    }\n  }\n\n  ngOnInit(): void {\n    this.ngControl?.control?.valueChanges.subscribe(() => {\n      this.cdr.markForCheck();\n    });\n    this.ngControl?.control?.statusChanges.subscribe(() => {\n      this.cdr.markForCheck();\n    });\n\n    this.enabled(this.formTemplate.enabled);\n\n    if(this.formTemplate.locked) {\n      this.enabled(false);\n    }\n\n    this.layout = this.formTemplate.layout;\n    this.onWindowResize();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const previousValue = changes['formTemplate'].previousValue;\n    const currentValue = changes['formTemplate'].currentValue;\n\n    if(currentValue) {\n\n      if(previousValue?.enabled !== currentValue?.enabled) {\n        this.enabled(currentValue?.enabled);\n      }\n\n      if(previousValue?.locked !== currentValue?.locked) {\n        if(currentValue.locked) {\n          this.enabled(false);\n        } else {\n          this.enabled(currentValue.enabled);\n        }\n      }\n\n      if(previousValue?.layout !== currentValue?.layout) {\n        this.layout = this.formTemplate.layout;\n        this.onWindowResize();\n      }\n\n      this.cdr.markForCheck();\n    }\n  }\n\n  constructor(private cdr: ChangeDetectorRef) {\n  }\n}\n","<div class=\"mb-4\" #formContainer>\n  <div class=\"flex w-full\"\n       [class.flex-column]=\"layout == OnshoreFormTemplateLayout.vertical\"\n       [class.flex-row]=\"layout == OnshoreFormTemplateLayout.horizontal\"\n       [class.justify-content-between]=\"layout == OnshoreFormTemplateLayout.horizontal\">\n\n    <div #formLabel\n         class=\"flex justify-content-between\"\n         [style]=\"formTemplate.labelStyle ?? 'min-width: 200px'\">\n\n      <b [class.mr-2]=\"layout == OnshoreFormTemplateLayout.horizontal\"\n         [class.mb-2]=\"layout == OnshoreFormTemplateLayout.vertical\">\n        {{formTemplate.label}}\n        <small *ngIf=\"formTemplate.required\" class=\"onshore-color-danger\">*</small>\n      </b>\n\n      <div *ngIf=\"formTemplate.tooltip && layout == OnshoreFormTemplateLayout.vertical\" [pTooltip]=\"formTemplate.tooltip\" [escape]=\"false\" appendTo=\"body\"><i class=\"fa fa-circle-question onshore-color-gray-5\"></i></div>\n\n    </div>\n\n    <div class=\"flex w-full\">\n      <p-toggleButton\n        *ngIf=\"formTemplate.locked\"\n        (onChange)=\"lockChanged($event.checked)\"\n        onIcon=\"fa fa-lock-open\"\n        offIcon=\"fa fa-lock\"\n        class=\"mr-2\"\n        [style]=\"{height: '36px'}\"\n        [disabled]=\"!formTemplate.enabled\">\n      </p-toggleButton>\n\n      <ng-content></ng-content>\n    </div>\n\n    <div *ngIf=\"formTemplate.tooltip && layout == OnshoreFormTemplateLayout.horizontal\" class=\"ml-2 align-self-center\" [pTooltip]=\"formTemplate.tooltip\" [escape]=\"false\"><i class=\"fa fa-circle-question onshore-color-gray-5\"></i></div>\n  </div>\n\n  <div *ngIf=\"ngControl.control.dirty\" [style]=\"{'margin-left': layout == OnshoreFormTemplateLayout.horizontal ? formLabel.clientWidth + 'px' : '0px'}\">\n    <onshore-form-validation-output\n      [validationItems]=\"formTemplate.validationItems\"\n      [validationErrors]=\"ngControl.control.errors\">\n    </onshore-form-validation-output>\n  </div>\n\n  <div [style]=\"{'margin-left': layout == OnshoreFormTemplateLayout.horizontal ? formLabel.clientWidth + 'px' : '0px'}\">\n    <small *ngIf=\"formTemplate.description\" class=\"mt-2 onshore-color-gray-5\"><i class=\"fa fa-info-circle\"></i> {{formTemplate.description}}</small>\n  </div>\n\n</div>\n"]}
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-item-container.component.js","sourceRoot":"","sources":["../../../../../../projects/onshore-forms/src/lib/components/form-item-container/form-item-container.component.ts","../../../../../../projects/onshore-forms/src/lib/components/form-item-container/form-item-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component, ElementRef,\n  HostListener,\n  Input,\n  OnChanges,\n  OnInit,\n  SimpleChanges, ViewChild\n} from '@angular/core';\nimport { OnshoreFormTemplateItem } from '../../models/form.models';\nimport { OnshoreFormTemplateLayout } from '../../enums/form.enums';\nimport { NgControl } from '@angular/forms';\n\n@Component({\n  selector: 'onshore-form-item-container',\n  templateUrl: './form-item-container.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class OnshoreFormItemContainer implements OnInit, OnChanges {\n  @Input() formTemplate!: OnshoreFormTemplateItem;\n  @Input() ngControl!: NgControl;\n\n  @ViewChild('formContainer') formContainer!: ElementRef;\n\n  OnshoreFormTemplateLayout = OnshoreFormTemplateLayout;\n\n  layout: OnshoreFormTemplateLayout = OnshoreFormTemplateLayout.auto;\n\n  enabled(enable: boolean) {\n    setTimeout(() => {\n        if(enable) {\n          this.ngControl?.control.enable();\n        } else {\n          this.ngControl?.control.disable();\n        }\n        this.cdr.markForCheck();\n    }, 100);\n  }\n\n  lockChanged(unlocked: boolean) {\n    if(unlocked && this.formTemplate.enabled) {\n      this.enabled(true);\n    } else {\n      this.enabled(false);\n    }\n    this.cdr.markForCheck();\n  }\n\n  @HostListener('window:resize', ['$event'])\n  onWindowResize() {\n    const conatinerWidth = this.formContainer?.nativeElement.offsetWidth;\n    if(conatinerWidth > 500 && this.formTemplate.layout === OnshoreFormTemplateLayout.auto && this.layout !== OnshoreFormTemplateLayout.horizontal) {\n      this.layout = OnshoreFormTemplateLayout.horizontal;\n      this.cdr.markForCheck();\n    }\n    if(conatinerWidth <= 500 && this.formTemplate.layout === OnshoreFormTemplateLayout.auto && this.layout !== OnshoreFormTemplateLayout.vertical) {\n      this.layout = OnshoreFormTemplateLayout.vertical;\n      this.cdr.markForCheck();\n    }\n  }\n\n  ngOnInit(): void {\n    this.ngControl?.control?.valueChanges.subscribe(value => {\n      this.cdr.markForCheck();\n    });\n    this.ngControl?.control?.statusChanges.subscribe(status => {\n      this.cdr.markForCheck();\n    });\n\n    this.enabled(this.formTemplate.enabled);\n\n    if(this.formTemplate.locked) {\n      this.enabled(false);\n    }\n\n    this.layout = this.formTemplate.layout;\n    this.onWindowResize();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const previousValue = changes['formTemplate'].previousValue;\n    const currentValue = changes['formTemplate'].currentValue;\n\n    if(currentValue) {\n\n      if(previousValue?.enabled !== currentValue?.enabled) {\n        this.enabled(currentValue?.enabled);\n      }\n\n      if(previousValue?.locked !== currentValue?.locked) {\n        if(currentValue.locked) {\n          this.enabled(false);\n        } else {\n          this.enabled(currentValue.enabled);\n        }\n      }\n\n      if(previousValue?.layout !== currentValue?.layout) {\n        this.layout = this.formTemplate.layout;\n        this.onWindowResize();\n      }\n\n      this.cdr.markForCheck();\n    }\n  }\n\n  constructor(private cdr: ChangeDetectorRef) {\n\n  }\n}\n","<div class=\"mb-4\" #formContainer>\n  <div class=\"flex w-full\"\n       [class.flex-column]=\"layout == OnshoreFormTemplateLayout.vertical\"\n       [class.flex-row]=\"layout == OnshoreFormTemplateLayout.horizontal\"\n       [class.justify-content-between]=\"layout == OnshoreFormTemplateLayout.horizontal\">\n\n    <div #formLabel\n         class=\"flex justify-content-between\"\n         [style]=\"formTemplate.labelStyle ?? 'min-width: 200px'\">\n\n      <b [class.mr-2]=\"layout == OnshoreFormTemplateLayout.horizontal\"\n         [class.mb-2]=\"layout == OnshoreFormTemplateLayout.vertical\">\n        {{formTemplate.label}}\n        <small *ngIf=\"formTemplate.required\" class=\"onshore-color-danger\">*</small>\n      </b>\n\n      <div *ngIf=\"formTemplate.tooltip && layout == OnshoreFormTemplateLayout.vertical\" [pTooltip]=\"formTemplate.tooltip\" [escape]=\"false\" appendTo=\"body\"><i class=\"fa fa-circle-question onshore-color-gray-5\"></i></div>\n\n    </div>\n\n    <div class=\"flex w-full\">\n      <p-toggleButton\n        *ngIf=\"formTemplate.locked\"\n        (onChange)=\"lockChanged($event.checked)\"\n        onIcon=\"fa fa-lock-open\"\n        offIcon=\"fa fa-lock\"\n        class=\"mr-2\"\n        [style]=\"{height: '36px'}\"\n        [disabled]=\"!formTemplate.enabled\">\n      </p-toggleButton>\n\n      <ng-content></ng-content>\n    </div>\n\n    <div *ngIf=\"formTemplate.tooltip && layout == OnshoreFormTemplateLayout.horizontal\" class=\"ml-2 align-self-center\" [pTooltip]=\"formTemplate.tooltip\" [escape]=\"false\"><i class=\"fa fa-circle-question onshore-color-gray-5\"></i></div>\n  </div>\n\n  <div *ngIf=\"ngControl.control.touched || ngControl.control.dirty\" [style]=\"{'margin-left': layout == OnshoreFormTemplateLayout.horizontal ? formLabel.clientWidth + 'px' : '0px'}\">\n    <onshore-form-validation-output\n      [validationItems]=\"formTemplate.validationItems\"\n      [validationErrors]=\"ngControl.control.errors\">\n    </onshore-form-validation-output>\n  </div>\n\n  <div [style]=\"{'margin-left': layout == OnshoreFormTemplateLayout.horizontal ? formLabel.clientWidth + 'px' : '0px'}\">\n    <small *ngIf=\"formTemplate.description\" class=\"mt-2 onshore-color-gray-5\"><i class=\"fa fa-info-circle\"></i> {{formTemplate.description}}</small>\n  </div>\n\n</div>\n"]}
@@ -65,10 +65,10 @@ export class OnshoreImageChooserComponent {
65
65
  }
66
66
  }
67
67
  OnshoreImageChooserComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: OnshoreImageChooserComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
68
- OnshoreImageChooserComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: OnshoreImageChooserComponent, selector: "onshore-image-chooser", inputs: { imageSettings: "imageSettings" }, outputs: { choosen: "choosen", canceled: "canceled" }, ngImport: i0, template: "<div class=\"flex flex-column justify-content-center align-items-center w-full\">\n\n <div *ngIf=\"!image\" class=\"flex justify-content-center flex-column align-items-center w-full\">\n <!--<div style=\"max-width: 400px\" class=\"pt-4\">\n <app-info-box title=\"Hinweis\"\n [description]=\"'Die Bilddatei muss mindestens ' + resizeToWidth + 'px x ' + resizeToHeight + 'px betragen, darf maximal 6,4 MB gro\u00DF sein und muss im Dateiformat JPG oder PNG vorliegen.'\"\n icon=\"fa-info-circle\"\n backgroud=\"navy\"\n iconPosition=\"bottom\"\n [descriptionWrap]=\"true\">\n </app-info-box>\n </div>-->\n\n <div\n class=\"onshore-image-upload flex flex-column justify-content-between align-items-center rounded-lg p-4 relative m-3\"\n [class.onshore-border-gray-3]=\"drag\"\n [class.onshore-border-danger]=\"imageError != imageErrorType.none\">\n <i class=\"fa fa-image fa-5x onshore-color-gray-4\"></i>\n <small class=\"onshore-color-gray-4 mb-2\">{{'form.imageControl.dropImageLabel' | translate}}</small>\n\n <button pButton\n type=\"button\"\n icon=\"fa fa-file\"\n [label]=\"'form.imageControl.imageChooserFileButton' | translate\"\n class=\"onshore-button-primary mr-2\">\n </button>\n\n <input\n (change)=\"fileChange($event)\"\n *ngIf=\"!image\"\n accept=\"image/png, image/jpeg, image/webp\"\n class=\"onshore-image-input absolute w-full h-full\"\n type=\"file\"\n (dragenter)=\"drag = true\"\n (dragleave)=\"drag = false\"\n (dragend)=\"drag = false\"\n />\n </div>\n </div>\n\n <div class=\"flex flex-column relative align-items-center w-full\" *ngIf=\"image\">\n <image-cropper\n class=\"m-3\" [style]=\"'height: ' + imageSettings.cropperPreviewHeight + 'px; width: ' + imageSettings.cropperPreviewWidth + 'px'\"\n [class.onshore-cropper-circle]=\"this.imageSettings.circleCropper\"\n (imageCropped)=\"imageCropped($event)\"\n [imageBase64]=\"image\"\n [imageQuality]=\"this.imageSettings.imageQuality\"\n [alignImage]=\"this.imageSettings.alignImage\"\n [backgroundColor]=\"this.imageSettings.backgroundColor\"\n [containWithinAspectRatio]=\"this.imageSettings.containWithinAspectRatio\"\n [format]=\"this.imageSettings.format\"\n [aspectRatio]=\"this.imageSettings.aspectRatio\"\n [resizeToHeight]=\"this.imageSettings.imageWidth\"\n [resizeToWidth]=\"this.imageSettings.imageHeight\">\n </image-cropper>\n </div>\n\n <div *ngIf=\"imageError\"class=\"pb-2 text-wrap text-center onshore-color-danger\">\n <small *ngIf=\"imageError == imageErrorType.ratio\">{{'form.imageControl.imageErrorRatio' | translate: {resizeToWidth: this.imageSettings.imageWidth, resizeToHeight: this.imageSettings.imageHeight} }}</small>\n <small *ngIf=\"imageError == imageErrorType.fileType\">{{'form.imageControl.imageErrorFileType' | translate}}</small>\n <small *ngIf=\"imageError == imageErrorType.size\">{{'form.imageControl.imageErrorSize' | translate}}</small>\n </div>\n</div>\n\n\n<p-footer>\n <div class=\"flex justify-content-end align-items-center mt-2\">\n <button pButton\n type=\"button\"\n icon=\"fa fa-times\"\n [label]=\"'form.imageControl.imageChooserCancelButton' | translate\"\n class=\"onshore-button-light mr-2\"\n (click)=\"clear(); canceled.emit(true)\">\n </button>\n\n <button pButton\n type=\"button\"\n [label]=\"'form.imageControl.imageChooserSelectButton' | translate\"\n class=\"onshore-button-light\"\n icon=\"fa fa-check\"\n (click)=\"imageCroppedReady()\">\n </button>\n </div>\n</p-footer>\n\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "component", type: i3.Footer, selector: "p-footer" }, { kind: "component", type: i4.ImageCropperComponent, selector: "image-cropper", inputs: ["imageChangedEvent", "imageURL", "imageBase64", "imageFile", "format", "transform", "maintainAspectRatio", "aspectRatio", "resizeToWidth", "resizeToHeight", "cropperMinWidth", "cropperMinHeight", "cropperMaxHeight", "cropperMaxWidth", "cropperStaticWidth", "cropperStaticHeight", "canvasRotation", "initialStepSize", "roundCropper", "onlyScaleDown", "imageQuality", "autoCrop", "backgroundColor", "containWithinAspectRatio", "hideResizeSquares", "allowMoveImage", "cropper", "alignImage", "disabled"], outputs: ["imageCropped", "startCropImage", "imageLoaded", "cropperReady", "loadImageFailed", "transformChange"] }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
68
+ OnshoreImageChooserComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: OnshoreImageChooserComponent, selector: "onshore-image-chooser", inputs: { imageSettings: "imageSettings" }, outputs: { choosen: "choosen", canceled: "canceled" }, ngImport: i0, template: "<div class=\"flex flex-column justify-content-center align-items-center w-full\">\n\n <div *ngIf=\"!image\" class=\"flex justify-content-center flex-column align-items-center w-full\">\n <div\n class=\"onshore-image-upload flex flex-column justify-content-between align-items-center rounded-lg p-4 relative m-3\"\n [class.onshore-border-gray-3]=\"drag\"\n [class.onshore-border-danger]=\"imageError != imageErrorType.none\">\n <i class=\"fa fa-image fa-5x onshore-color-gray-4\"></i>\n <small class=\"onshore-color-gray-4 mb-2\">{{'form.imageControl.dropImageLabel' | translate}}</small>\n\n <button pButton\n type=\"button\"\n icon=\"fa fa-file\"\n [label]=\"'form.imageControl.imageChooserFileButton' | translate\"\n class=\"onshore-button-primary mr-2\">\n </button>\n\n <input\n (change)=\"fileChange($event)\"\n *ngIf=\"!image\"\n accept=\"image/png, image/jpeg, image/webp\"\n class=\"onshore-image-input absolute w-full h-full\"\n type=\"file\"\n (dragenter)=\"drag = true\"\n (dragleave)=\"drag = false\"\n (dragend)=\"drag = false\"\n />\n </div>\n </div>\n\n <div class=\"flex flex-column relative align-items-center w-full\" *ngIf=\"image\">\n <image-cropper\n class=\"m-3\"\n [style]=\"'align-items: center; height: ' + (imageSettings.cropperPreviewHeight * this.imageSettings.aspectRatio) + 'px; width: ' + (imageSettings.cropperPreviewWidth * this.imageSettings.aspectRatio) + 'px'\"\n [class.onshore-cropper-circle]=\"this.imageSettings.circleCropper\"\n (imageCropped)=\"imageCropped($event)\"\n [imageBase64]=\"image\"\n [imageQuality]=\"this.imageSettings.imageQuality\"\n [alignImage]=\"this.imageSettings.alignImage\"\n [backgroundColor]=\"this.imageSettings.backgroundColor\"\n [containWithinAspectRatio]=\"this.imageSettings.containWithinAspectRatio\"\n [format]=\"this.imageSettings.format\"\n [aspectRatio]=\"this.imageSettings.aspectRatio\"\n [resizeToHeight]=\"this.imageSettings.imageWidth * this.imageSettings.aspectRatio\"\n [resizeToWidth]=\"this.imageSettings.imageHeight * this.imageSettings.aspectRatio\">\n </image-cropper>\n </div>\n\n <div *ngIf=\"imageError\"class=\"pb-2 text-wrap text-center onshore-color-danger\">\n <small *ngIf=\"imageError == imageErrorType.ratio\">{{'form.imageControl.imageErrorRatio' | translate: {resizeToWidth: this.imageSettings.imageWidth, resizeToHeight: this.imageSettings.imageHeight} }}</small>\n <small *ngIf=\"imageError == imageErrorType.fileType\">{{'form.imageControl.imageErrorFileType' | translate}}</small>\n <small *ngIf=\"imageError == imageErrorType.size\">{{'form.imageControl.imageErrorSize' | translate}}</small>\n </div>\n</div>\n\n\n<p-footer>\n <div class=\"flex justify-content-end align-items-center mt-2\">\n <button pButton\n type=\"button\"\n icon=\"fa fa-times\"\n [label]=\"'form.imageControl.imageChooserCancelButton' | translate\"\n class=\"onshore-button-light mr-2\"\n (click)=\"clear(); canceled.emit(true)\">\n </button>\n\n <button pButton\n type=\"button\"\n [label]=\"'form.imageControl.imageChooserSelectButton' | translate\"\n class=\"onshore-button-primary\"\n icon=\"fa fa-check\"\n [disabled]=\"!image\"\n (click)=\"imageCroppedReady()\">\n </button>\n </div>\n</p-footer>\n\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "component", type: i3.Footer, selector: "p-footer" }, { kind: "component", type: i4.ImageCropperComponent, selector: "image-cropper", inputs: ["imageChangedEvent", "imageURL", "imageBase64", "imageFile", "format", "transform", "maintainAspectRatio", "aspectRatio", "resizeToWidth", "resizeToHeight", "cropperMinWidth", "cropperMinHeight", "cropperMaxHeight", "cropperMaxWidth", "cropperStaticWidth", "cropperStaticHeight", "canvasRotation", "initialStepSize", "roundCropper", "onlyScaleDown", "imageQuality", "autoCrop", "backgroundColor", "containWithinAspectRatio", "hideResizeSquares", "allowMoveImage", "cropper", "alignImage", "disabled"], outputs: ["imageCropped", "startCropImage", "imageLoaded", "cropperReady", "loadImageFailed", "transformChange"] }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
69
69
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: OnshoreImageChooserComponent, decorators: [{
70
70
  type: Component,
71
- args: [{ selector: 'onshore-image-chooser', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"flex flex-column justify-content-center align-items-center w-full\">\n\n <div *ngIf=\"!image\" class=\"flex justify-content-center flex-column align-items-center w-full\">\n <!--<div style=\"max-width: 400px\" class=\"pt-4\">\n <app-info-box title=\"Hinweis\"\n [description]=\"'Die Bilddatei muss mindestens ' + resizeToWidth + 'px x ' + resizeToHeight + 'px betragen, darf maximal 6,4 MB gro\u00DF sein und muss im Dateiformat JPG oder PNG vorliegen.'\"\n icon=\"fa-info-circle\"\n backgroud=\"navy\"\n iconPosition=\"bottom\"\n [descriptionWrap]=\"true\">\n </app-info-box>\n </div>-->\n\n <div\n class=\"onshore-image-upload flex flex-column justify-content-between align-items-center rounded-lg p-4 relative m-3\"\n [class.onshore-border-gray-3]=\"drag\"\n [class.onshore-border-danger]=\"imageError != imageErrorType.none\">\n <i class=\"fa fa-image fa-5x onshore-color-gray-4\"></i>\n <small class=\"onshore-color-gray-4 mb-2\">{{'form.imageControl.dropImageLabel' | translate}}</small>\n\n <button pButton\n type=\"button\"\n icon=\"fa fa-file\"\n [label]=\"'form.imageControl.imageChooserFileButton' | translate\"\n class=\"onshore-button-primary mr-2\">\n </button>\n\n <input\n (change)=\"fileChange($event)\"\n *ngIf=\"!image\"\n accept=\"image/png, image/jpeg, image/webp\"\n class=\"onshore-image-input absolute w-full h-full\"\n type=\"file\"\n (dragenter)=\"drag = true\"\n (dragleave)=\"drag = false\"\n (dragend)=\"drag = false\"\n />\n </div>\n </div>\n\n <div class=\"flex flex-column relative align-items-center w-full\" *ngIf=\"image\">\n <image-cropper\n class=\"m-3\" [style]=\"'height: ' + imageSettings.cropperPreviewHeight + 'px; width: ' + imageSettings.cropperPreviewWidth + 'px'\"\n [class.onshore-cropper-circle]=\"this.imageSettings.circleCropper\"\n (imageCropped)=\"imageCropped($event)\"\n [imageBase64]=\"image\"\n [imageQuality]=\"this.imageSettings.imageQuality\"\n [alignImage]=\"this.imageSettings.alignImage\"\n [backgroundColor]=\"this.imageSettings.backgroundColor\"\n [containWithinAspectRatio]=\"this.imageSettings.containWithinAspectRatio\"\n [format]=\"this.imageSettings.format\"\n [aspectRatio]=\"this.imageSettings.aspectRatio\"\n [resizeToHeight]=\"this.imageSettings.imageWidth\"\n [resizeToWidth]=\"this.imageSettings.imageHeight\">\n </image-cropper>\n </div>\n\n <div *ngIf=\"imageError\"class=\"pb-2 text-wrap text-center onshore-color-danger\">\n <small *ngIf=\"imageError == imageErrorType.ratio\">{{'form.imageControl.imageErrorRatio' | translate: {resizeToWidth: this.imageSettings.imageWidth, resizeToHeight: this.imageSettings.imageHeight} }}</small>\n <small *ngIf=\"imageError == imageErrorType.fileType\">{{'form.imageControl.imageErrorFileType' | translate}}</small>\n <small *ngIf=\"imageError == imageErrorType.size\">{{'form.imageControl.imageErrorSize' | translate}}</small>\n </div>\n</div>\n\n\n<p-footer>\n <div class=\"flex justify-content-end align-items-center mt-2\">\n <button pButton\n type=\"button\"\n icon=\"fa fa-times\"\n [label]=\"'form.imageControl.imageChooserCancelButton' | translate\"\n class=\"onshore-button-light mr-2\"\n (click)=\"clear(); canceled.emit(true)\">\n </button>\n\n <button pButton\n type=\"button\"\n [label]=\"'form.imageControl.imageChooserSelectButton' | translate\"\n class=\"onshore-button-light\"\n icon=\"fa fa-check\"\n (click)=\"imageCroppedReady()\">\n </button>\n </div>\n</p-footer>\n\n" }]
71
+ args: [{ selector: 'onshore-image-chooser', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"flex flex-column justify-content-center align-items-center w-full\">\n\n <div *ngIf=\"!image\" class=\"flex justify-content-center flex-column align-items-center w-full\">\n <div\n class=\"onshore-image-upload flex flex-column justify-content-between align-items-center rounded-lg p-4 relative m-3\"\n [class.onshore-border-gray-3]=\"drag\"\n [class.onshore-border-danger]=\"imageError != imageErrorType.none\">\n <i class=\"fa fa-image fa-5x onshore-color-gray-4\"></i>\n <small class=\"onshore-color-gray-4 mb-2\">{{'form.imageControl.dropImageLabel' | translate}}</small>\n\n <button pButton\n type=\"button\"\n icon=\"fa fa-file\"\n [label]=\"'form.imageControl.imageChooserFileButton' | translate\"\n class=\"onshore-button-primary mr-2\">\n </button>\n\n <input\n (change)=\"fileChange($event)\"\n *ngIf=\"!image\"\n accept=\"image/png, image/jpeg, image/webp\"\n class=\"onshore-image-input absolute w-full h-full\"\n type=\"file\"\n (dragenter)=\"drag = true\"\n (dragleave)=\"drag = false\"\n (dragend)=\"drag = false\"\n />\n </div>\n </div>\n\n <div class=\"flex flex-column relative align-items-center w-full\" *ngIf=\"image\">\n <image-cropper\n class=\"m-3\"\n [style]=\"'align-items: center; height: ' + (imageSettings.cropperPreviewHeight * this.imageSettings.aspectRatio) + 'px; width: ' + (imageSettings.cropperPreviewWidth * this.imageSettings.aspectRatio) + 'px'\"\n [class.onshore-cropper-circle]=\"this.imageSettings.circleCropper\"\n (imageCropped)=\"imageCropped($event)\"\n [imageBase64]=\"image\"\n [imageQuality]=\"this.imageSettings.imageQuality\"\n [alignImage]=\"this.imageSettings.alignImage\"\n [backgroundColor]=\"this.imageSettings.backgroundColor\"\n [containWithinAspectRatio]=\"this.imageSettings.containWithinAspectRatio\"\n [format]=\"this.imageSettings.format\"\n [aspectRatio]=\"this.imageSettings.aspectRatio\"\n [resizeToHeight]=\"this.imageSettings.imageWidth * this.imageSettings.aspectRatio\"\n [resizeToWidth]=\"this.imageSettings.imageHeight * this.imageSettings.aspectRatio\">\n </image-cropper>\n </div>\n\n <div *ngIf=\"imageError\"class=\"pb-2 text-wrap text-center onshore-color-danger\">\n <small *ngIf=\"imageError == imageErrorType.ratio\">{{'form.imageControl.imageErrorRatio' | translate: {resizeToWidth: this.imageSettings.imageWidth, resizeToHeight: this.imageSettings.imageHeight} }}</small>\n <small *ngIf=\"imageError == imageErrorType.fileType\">{{'form.imageControl.imageErrorFileType' | translate}}</small>\n <small *ngIf=\"imageError == imageErrorType.size\">{{'form.imageControl.imageErrorSize' | translate}}</small>\n </div>\n</div>\n\n\n<p-footer>\n <div class=\"flex justify-content-end align-items-center mt-2\">\n <button pButton\n type=\"button\"\n icon=\"fa fa-times\"\n [label]=\"'form.imageControl.imageChooserCancelButton' | translate\"\n class=\"onshore-button-light mr-2\"\n (click)=\"clear(); canceled.emit(true)\">\n </button>\n\n <button pButton\n type=\"button\"\n [label]=\"'form.imageControl.imageChooserSelectButton' | translate\"\n class=\"onshore-button-primary\"\n icon=\"fa fa-check\"\n [disabled]=\"!image\"\n (click)=\"imageCroppedReady()\">\n </button>\n </div>\n</p-footer>\n\n" }]
72
72
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { imageSettings: [{
73
73
  type: Input
74
74
  }], choosen: [{
@@ -76,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
76
76
  }], canceled: [{
77
77
  type: Output
78
78
  }] } });
79
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-chooser.component.js","sourceRoot":"","sources":["../../../../../../projects/onshore-forms/src/lib/components/image-chooser/image-chooser.component.ts","../../../../../../projects/onshore-forms/src/lib/components/image-chooser/image-chooser.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output\n} from '@angular/core';\nimport { ImageCroppedEvent } from 'ngx-image-cropper';\nimport { OnshoreImageError } from '../../enums/form.enums';\nimport { OnshoreFormImageSettings } from '../../models/form.models';\n\n@Component({\n  selector: 'onshore-image-chooser',\n  templateUrl: './image-chooser.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class OnshoreImageChooserComponent {\n\n  drag = false;\n  image = '';\n  finalImage = '';\n  imageErrorType = OnshoreImageError;\n  imageError: OnshoreImageError = OnshoreImageError.none;\n\n  @Input() imageSettings: OnshoreFormImageSettings;\n\n  @Output() choosen: EventEmitter<string> = new EventEmitter();\n  @Output() canceled: EventEmitter<boolean> = new EventEmitter();\n\n  clear() {\n    this.image = '';\n    this.finalImage = '';\n    this.imageError = OnshoreImageError.none;\n  }\n\n  public fileChange(event: Event): void {\n    this.imageError = OnshoreImageError.none;\n    const target = event.target as HTMLInputElement;\n    const file: File | undefined | null = target?.files ? target?.files[0] : null;\n\n    if (file?.type != 'image/png' && file?.type != 'image/jpeg' && file?.type != 'image/webp') {\n      this.imageError = OnshoreImageError.fileType;\n      return;\n    }\n\n    if (file?.size > this.imageSettings.maxFileSize) {\n      this.imageError = OnshoreImageError.size;\n      return;\n    }\n\n    if (file) {\n      const reader = new FileReader();\n      reader.readAsDataURL(file);\n      reader.onload = () => {\n\n        const img = new Image();\n        img.src = window.URL.createObjectURL(file);\n        img.onload = () => {\n\n          const originalWidth = img.width;\n          const originalHeight = img.height;\n\n          if (originalWidth >= this.imageSettings.imageWidth && originalHeight >= this.imageSettings.imageHeight) {\n            this.image = reader.result?.toString() || '';\n          } else {\n            this.imageError = OnshoreImageError.ratio;\n          }\n          this.cdr.markForCheck();\n\n        }\n\n      };\n    }\n\n\n\n  }\n\n  public imageCropped(event: ImageCroppedEvent): void {\n    // ToDo: Check needed base64 format\n    //this.finalImage = event.base64.split(',')[1];\n    this.finalImage = event.base64 || '';\n  }\n\n  public imageCroppedReady(): void {\n    this.choosen.emit(this.finalImage);\n    this.clear();\n  }\n\n  constructor(private cdr: ChangeDetectorRef) {\n  }\n}\n","<div class=\"flex flex-column justify-content-center align-items-center w-full\">\n\n  <div *ngIf=\"!image\" class=\"flex justify-content-center flex-column align-items-center w-full\">\n    <!--<div style=\"max-width: 400px\" class=\"pt-4\">\n      <app-info-box title=\"Hinweis\"\n                    [description]=\"'Die Bilddatei muss mindestens ' + resizeToWidth + 'px x ' + resizeToHeight + 'px betragen, darf maximal 6,4 MB groß sein und muss im Dateiformat JPG oder PNG vorliegen.'\"\n                    icon=\"fa-info-circle\"\n                    backgroud=\"navy\"\n                    iconPosition=\"bottom\"\n                    [descriptionWrap]=\"true\">\n      </app-info-box>\n    </div>-->\n\n    <div\n      class=\"onshore-image-upload flex flex-column justify-content-between align-items-center rounded-lg p-4 relative m-3\"\n      [class.onshore-border-gray-3]=\"drag\"\n      [class.onshore-border-danger]=\"imageError != imageErrorType.none\">\n      <i class=\"fa fa-image fa-5x onshore-color-gray-4\"></i>\n      <small class=\"onshore-color-gray-4 mb-2\">{{'form.imageControl.dropImageLabel' | translate}}</small>\n\n      <button pButton\n              type=\"button\"\n              icon=\"fa fa-file\"\n              [label]=\"'form.imageControl.imageChooserFileButton' | translate\"\n              class=\"onshore-button-primary mr-2\">\n      </button>\n\n      <input\n        (change)=\"fileChange($event)\"\n        *ngIf=\"!image\"\n        accept=\"image/png, image/jpeg, image/webp\"\n        class=\"onshore-image-input absolute w-full h-full\"\n        type=\"file\"\n        (dragenter)=\"drag = true\"\n        (dragleave)=\"drag = false\"\n        (dragend)=\"drag = false\"\n      />\n    </div>\n  </div>\n\n  <div class=\"flex flex-column relative align-items-center w-full\" *ngIf=\"image\">\n    <image-cropper\n      class=\"m-3\" [style]=\"'height: ' + imageSettings.cropperPreviewHeight + 'px; width: ' + imageSettings.cropperPreviewWidth + 'px'\"\n      [class.onshore-cropper-circle]=\"this.imageSettings.circleCropper\"\n      (imageCropped)=\"imageCropped($event)\"\n      [imageBase64]=\"image\"\n      [imageQuality]=\"this.imageSettings.imageQuality\"\n      [alignImage]=\"this.imageSettings.alignImage\"\n      [backgroundColor]=\"this.imageSettings.backgroundColor\"\n      [containWithinAspectRatio]=\"this.imageSettings.containWithinAspectRatio\"\n      [format]=\"this.imageSettings.format\"\n      [aspectRatio]=\"this.imageSettings.aspectRatio\"\n      [resizeToHeight]=\"this.imageSettings.imageWidth\"\n      [resizeToWidth]=\"this.imageSettings.imageHeight\">\n    </image-cropper>\n  </div>\n\n  <div *ngIf=\"imageError\"class=\"pb-2 text-wrap text-center onshore-color-danger\">\n    <small *ngIf=\"imageError == imageErrorType.ratio\">{{'form.imageControl.imageErrorRatio' | translate: {resizeToWidth: this.imageSettings.imageWidth, resizeToHeight: this.imageSettings.imageHeight} }}</small>\n    <small *ngIf=\"imageError == imageErrorType.fileType\">{{'form.imageControl.imageErrorFileType' | translate}}</small>\n    <small *ngIf=\"imageError == imageErrorType.size\">{{'form.imageControl.imageErrorSize' | translate}}</small>\n  </div>\n</div>\n\n\n<p-footer>\n  <div class=\"flex justify-content-end align-items-center mt-2\">\n    <button pButton\n            type=\"button\"\n            icon=\"fa fa-times\"\n            [label]=\"'form.imageControl.imageChooserCancelButton' | translate\"\n            class=\"onshore-button-light mr-2\"\n            (click)=\"clear(); canceled.emit(true)\">\n    </button>\n\n    <button pButton\n            type=\"button\"\n            [label]=\"'form.imageControl.imageChooserSelectButton' | translate\"\n            class=\"onshore-button-light\"\n            icon=\"fa fa-check\"\n            (click)=\"imageCroppedReady()\">\n    </button>\n  </div>\n</p-footer>\n\n"]}
79
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-chooser.component.js","sourceRoot":"","sources":["../../../../../../projects/onshore-forms/src/lib/components/image-chooser/image-chooser.component.ts","../../../../../../projects/onshore-forms/src/lib/components/image-chooser/image-chooser.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output\n} from '@angular/core';\nimport { ImageCroppedEvent } from 'ngx-image-cropper';\nimport { OnshoreImageError } from '../../enums/form.enums';\nimport { OnshoreFormImageSettings } from '../../models/form.models';\n\n@Component({\n  selector: 'onshore-image-chooser',\n  templateUrl: './image-chooser.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class OnshoreImageChooserComponent {\n\n  drag = false;\n  image = '';\n  finalImage = '';\n  imageErrorType = OnshoreImageError;\n  imageError: OnshoreImageError = OnshoreImageError.none;\n\n  @Input() imageSettings: OnshoreFormImageSettings;\n\n  @Output() choosen: EventEmitter<string> = new EventEmitter();\n  @Output() canceled: EventEmitter<boolean> = new EventEmitter();\n\n  clear() {\n    this.image = '';\n    this.finalImage = '';\n    this.imageError = OnshoreImageError.none;\n  }\n\n  public fileChange(event: Event): void {\n    this.imageError = OnshoreImageError.none;\n    const target = event.target as HTMLInputElement;\n    const file: File | undefined | null = target?.files ? target?.files[0] : null;\n\n    if (file?.type != 'image/png' && file?.type != 'image/jpeg' && file?.type != 'image/webp') {\n      this.imageError = OnshoreImageError.fileType;\n      return;\n    }\n\n    if (file?.size > this.imageSettings.maxFileSize) {\n      this.imageError = OnshoreImageError.size;\n      return;\n    }\n\n    if (file) {\n      const reader = new FileReader();\n      reader.readAsDataURL(file);\n      reader.onload = () => {\n\n        const img = new Image();\n        img.src = window.URL.createObjectURL(file);\n        img.onload = () => {\n\n          const originalWidth = img.width;\n          const originalHeight = img.height;\n\n          if (originalWidth >= this.imageSettings.imageWidth && originalHeight >= this.imageSettings.imageHeight) {\n            this.image = reader.result?.toString() || '';\n          } else {\n            this.imageError = OnshoreImageError.ratio;\n          }\n          this.cdr.markForCheck();\n\n        }\n\n      };\n    }\n\n\n\n  }\n\n  public imageCropped(event: ImageCroppedEvent): void {\n    // ToDo: Check needed base64 format\n    //this.finalImage = event.base64.split(',')[1];\n    this.finalImage = event.base64 || '';\n  }\n\n  public imageCroppedReady(): void {\n    this.choosen.emit(this.finalImage);\n    this.clear();\n  }\n\n  constructor(private cdr: ChangeDetectorRef) {\n  }\n}\n","<div class=\"flex flex-column justify-content-center align-items-center w-full\">\n\n  <div *ngIf=\"!image\" class=\"flex justify-content-center flex-column align-items-center w-full\">\n    <div\n      class=\"onshore-image-upload flex flex-column justify-content-between align-items-center rounded-lg p-4 relative m-3\"\n      [class.onshore-border-gray-3]=\"drag\"\n      [class.onshore-border-danger]=\"imageError != imageErrorType.none\">\n      <i class=\"fa fa-image fa-5x onshore-color-gray-4\"></i>\n      <small class=\"onshore-color-gray-4 mb-2\">{{'form.imageControl.dropImageLabel' | translate}}</small>\n\n      <button pButton\n              type=\"button\"\n              icon=\"fa fa-file\"\n              [label]=\"'form.imageControl.imageChooserFileButton' | translate\"\n              class=\"onshore-button-primary mr-2\">\n      </button>\n\n      <input\n        (change)=\"fileChange($event)\"\n        *ngIf=\"!image\"\n        accept=\"image/png, image/jpeg, image/webp\"\n        class=\"onshore-image-input absolute w-full h-full\"\n        type=\"file\"\n        (dragenter)=\"drag = true\"\n        (dragleave)=\"drag = false\"\n        (dragend)=\"drag = false\"\n      />\n    </div>\n  </div>\n\n  <div class=\"flex flex-column relative align-items-center w-full\" *ngIf=\"image\">\n    <image-cropper\n      class=\"m-3\"\n      [style]=\"'align-items: center; height: ' + (imageSettings.cropperPreviewHeight * this.imageSettings.aspectRatio) + 'px; width: ' + (imageSettings.cropperPreviewWidth * this.imageSettings.aspectRatio) + 'px'\"\n      [class.onshore-cropper-circle]=\"this.imageSettings.circleCropper\"\n      (imageCropped)=\"imageCropped($event)\"\n      [imageBase64]=\"image\"\n      [imageQuality]=\"this.imageSettings.imageQuality\"\n      [alignImage]=\"this.imageSettings.alignImage\"\n      [backgroundColor]=\"this.imageSettings.backgroundColor\"\n      [containWithinAspectRatio]=\"this.imageSettings.containWithinAspectRatio\"\n      [format]=\"this.imageSettings.format\"\n      [aspectRatio]=\"this.imageSettings.aspectRatio\"\n      [resizeToHeight]=\"this.imageSettings.imageWidth * this.imageSettings.aspectRatio\"\n      [resizeToWidth]=\"this.imageSettings.imageHeight * this.imageSettings.aspectRatio\">\n    </image-cropper>\n  </div>\n\n  <div *ngIf=\"imageError\"class=\"pb-2 text-wrap text-center onshore-color-danger\">\n    <small *ngIf=\"imageError == imageErrorType.ratio\">{{'form.imageControl.imageErrorRatio' | translate: {resizeToWidth: this.imageSettings.imageWidth, resizeToHeight: this.imageSettings.imageHeight} }}</small>\n    <small *ngIf=\"imageError == imageErrorType.fileType\">{{'form.imageControl.imageErrorFileType' | translate}}</small>\n    <small *ngIf=\"imageError == imageErrorType.size\">{{'form.imageControl.imageErrorSize' | translate}}</small>\n  </div>\n</div>\n\n\n<p-footer>\n  <div class=\"flex justify-content-end align-items-center mt-2\">\n    <button pButton\n            type=\"button\"\n            icon=\"fa fa-times\"\n            [label]=\"'form.imageControl.imageChooserCancelButton' | translate\"\n            class=\"onshore-button-light mr-2\"\n            (click)=\"clear(); canceled.emit(true)\">\n    </button>\n\n    <button pButton\n            type=\"button\"\n            [label]=\"'form.imageControl.imageChooserSelectButton' | translate\"\n            class=\"onshore-button-primary\"\n            icon=\"fa fa-check\"\n            [disabled]=\"!image\"\n            (click)=\"imageCroppedReady()\">\n    </button>\n  </div>\n</p-footer>\n\n"]}
@@ -21,10 +21,10 @@ export class OnshoreImagePlaceholderComponent {
21
21
  }
22
22
  }
23
23
  OnshoreImagePlaceholderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: OnshoreImagePlaceholderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
24
- OnshoreImagePlaceholderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: OnshoreImagePlaceholderComponent, selector: "onshore-image-placeholder", inputs: { placeholderIcon: "placeholderIcon", placeholderImage: "placeholderImage", image: "image", imageStyle: "imageStyle", placeholderStyle: "placeholderStyle", showLoader: "showLoader" }, ngImport: i0, template: "<div class=\"h-full\" [hidden]=\"!imageLoaded || !image\">\n <img [style]=\"imageStyle\" [src]=\"image\" (load)=\"loadReady()\" (abort)=\"abort()\" />\n</div>\n\n<div *ngIf=\"!imageLoaded || !image\" class=\"flex justify-content-center align-items-center\" [style]=\"placeholderStyle\" [class.bg-gray-200]=\"placeholderIcon\" [class.p-2]=\"placeholderIcon\">\n <i *ngIf=\"placeholderIcon\" [class]=\"'text-muted fa ' + placeholderIcon\" [class.opacity-20]=\"showLoader && image\"></i>\n <img *ngIf=\"placeholderImage\" [src]=\"placeholderImage\" [class.opacity-20]=\"showLoader && image\" class=\"h-full\" />\n <i *ngIf=\"showLoader && image\" class=\"fas fa-circle-notch fa-spin fa-2x absolute\"></i>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
24
+ OnshoreImagePlaceholderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: OnshoreImagePlaceholderComponent, selector: "onshore-image-placeholder", inputs: { placeholderIcon: "placeholderIcon", placeholderImage: "placeholderImage", image: "image", imageStyle: "imageStyle", placeholderStyle: "placeholderStyle", showLoader: "showLoader" }, ngImport: i0, template: "<div [hidden]=\"!imageLoaded || !image\">\n <img [style]=\"imageStyle\" [src]=\"image\" (load)=\"loadReady()\" (abort)=\"abort()\" />\n</div>\n\n<div *ngIf=\"!imageLoaded || !image\" class=\"flex justify-content-center align-items-center\" [style]=\"placeholderStyle\" [class.bg-gray-200]=\"placeholderIcon\" [class.p-2]=\"placeholderIcon\">\n <i *ngIf=\"placeholderIcon\" [class]=\"'text-muted fa ' + placeholderIcon\" [class.opacity-20]=\"showLoader && image\"></i>\n <img *ngIf=\"placeholderImage\" [src]=\"placeholderImage\" [class.opacity-20]=\"showLoader && image\" class=\"h-full\" />\n <i *ngIf=\"showLoader && image\" class=\"fas fa-circle-notch fa-spin fa-2x absolute\"></i>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
25
25
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: OnshoreImagePlaceholderComponent, decorators: [{
26
26
  type: Component,
27
- args: [{ selector: 'onshore-image-placeholder', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"h-full\" [hidden]=\"!imageLoaded || !image\">\n <img [style]=\"imageStyle\" [src]=\"image\" (load)=\"loadReady()\" (abort)=\"abort()\" />\n</div>\n\n<div *ngIf=\"!imageLoaded || !image\" class=\"flex justify-content-center align-items-center\" [style]=\"placeholderStyle\" [class.bg-gray-200]=\"placeholderIcon\" [class.p-2]=\"placeholderIcon\">\n <i *ngIf=\"placeholderIcon\" [class]=\"'text-muted fa ' + placeholderIcon\" [class.opacity-20]=\"showLoader && image\"></i>\n <img *ngIf=\"placeholderImage\" [src]=\"placeholderImage\" [class.opacity-20]=\"showLoader && image\" class=\"h-full\" />\n <i *ngIf=\"showLoader && image\" class=\"fas fa-circle-notch fa-spin fa-2x absolute\"></i>\n</div>\n" }]
27
+ args: [{ selector: 'onshore-image-placeholder', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [hidden]=\"!imageLoaded || !image\">\n <img [style]=\"imageStyle\" [src]=\"image\" (load)=\"loadReady()\" (abort)=\"abort()\" />\n</div>\n\n<div *ngIf=\"!imageLoaded || !image\" class=\"flex justify-content-center align-items-center\" [style]=\"placeholderStyle\" [class.bg-gray-200]=\"placeholderIcon\" [class.p-2]=\"placeholderIcon\">\n <i *ngIf=\"placeholderIcon\" [class]=\"'text-muted fa ' + placeholderIcon\" [class.opacity-20]=\"showLoader && image\"></i>\n <img *ngIf=\"placeholderImage\" [src]=\"placeholderImage\" [class.opacity-20]=\"showLoader && image\" class=\"h-full\" />\n <i *ngIf=\"showLoader && image\" class=\"fas fa-circle-notch fa-spin fa-2x absolute\"></i>\n</div>\n" }]
28
28
  }], ctorParameters: function () { return []; }, propDecorators: { placeholderIcon: [{
29
29
  type: Input
30
30
  }], placeholderImage: [{
@@ -38,4 +38,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
38
38
  }], showLoader: [{
39
39
  type: Input
40
40
  }] } });
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UtcGxhY2Vob2xkZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvb25zaG9yZS1mb3Jtcy9zcmMvbGliL2NvbXBvbmVudHMvaW1hZ2UtcGxhY2Vob2xkZXIvaW1hZ2UtcGxhY2Vob2xkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvb25zaG9yZS1mb3Jtcy9zcmMvbGliL2NvbXBvbmVudHMvaW1hZ2UtcGxhY2Vob2xkZXIvaW1hZ2UtcGxhY2Vob2xkZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQU8xRSxNQUFNLE9BQU8sZ0NBQWdDO0lBcUIzQztRQW5CZ0Isb0JBQWUsR0FBVyxFQUFFLENBQUM7UUFDN0IscUJBQWdCLEdBQVcsRUFBRSxDQUFDO1FBQzlCLFVBQUssR0FBVyxFQUFFLENBQUM7UUFDbkIsZUFBVSxHQUFXLEVBQUUsQ0FBQztRQUN4QixxQkFBZ0IsR0FBVyxFQUFFLENBQUM7UUFDOUIsZUFBVSxHQUFZLElBQUksQ0FBQztRQUUzQyxnQkFBVyxHQUFHLEtBQUssQ0FBQztJQVlMLENBQUM7SUFWaEIsU0FBUztRQUNQLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDO0lBQzFCLENBQUM7SUFFRCxLQUFLO1FBQ0gsSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLENBQUM7UUFDekIsSUFBSSxDQUFDLFVBQVUsR0FBRyxLQUFLLENBQUM7SUFDMUIsQ0FBQzs7NkhBbkJVLGdDQUFnQztpSEFBaEMsZ0NBQWdDLGlRQ1A3Qyw2c0JBU0E7MkZERmEsZ0NBQWdDO2tCQUw1QyxTQUFTOytCQUNFLDJCQUEyQixtQkFFcEIsdUJBQXVCLENBQUMsTUFBTTswRUFJL0IsZUFBZTtzQkFBOUIsS0FBSztnQkFDVSxnQkFBZ0I7c0JBQS9CLEtBQUs7Z0JBQ1UsS0FBSztzQkFBcEIsS0FBSztnQkFDVSxVQUFVO3NCQUF6QixLQUFLO2dCQUNVLGdCQUFnQjtzQkFBL0IsS0FBSztnQkFDVSxVQUFVO3NCQUF6QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnb25zaG9yZS1pbWFnZS1wbGFjZWhvbGRlcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9pbWFnZS1wbGFjZWhvbGRlci5jb21wb25lbnQuaHRtbCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBPbnNob3JlSW1hZ2VQbGFjZWhvbGRlckNvbXBvbmVudCB7XG5cbiAgQElucHV0KCkgcHVibGljIHBsYWNlaG9sZGVySWNvbjogc3RyaW5nID0gJyc7XG4gIEBJbnB1dCgpIHB1YmxpYyBwbGFjZWhvbGRlckltYWdlOiBzdHJpbmcgPSAnJztcbiAgQElucHV0KCkgcHVibGljIGltYWdlOiBzdHJpbmcgPSAnJztcbiAgQElucHV0KCkgcHVibGljIGltYWdlU3R5bGU6IHN0cmluZyA9ICcnO1xuICBASW5wdXQoKSBwdWJsaWMgcGxhY2Vob2xkZXJTdHlsZTogc3RyaW5nID0gJyc7XG4gIEBJbnB1dCgpIHB1YmxpYyBzaG93TG9hZGVyOiBib29sZWFuID0gdHJ1ZTtcblxuICBpbWFnZUxvYWRlZCA9IGZhbHNlO1xuXG4gIGxvYWRSZWFkeSgpIHtcbiAgICB0aGlzLmltYWdlTG9hZGVkID0gdHJ1ZTtcbiAgICB0aGlzLnNob3dMb2FkZXIgPSBmYWxzZTtcbiAgfVxuXG4gIGFib3J0KCkge1xuICAgIHRoaXMuaW1hZ2VMb2FkZWQgPSBmYWxzZTtcbiAgICB0aGlzLnNob3dMb2FkZXIgPSBmYWxzZTtcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKCkge31cblxufVxuIiwiPGRpdiBjbGFzcz1cImgtZnVsbFwiIFtoaWRkZW5dPVwiIWltYWdlTG9hZGVkIHx8ICFpbWFnZVwiPlxuICA8aW1nIFtzdHlsZV09XCJpbWFnZVN0eWxlXCIgW3NyY109XCJpbWFnZVwiIChsb2FkKT1cImxvYWRSZWFkeSgpXCIgKGFib3J0KT1cImFib3J0KClcIiAvPlxuPC9kaXY+XG5cbjxkaXYgKm5nSWY9XCIhaW1hZ2VMb2FkZWQgfHwgIWltYWdlXCIgY2xhc3M9XCJmbGV4IGp1c3RpZnktY29udGVudC1jZW50ZXIgYWxpZ24taXRlbXMtY2VudGVyXCIgW3N0eWxlXT1cInBsYWNlaG9sZGVyU3R5bGVcIiBbY2xhc3MuYmctZ3JheS0yMDBdPVwicGxhY2Vob2xkZXJJY29uXCIgW2NsYXNzLnAtMl09XCJwbGFjZWhvbGRlckljb25cIj5cbiAgPGkgKm5nSWY9XCJwbGFjZWhvbGRlckljb25cIiBbY2xhc3NdPVwiJ3RleHQtbXV0ZWQgZmEgJyArIHBsYWNlaG9sZGVySWNvblwiIFtjbGFzcy5vcGFjaXR5LTIwXT1cInNob3dMb2FkZXIgJiYgaW1hZ2VcIj48L2k+XG4gIDxpbWcgKm5nSWY9XCJwbGFjZWhvbGRlckltYWdlXCIgW3NyY109XCJwbGFjZWhvbGRlckltYWdlXCIgW2NsYXNzLm9wYWNpdHktMjBdPVwic2hvd0xvYWRlciAmJiBpbWFnZVwiIGNsYXNzPVwiaC1mdWxsXCIgLz5cbiAgPGkgKm5nSWY9XCJzaG93TG9hZGVyICYmIGltYWdlXCIgY2xhc3M9XCJmYXMgZmEtY2lyY2xlLW5vdGNoIGZhLXNwaW4gZmEtMnggYWJzb2x1dGVcIj48L2k+XG48L2Rpdj5cbiJdfQ==
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UtcGxhY2Vob2xkZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvb25zaG9yZS1mb3Jtcy9zcmMvbGliL2NvbXBvbmVudHMvaW1hZ2UtcGxhY2Vob2xkZXIvaW1hZ2UtcGxhY2Vob2xkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvb25zaG9yZS1mb3Jtcy9zcmMvbGliL2NvbXBvbmVudHMvaW1hZ2UtcGxhY2Vob2xkZXIvaW1hZ2UtcGxhY2Vob2xkZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQU8xRSxNQUFNLE9BQU8sZ0NBQWdDO0lBcUIzQztRQW5CZ0Isb0JBQWUsR0FBVyxFQUFFLENBQUM7UUFDN0IscUJBQWdCLEdBQVcsRUFBRSxDQUFDO1FBQzlCLFVBQUssR0FBVyxFQUFFLENBQUM7UUFDbkIsZUFBVSxHQUFXLEVBQUUsQ0FBQztRQUN4QixxQkFBZ0IsR0FBVyxFQUFFLENBQUM7UUFDOUIsZUFBVSxHQUFZLElBQUksQ0FBQztRQUUzQyxnQkFBVyxHQUFHLEtBQUssQ0FBQztJQVlMLENBQUM7SUFWaEIsU0FBUztRQUNQLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDO0lBQzFCLENBQUM7SUFFRCxLQUFLO1FBQ0gsSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLENBQUM7UUFDekIsSUFBSSxDQUFDLFVBQVUsR0FBRyxLQUFLLENBQUM7SUFDMUIsQ0FBQzs7NkhBbkJVLGdDQUFnQztpSEFBaEMsZ0NBQWdDLGlRQ1A3Qyw0ckJBU0E7MkZERmEsZ0NBQWdDO2tCQUw1QyxTQUFTOytCQUNFLDJCQUEyQixtQkFFcEIsdUJBQXVCLENBQUMsTUFBTTswRUFJL0IsZUFBZTtzQkFBOUIsS0FBSztnQkFDVSxnQkFBZ0I7c0JBQS9CLEtBQUs7Z0JBQ1UsS0FBSztzQkFBcEIsS0FBSztnQkFDVSxVQUFVO3NCQUF6QixLQUFLO2dCQUNVLGdCQUFnQjtzQkFBL0IsS0FBSztnQkFDVSxVQUFVO3NCQUF6QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnb25zaG9yZS1pbWFnZS1wbGFjZWhvbGRlcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9pbWFnZS1wbGFjZWhvbGRlci5jb21wb25lbnQuaHRtbCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBPbnNob3JlSW1hZ2VQbGFjZWhvbGRlckNvbXBvbmVudCB7XG5cbiAgQElucHV0KCkgcHVibGljIHBsYWNlaG9sZGVySWNvbjogc3RyaW5nID0gJyc7XG4gIEBJbnB1dCgpIHB1YmxpYyBwbGFjZWhvbGRlckltYWdlOiBzdHJpbmcgPSAnJztcbiAgQElucHV0KCkgcHVibGljIGltYWdlOiBzdHJpbmcgPSAnJztcbiAgQElucHV0KCkgcHVibGljIGltYWdlU3R5bGU6IHN0cmluZyA9ICcnO1xuICBASW5wdXQoKSBwdWJsaWMgcGxhY2Vob2xkZXJTdHlsZTogc3RyaW5nID0gJyc7XG4gIEBJbnB1dCgpIHB1YmxpYyBzaG93TG9hZGVyOiBib29sZWFuID0gdHJ1ZTtcblxuICBpbWFnZUxvYWRlZCA9IGZhbHNlO1xuXG4gIGxvYWRSZWFkeSgpIHtcbiAgICB0aGlzLmltYWdlTG9hZGVkID0gdHJ1ZTtcbiAgICB0aGlzLnNob3dMb2FkZXIgPSBmYWxzZTtcbiAgfVxuXG4gIGFib3J0KCkge1xuICAgIHRoaXMuaW1hZ2VMb2FkZWQgPSBmYWxzZTtcbiAgICB0aGlzLnNob3dMb2FkZXIgPSBmYWxzZTtcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKCkge31cblxufVxuIiwiPGRpdiBbaGlkZGVuXT1cIiFpbWFnZUxvYWRlZCB8fCAhaW1hZ2VcIj5cbiAgPGltZyBbc3R5bGVdPVwiaW1hZ2VTdHlsZVwiIFtzcmNdPVwiaW1hZ2VcIiAobG9hZCk9XCJsb2FkUmVhZHkoKVwiIChhYm9ydCk9XCJhYm9ydCgpXCIgLz5cbjwvZGl2PlxuXG48ZGl2ICpuZ0lmPVwiIWltYWdlTG9hZGVkIHx8ICFpbWFnZVwiIGNsYXNzPVwiZmxleCBqdXN0aWZ5LWNvbnRlbnQtY2VudGVyIGFsaWduLWl0ZW1zLWNlbnRlclwiIFtzdHlsZV09XCJwbGFjZWhvbGRlclN0eWxlXCIgW2NsYXNzLmJnLWdyYXktMjAwXT1cInBsYWNlaG9sZGVySWNvblwiIFtjbGFzcy5wLTJdPVwicGxhY2Vob2xkZXJJY29uXCI+XG4gIDxpICpuZ0lmPVwicGxhY2Vob2xkZXJJY29uXCIgW2NsYXNzXT1cIid0ZXh0LW11dGVkIGZhICcgKyBwbGFjZWhvbGRlckljb25cIiBbY2xhc3Mub3BhY2l0eS0yMF09XCJzaG93TG9hZGVyICYmIGltYWdlXCI+PC9pPlxuICA8aW1nICpuZ0lmPVwicGxhY2Vob2xkZXJJbWFnZVwiIFtzcmNdPVwicGxhY2Vob2xkZXJJbWFnZVwiIFtjbGFzcy5vcGFjaXR5LTIwXT1cInNob3dMb2FkZXIgJiYgaW1hZ2VcIiBjbGFzcz1cImgtZnVsbFwiIC8+XG4gIDxpICpuZ0lmPVwic2hvd0xvYWRlciAmJiBpbWFnZVwiIGNsYXNzPVwiZmFzIGZhLWNpcmNsZS1ub3RjaCBmYS1zcGluIGZhLTJ4IGFic29sdXRlXCI+PC9pPlxuPC9kaXY+XG4iXX0=