@wertzui/ngx-restworld-client 7.2.0 → 8.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/components/restworld-file/restworld-file.component.mjs +57 -0
- package/esm2020/lib/components/restworld-form/restworld-form.component.mjs +188 -0
- package/esm2020/lib/components/restworld-id-navigation/restworld-id-navigation.component.mjs +65 -0
- package/esm2020/lib/components/restworld-image/restworld-image.component.mjs +164 -0
- package/esm2020/lib/components/restworld-inputs/restworld-inputs.mjs +306 -0
- package/esm2020/lib/components/restworld-label/restworld-label.component.mjs +24 -0
- package/esm2020/lib/components/restworld-menu-button/restworld-menu-button.component.mjs +40 -0
- package/esm2020/lib/components/restworld-table/restworld-table.component.mjs +157 -0
- package/esm2020/lib/components/restworld-validation-errors/restworld-validation-errors.component.mjs +21 -0
- package/esm2020/lib/models/o-data.mjs +2 -0
- package/esm2020/lib/models/restworld-image.mjs +2 -0
- package/esm2020/lib/models/restworld-options.mjs +2 -2
- package/esm2020/lib/models/special-properties.mjs +6 -0
- package/esm2020/lib/models/templating.mjs +2 -0
- package/esm2020/lib/restworld-client.module.mjs +83 -25
- package/esm2020/lib/services/o-data.service.mjs +6 -3
- package/esm2020/lib/services/restworld-client-collection.mjs +7 -7
- package/esm2020/lib/services/restworld-client.mjs +40 -29
- package/esm2020/lib/services/settings.service.mjs +5 -5
- package/esm2020/lib/views/restworld-edit-view/restworld-edit-view.component.mjs +24 -255
- package/esm2020/lib/views/restworld-list-view/restworld-list-view.component.mjs +49 -101
- package/esm2020/public-api.mjs +17 -6
- package/fesm2015/wertzui-ngx-restworld-client.mjs +1373 -1017
- package/fesm2015/wertzui-ngx-restworld-client.mjs.map +1 -1
- package/fesm2020/wertzui-ngx-restworld-client.mjs +1322 -978
- package/fesm2020/wertzui-ngx-restworld-client.mjs.map +1 -1
- package/index.d.ts +1 -0
- package/lib/components/restworld-avatar/restworld-avatar.component.d.ts +1 -0
- package/lib/components/restworld-avatar/restworld-avatar.component.d.ts.map +1 -0
- package/lib/{views/restworld-file-view/restworld-file-view.component.d.ts → components/restworld-file/restworld-file.component.d.ts} +4 -3
- package/lib/components/restworld-file/restworld-file.component.d.ts.map +1 -0
- package/lib/components/restworld-form/restworld-form.component.d.ts +53 -0
- package/lib/components/restworld-form/restworld-form.component.d.ts.map +1 -0
- package/lib/components/restworld-id-navigation/restworld-id-navigation.component.d.ts +27 -0
- package/lib/components/restworld-id-navigation/restworld-id-navigation.component.d.ts.map +1 -0
- package/lib/components/restworld-image/restworld-image.component.d.ts +62 -0
- package/lib/components/restworld-image/restworld-image.component.d.ts.map +1 -0
- package/lib/components/restworld-inputs/restworld-inputs.d.ts +146 -0
- package/lib/components/restworld-inputs/restworld-inputs.d.ts.map +1 -0
- package/lib/components/restworld-label/restworld-label.component.d.ts +14 -0
- package/lib/components/restworld-label/restworld-label.component.d.ts.map +1 -0
- package/lib/components/restworld-menu-button/restworld-menu-button.component.d.ts +12 -0
- package/lib/components/restworld-menu-button/restworld-menu-button.component.d.ts.map +1 -0
- package/lib/components/restworld-table/restworld-table.component.d.ts +54 -0
- package/lib/components/restworld-table/restworld-table.component.d.ts.map +1 -0
- package/lib/components/restworld-validation-errors/restworld-validation-errors.component.d.ts +15 -0
- package/lib/components/restworld-validation-errors/restworld-validation-errors.component.d.ts.map +1 -0
- package/lib/constants/link-names.d.ts +1 -0
- package/lib/constants/link-names.d.ts.map +1 -0
- package/lib/models/api-url.d.ts +1 -0
- package/lib/models/api-url.d.ts.map +1 -0
- package/lib/models/client-settings.d.ts +1 -0
- package/lib/models/client-settings.d.ts.map +1 -0
- package/lib/models/o-data.d.ts +7 -0
- package/lib/models/o-data.d.ts.map +1 -0
- package/lib/models/problem-details.d.ts +1 -0
- package/lib/models/problem-details.d.ts.map +1 -0
- package/lib/models/restworld-image.d.ts +28 -0
- package/lib/models/restworld-image.d.ts.map +1 -0
- package/lib/models/restworld-options.d.ts +2 -1
- package/lib/models/restworld-options.d.ts.map +1 -0
- package/lib/models/special-properties.d.ts +9 -0
- package/lib/models/special-properties.d.ts.map +1 -0
- package/lib/models/templating.d.ts +8 -0
- package/lib/models/templating.d.ts.map +1 -0
- package/lib/pipes/as.pipe.d.ts +1 -0
- package/lib/pipes/as.pipe.d.ts.map +1 -0
- package/lib/pipes/safe-url.pipe.d.ts +1 -0
- package/lib/pipes/safe-url.pipe.d.ts.map +1 -0
- package/lib/restworld-client.module.d.ts +45 -37
- package/lib/restworld-client.module.d.ts.map +1 -0
- package/lib/services/avatar-generator.d.ts +1 -0
- package/lib/services/avatar-generator.d.ts.map +1 -0
- package/lib/services/form.service.d.ts +1 -0
- package/lib/services/form.service.d.ts.map +1 -0
- package/lib/services/o-data.service.d.ts +1 -0
- package/lib/services/o-data.service.d.ts.map +1 -0
- package/lib/services/restworld-client-collection.d.ts +9 -8
- package/lib/services/restworld-client-collection.d.ts.map +1 -0
- package/lib/services/restworld-client.d.ts +12 -4
- package/lib/services/restworld-client.d.ts.map +1 -0
- package/lib/services/settings.service.d.ts +3 -2
- package/lib/services/settings.service.d.ts.map +1 -0
- package/lib/views/restworld-edit-view/restworld-edit-view.component.d.ts +16 -68
- package/lib/views/restworld-edit-view/restworld-edit-view.component.d.ts.map +1 -0
- package/lib/views/restworld-list-view/restworld-list-view.component.d.ts +25 -41
- package/lib/views/restworld-list-view/restworld-list-view.component.d.ts.map +1 -0
- package/package.json +6 -6
- package/public-api.d.ts +17 -5
- package/public-api.d.ts.map +1 -0
- package/wertzui-ngx-restworld-client.d.ts.map +1 -0
- package/esm2020/lib/views/restworld-edit-form/restworld-edit-form.component.mjs +0 -233
- package/esm2020/lib/views/restworld-file-view/restworld-file-view.component.mjs +0 -57
- package/esm2020/lib/views/restworld-image-view/restworld-image-view.component.mjs +0 -139
- package/lib/views/restworld-edit-form/restworld-edit-form.component.d.ts +0 -74
- package/lib/views/restworld-image-view/restworld-image-view.component.d.ts +0 -57
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
import { Component, forwardRef, Input, ViewChildren } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { ImageCropperComponent } from 'ngx-image-cropper';
|
|
4
|
+
import { FileUpload } from 'primeng/fileupload';
|
|
5
|
+
import { Dialog } from 'primeng/dialog';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/common";
|
|
8
|
+
import * as i2 from "@angular/forms";
|
|
9
|
+
import * as i3 from "primeng/tooltip";
|
|
10
|
+
import * as i4 from "primeng/inputtext";
|
|
11
|
+
import * as i5 from "primeng/button";
|
|
12
|
+
import * as i6 from "primeng/ripple";
|
|
13
|
+
import * as i7 from "primeng/fileupload";
|
|
14
|
+
import * as i8 from "ngx-image-cropper";
|
|
15
|
+
import * as i9 from "primeng/dialog";
|
|
16
|
+
import * as i10 from "primeng/colorpicker";
|
|
17
|
+
import * as i11 from "../../pipes/safe-url.pipe";
|
|
18
|
+
export class RestWorldImageComponent {
|
|
19
|
+
constructor() {
|
|
20
|
+
this.disabled = false;
|
|
21
|
+
this.displayCropDialog = false;
|
|
22
|
+
}
|
|
23
|
+
get alt() {
|
|
24
|
+
return this.property.prompt ?? this.property.name;
|
|
25
|
+
}
|
|
26
|
+
get accept() {
|
|
27
|
+
return this.property.restWorldImage.accept ?? this.property.placeholder ?? "image/*";
|
|
28
|
+
}
|
|
29
|
+
get fileName() {
|
|
30
|
+
return this.property.name + "." + (this.property.restWorldImage.format ?? ".png");
|
|
31
|
+
}
|
|
32
|
+
get alignImage() {
|
|
33
|
+
return this.property.restWorldImage.alignImage;
|
|
34
|
+
}
|
|
35
|
+
get aspectRatio() {
|
|
36
|
+
return this.property.restWorldImage.aspectRatio;
|
|
37
|
+
}
|
|
38
|
+
get backgroundColor() {
|
|
39
|
+
return this.property.restWorldImage.backgroundColor;
|
|
40
|
+
}
|
|
41
|
+
set backgroundColor(value) {
|
|
42
|
+
this.property.restWorldImage.backgroundColor = value;
|
|
43
|
+
}
|
|
44
|
+
get canvasRotation() {
|
|
45
|
+
return this.property.restWorldImage.canvasRotation;
|
|
46
|
+
}
|
|
47
|
+
get containWithinAspectRatio() {
|
|
48
|
+
return this.property.restWorldImage.containWithinAspectRatio;
|
|
49
|
+
}
|
|
50
|
+
get cropper() {
|
|
51
|
+
return this.property.restWorldImage.cropper;
|
|
52
|
+
}
|
|
53
|
+
get cropperMaxHeight() {
|
|
54
|
+
return this.property.restWorldImage.cropperMaxHeight;
|
|
55
|
+
}
|
|
56
|
+
get cropperMaxWidth() {
|
|
57
|
+
return this.property.restWorldImage.cropperMaxWidth;
|
|
58
|
+
}
|
|
59
|
+
get cropperMinHeight() {
|
|
60
|
+
return this.property.restWorldImage.cropperMinHeight;
|
|
61
|
+
}
|
|
62
|
+
get cropperMinWidth() {
|
|
63
|
+
return this.property.restWorldImage.cropperMinWidth;
|
|
64
|
+
}
|
|
65
|
+
get cropperStaticHeight() {
|
|
66
|
+
return this.property.restWorldImage.cropperStaticHeight;
|
|
67
|
+
}
|
|
68
|
+
get cropperStaticWidth() {
|
|
69
|
+
return this.property.restWorldImage.cropperStaticWidth;
|
|
70
|
+
}
|
|
71
|
+
get format() {
|
|
72
|
+
return this.property.restWorldImage.format;
|
|
73
|
+
}
|
|
74
|
+
get imageQuality() {
|
|
75
|
+
return this.property.restWorldImage.imageQuality;
|
|
76
|
+
}
|
|
77
|
+
get initialStepSize() {
|
|
78
|
+
return this.property.restWorldImage.initialStepSize;
|
|
79
|
+
}
|
|
80
|
+
get maintainAspectRatio() {
|
|
81
|
+
return this.property.restWorldImage.maintainAspectRatio;
|
|
82
|
+
}
|
|
83
|
+
get onlyScaleDown() {
|
|
84
|
+
return this.property.restWorldImage.onlyScaleDown;
|
|
85
|
+
}
|
|
86
|
+
get resizeToWidth() {
|
|
87
|
+
return this.property.restWorldImage.resizeToWidth;
|
|
88
|
+
}
|
|
89
|
+
get resizeToHeight() {
|
|
90
|
+
return this.property.restWorldImage.resizeToHeight;
|
|
91
|
+
}
|
|
92
|
+
get roundCropper() {
|
|
93
|
+
return this.property.restWorldImage.roundCropper;
|
|
94
|
+
}
|
|
95
|
+
writeValue(obj) {
|
|
96
|
+
this.uri = obj;
|
|
97
|
+
}
|
|
98
|
+
registerOnChange(fn) {
|
|
99
|
+
this.onChange = fn;
|
|
100
|
+
}
|
|
101
|
+
registerOnTouched() {
|
|
102
|
+
// not needed for this component, but needed to implement the interface
|
|
103
|
+
}
|
|
104
|
+
setDisabledState(isDisabled) {
|
|
105
|
+
this.disabled = isDisabled;
|
|
106
|
+
}
|
|
107
|
+
ngOnInit() {
|
|
108
|
+
// If no background color is set, we set it to white.
|
|
109
|
+
// Otherwise the color picker would show red, the input would be empty and the image cropper would show transparent.
|
|
110
|
+
if (!this.backgroundColor)
|
|
111
|
+
this.backgroundColor = '#ffffff';
|
|
112
|
+
}
|
|
113
|
+
ngAfterViewInit() {
|
|
114
|
+
// We need to trigger imageLoadedInView each time, after the opening animation of the dialog has been completed.
|
|
115
|
+
// Otherwise the image cropper initially (and after every window resize) thinks that the image size is 0x0,
|
|
116
|
+
// because the opening animation hast just begun when the image cropper is first shown.
|
|
117
|
+
this.dialogs?.map(d => d.onShow.subscribe(() => this.imageCroppers?.forEach(i => { i.imageLoadedInView(); })));
|
|
118
|
+
}
|
|
119
|
+
showCropDialog() {
|
|
120
|
+
this.displayCropDialog = true;
|
|
121
|
+
}
|
|
122
|
+
imageChanged(event) {
|
|
123
|
+
this.tempImageFile = event.files[0];
|
|
124
|
+
this.showCropDialog();
|
|
125
|
+
}
|
|
126
|
+
croppedImageChanged(event) {
|
|
127
|
+
this.tempCroppedUri = event.base64;
|
|
128
|
+
}
|
|
129
|
+
acceptCroppedImage() {
|
|
130
|
+
this.uri = this.tempCroppedUri;
|
|
131
|
+
this.onChange?.(this.uri);
|
|
132
|
+
this.closeCropDialog();
|
|
133
|
+
}
|
|
134
|
+
closeCropDialog() {
|
|
135
|
+
this.fileUploads?.forEach(f => f.clear());
|
|
136
|
+
this.displayCropDialog = false;
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
RestWorldImageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldImageComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
140
|
+
RestWorldImageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: RestWorldImageComponent, selector: "rw-image", inputs: { property: "property" }, providers: [{
|
|
141
|
+
provide: NG_VALUE_ACCESSOR,
|
|
142
|
+
useExisting: forwardRef(() => RestWorldImageComponent),
|
|
143
|
+
multi: true
|
|
144
|
+
}], viewQueries: [{ propertyName: "fileUploads", predicate: FileUpload, descendants: true }, { propertyName: "imageCroppers", predicate: ImageCropperComponent, descendants: true }, { propertyName: "dialogs", predicate: Dialog, descendants: true }], ngImport: i0, template: "<div class=\"flex align-items-center\">\r\n <p-button *ngIf=\"!uri\" [disabled]=\"true\" icon=\"pi pi-download\" class=\"mr-1\" pTooltip=\"No image present\"></p-button>\r\n <a *ngIf=\"uri\" [href]=\"uri | safeUrl\" [download]=\"fileName || 'download'\" class=\"mr-1\" pButton pTooltip=\"Download image\" icon=\"pi pi-download\"></a>\r\n <p-fileUpload class=\"mr-1\" chooseIcon=\"pi-upload fas fa-upload\" mode=\"basic\" [auto]=\"true\" [accept]=\"accept || 'image/*'\" [customUpload]=\"true\" (uploadHandler)=\"imageChanged($event)\" pTooltip=\"Upload new image\"></p-fileUpload>\r\n <img *ngIf=\"uri\" class=\"thumbnail\" [src]=\"uri | safeUrl\" [alt]=\"alt\" (click)=\"showCropDialog()\" pTooltip=\"Zoom and crop\" />\r\n</div>\r\n\r\n<p-dialog [header]=\"alt ?? ''\" [(visible)]=\"displayCropDialog\">\r\n <image-cropper\r\n [autoCrop]=\"true\"\r\n (imageCropped)=\"croppedImageChanged($event)\"\r\n [alignImage]=\"alignImage ?? 'center'\"\r\n [aspectRatio]=\"aspectRatio ?? 1\"\r\n [backgroundColor]=\"backgroundColor ?? null\"\r\n [canvasRotation]=\"canvasRotation ?? 0\"\r\n [containWithinAspectRatio]=\"containWithinAspectRatio ?? false\"\r\n [cropper]=\"cropper ?? { x1: -100, y1: -100, x2: 10000, y2: 10000 }\"\r\n [cropperMaxHeight]=\"cropperMaxHeight ?? 0\"\r\n [cropperMaxWidth]=\"cropperMaxWidth ?? 0\"\r\n [cropperMinHeight]=\"cropperMinHeight ?? 0\"\r\n [cropperMinWidth]=\"cropperMinWidth ?? 0\"\r\n [cropperStaticHeight]=\"cropperStaticHeight ?? 0\"\r\n [cropperStaticWidth]=\"cropperStaticWidth ?? 0\"\r\n [format]=\"format ?? 'png'\"\r\n [imageQuality]=\"imageQuality ?? 92\"\r\n [initialStepSize]=\"initialStepSize ?? 3\"\r\n [maintainAspectRatio]=\"maintainAspectRatio ?? true\"\r\n [onlyScaleDown]=\"onlyScaleDown ?? false\"\r\n [resizeToWidth]=\"resizeToWidth ?? 0\"\r\n [resizeToHeight]=\"resizeToHeight ?? 0\"\r\n [roundCropper]=\"roundCropper ?? false\"\r\n [imageFile]=\"tempImageFile!\"\r\n [imageURL]=\"uri!\"\r\n ></image-cropper>\r\n <div class=\"flex justify-content-end\">\r\n <div class=\"flex-auto align-items-center\">\r\n <span>Background color: </span>\r\n <p-colorPicker [(ngModel)]=\"backgroundColor\" appendTo=\"body\" class=\"ml-1 mr-1\"></p-colorPicker>\r\n <input pInputText [(ngModel)]=\"backgroundColor\" />\r\n </div>\r\n <button type=\"button\" pButton pRipple (click)=\"acceptCroppedImage()\" class=\"mr-2\">Ok</button>\r\n <button type=\"button\" pButton pRipple (click)=\"closeCropDialog()\">Cancel</button>\r\n </div>\r\n</p-dialog>\r\n", styles: ["img.thumbnail{height:calc(1rem + 18px);cursor:zoom-in;border-radius:3px}a{text-decoration:none}a.p-button-icon-only span.p-button-label{height:1rem!important}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "fitContent", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i4.InputText, selector: "[pInputText]" }, { kind: "directive", type: i5.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "component", type: i5.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "style", "styleClass", "badgeClass", "ariaLabel"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "directive", type: i6.Ripple, selector: "[pRipple]" }, { kind: "component", type: i7.FileUpload, selector: "p-fileUpload", inputs: ["name", "url", "method", "multiple", "accept", "disabled", "auto", "withCredentials", "maxFileSize", "invalidFileSizeMessageSummary", "invalidFileSizeMessageDetail", "invalidFileTypeMessageSummary", "invalidFileTypeMessageDetail", "invalidFileLimitMessageDetail", "invalidFileLimitMessageSummary", "style", "styleClass", "previewWidth", "chooseLabel", "uploadLabel", "cancelLabel", "chooseIcon", "uploadIcon", "cancelIcon", "showUploadButton", "showCancelButton", "mode", "headers", "customUpload", "fileLimit", "uploadStyleClass", "cancelStyleClass", "removeStyleClass", "chooseStyleClass", "files"], outputs: ["onBeforeUpload", "onSend", "onUpload", "onError", "onClear", "onRemove", "onSelect", "onProgress", "uploadHandler", "onImageError"] }, { kind: "component", type: i8.ImageCropperComponent, selector: "image-cropper", inputs: ["imageChangedEvent", "imageURL", "imageBase64", "imageFile", "imageAltText", "format", "transform", "maintainAspectRatio", "aspectRatio", "resetCropOnAspectRatioChange", "resizeToWidth", "resizeToHeight", "cropperMinWidth", "cropperMinHeight", "cropperMaxHeight", "cropperMaxWidth", "cropperStaticWidth", "cropperStaticHeight", "canvasRotation", "initialStepSize", "roundCropper", "onlyScaleDown", "imageQuality", "autoCrop", "backgroundColor", "containWithinAspectRatio", "hideResizeSquares", "allowMoveImage", "cropper", "alignImage", "disabled", "hidden"], outputs: ["imageCropped", "startCropImage", "imageLoaded", "cropperReady", "loadImageFailed", "transformChange"] }, { kind: "component", type: i9.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: i10.ColorPicker, selector: "p-colorPicker", inputs: ["style", "styleClass", "inline", "format", "appendTo", "disabled", "tabindex", "inputId", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onChange", "onShow", "onHide"] }, { kind: "pipe", type: i11.SafeUrlPipe, name: "safeUrl" }] });
|
|
145
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldImageComponent, decorators: [{
|
|
146
|
+
type: Component,
|
|
147
|
+
args: [{ selector: 'rw-image', providers: [{
|
|
148
|
+
provide: NG_VALUE_ACCESSOR,
|
|
149
|
+
useExisting: forwardRef(() => RestWorldImageComponent),
|
|
150
|
+
multi: true
|
|
151
|
+
}], template: "<div class=\"flex align-items-center\">\r\n <p-button *ngIf=\"!uri\" [disabled]=\"true\" icon=\"pi pi-download\" class=\"mr-1\" pTooltip=\"No image present\"></p-button>\r\n <a *ngIf=\"uri\" [href]=\"uri | safeUrl\" [download]=\"fileName || 'download'\" class=\"mr-1\" pButton pTooltip=\"Download image\" icon=\"pi pi-download\"></a>\r\n <p-fileUpload class=\"mr-1\" chooseIcon=\"pi-upload fas fa-upload\" mode=\"basic\" [auto]=\"true\" [accept]=\"accept || 'image/*'\" [customUpload]=\"true\" (uploadHandler)=\"imageChanged($event)\" pTooltip=\"Upload new image\"></p-fileUpload>\r\n <img *ngIf=\"uri\" class=\"thumbnail\" [src]=\"uri | safeUrl\" [alt]=\"alt\" (click)=\"showCropDialog()\" pTooltip=\"Zoom and crop\" />\r\n</div>\r\n\r\n<p-dialog [header]=\"alt ?? ''\" [(visible)]=\"displayCropDialog\">\r\n <image-cropper\r\n [autoCrop]=\"true\"\r\n (imageCropped)=\"croppedImageChanged($event)\"\r\n [alignImage]=\"alignImage ?? 'center'\"\r\n [aspectRatio]=\"aspectRatio ?? 1\"\r\n [backgroundColor]=\"backgroundColor ?? null\"\r\n [canvasRotation]=\"canvasRotation ?? 0\"\r\n [containWithinAspectRatio]=\"containWithinAspectRatio ?? false\"\r\n [cropper]=\"cropper ?? { x1: -100, y1: -100, x2: 10000, y2: 10000 }\"\r\n [cropperMaxHeight]=\"cropperMaxHeight ?? 0\"\r\n [cropperMaxWidth]=\"cropperMaxWidth ?? 0\"\r\n [cropperMinHeight]=\"cropperMinHeight ?? 0\"\r\n [cropperMinWidth]=\"cropperMinWidth ?? 0\"\r\n [cropperStaticHeight]=\"cropperStaticHeight ?? 0\"\r\n [cropperStaticWidth]=\"cropperStaticWidth ?? 0\"\r\n [format]=\"format ?? 'png'\"\r\n [imageQuality]=\"imageQuality ?? 92\"\r\n [initialStepSize]=\"initialStepSize ?? 3\"\r\n [maintainAspectRatio]=\"maintainAspectRatio ?? true\"\r\n [onlyScaleDown]=\"onlyScaleDown ?? false\"\r\n [resizeToWidth]=\"resizeToWidth ?? 0\"\r\n [resizeToHeight]=\"resizeToHeight ?? 0\"\r\n [roundCropper]=\"roundCropper ?? false\"\r\n [imageFile]=\"tempImageFile!\"\r\n [imageURL]=\"uri!\"\r\n ></image-cropper>\r\n <div class=\"flex justify-content-end\">\r\n <div class=\"flex-auto align-items-center\">\r\n <span>Background color: </span>\r\n <p-colorPicker [(ngModel)]=\"backgroundColor\" appendTo=\"body\" class=\"ml-1 mr-1\"></p-colorPicker>\r\n <input pInputText [(ngModel)]=\"backgroundColor\" />\r\n </div>\r\n <button type=\"button\" pButton pRipple (click)=\"acceptCroppedImage()\" class=\"mr-2\">Ok</button>\r\n <button type=\"button\" pButton pRipple (click)=\"closeCropDialog()\">Cancel</button>\r\n </div>\r\n</p-dialog>\r\n", styles: ["img.thumbnail{height:calc(1rem + 18px);cursor:zoom-in;border-radius:3px}a{text-decoration:none}a.p-button-icon-only span.p-button-label{height:1rem!important}\n"] }]
|
|
152
|
+
}], propDecorators: { property: [{
|
|
153
|
+
type: Input
|
|
154
|
+
}], fileUploads: [{
|
|
155
|
+
type: ViewChildren,
|
|
156
|
+
args: [FileUpload]
|
|
157
|
+
}], imageCroppers: [{
|
|
158
|
+
type: ViewChildren,
|
|
159
|
+
args: [ImageCropperComponent]
|
|
160
|
+
}], dialogs: [{
|
|
161
|
+
type: ViewChildren,
|
|
162
|
+
args: [Dialog]
|
|
163
|
+
}] } });
|
|
164
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restworld-image.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-image/restworld-image.component.ts","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-image/restworld-image.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAE,UAAU,EAAE,KAAK,EAAgC,YAAY,EAAE,MAAM,eAAe,CAAC;AACxH,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAsC,qBAAqB,EAAgB,MAAM,mBAAmB,CAAC;AAC5G,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;;;;;;;;;;;;;AAevC,MAAM,OAAO,uBAAuB;IAVpC;QA0HS,aAAQ,GAAG,KAAK,CAAC;QAGjB,sBAAiB,GAAG,KAAK,CAAC;KAwDlC;IApKC,IAAW,GAAG;QACZ,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;IACpD,CAAC;IAED,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,MAAM,IAAI,IAAI,CAAC,QAAQ,CAAC,WAAW,IAAI,SAAS,CAAC;IACvF,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,GAAG,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,MAAM,IAAI,MAAM,CAAC,CAAC;IACpF,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,UAAU,CAAC;IACjD,CAAC;IAED,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,WAAW,CAAC;IAClD,CAAC;IAED,IAAW,eAAe;QACxB,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,eAAe,CAAC;IACtD,CAAC;IACD,IAAW,eAAe,CAAC,KAAyB;QAClD,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,eAAe,GAAG,KAAK,CAAC;IACvD,CAAC;IAED,IAAW,cAAc;QACvB,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,cAAc,CAAC;IACrD,CAAC;IAED,IAAW,wBAAwB;QACjC,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,wBAAwB,CAAC;IAC/D,CAAC;IAED,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC;IAC9C,CAAC;IAED,IAAW,gBAAgB;QACzB,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,gBAAgB,CAAC;IACvD,CAAC;IAED,IAAW,eAAe;QACxB,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,eAAe,CAAC;IACtD,CAAC;IAED,IAAW,gBAAgB;QACzB,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,gBAAgB,CAAC;IACvD,CAAC;IAED,IAAW,eAAe;QACxB,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,eAAe,CAAC;IACtD,CAAC;IAED,IAAW,mBAAmB;QAC5B,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,mBAAmB,CAAC;IAC1D,CAAC;IAED,IAAW,kBAAkB;QAC3B,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,kBAAkB,CAAC;IACzD,CAAC;IAED,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,MAAM,CAAC;IAC7C,CAAC;IAED,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,YAAY,CAAC;IACnD,CAAC;IAED,IAAW,eAAe;QACxB,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,eAAe,CAAC;IACtD,CAAC;IAED,IAAW,mBAAmB;QAC5B,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,mBAAmB,CAAC;IAC1D,CAAC;IAED,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,aAAa,CAAC;IACpD,CAAC;IAED,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,aAAa,CAAC;IACpD,CAAC;IAED,IAAW,cAAc;QACvB,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,cAAc,CAAC;IACrD,CAAC;IAED,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,YAAY,CAAC;IACnD,CAAC;IAkBD,UAAU,CAAC,GAAmB;QAC5B,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;IACjB,CAAC;IACD,gBAAgB,CAAC,EAAa;QAC5B,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IACD,iBAAiB;QACf,uEAAuE;IACzE,CAAC;IAED,gBAAgB,CAAE,UAAmB;QACnC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;IAED,QAAQ;QACN,qDAAqD;QACrD,oHAAoH;QACpH,IAAI,CAAC,IAAI,CAAC,eAAe;YACvB,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;IACrC,CAAC;IAED,eAAe;QACb,gHAAgH;QAChH,2GAA2G;QAC3G,uFAAuF;QACvF,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE,CAC7C,IAAI,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,iBAAiB,EAAE,CAAC,CAAC,CAAC,CAAC,CAC7D,CAAC,CAAC;IACL,CAAC;IAEM,cAAc;QACnB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;IAChC,CAAC;IAEM,YAAY,CAAC,KAAwB;QAC1C,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACpC,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEM,mBAAmB,CAAC,KAAwB;QACjD,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,MAAM,CAAC;IACrC,CAAC;IAEM,kBAAkB;QACvB,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC;QAC/B,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC1B,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAEM,eAAe;QACpB,IAAI,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC;QAC1C,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;IACjC,CAAC;;oHA1KU,uBAAuB;wGAAvB,uBAAuB,qEANvB,CAAC;YACV,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,uBAAuB,CAAC;YACtD,KAAK,EAAE,IAAI;SACZ,CAAC,0DAwGY,UAAU,mEAIV,qBAAqB,6DAGrB,MAAM,gDChItB,04FA4CA;2FDzBa,uBAAuB;kBAVnC,SAAS;+BACE,UAAU,aAGT,CAAC;4BACV,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,wBAAwB,CAAC;4BACtD,KAAK,EAAE,IAAI;yBACZ,CAAC;8BAOK,QAAQ;sBADd,KAAK;gBAmGN,WAAW;sBADV,YAAY;uBAAC,UAAU;gBAKxB,aAAa;sBADZ,YAAY;uBAAC,qBAAqB;gBAInC,OAAO;sBADN,YAAY;uBAAC,MAAM","sourcesContent":["import { AfterViewInit, Component, forwardRef, Input, OnDestroy, OnInit, QueryList, ViewChildren } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { CropperPosition, ImageCroppedEvent, ImageCropperComponent, OutputFormat } from 'ngx-image-cropper';\r\nimport { FileUpload } from 'primeng/fileupload';\r\nimport { Dialog } from 'primeng/dialog'\r\nimport { Subscription } from 'rxjs';\r\nimport { Property } from '@wertzui/ngx-hal-client';\r\nimport { RestWorldImage } from '../../models/restworld-image'\r\n\r\n@Component({\r\n  selector: 'rw-image',\r\n  templateUrl: './restworld-image.component.html',\r\n  styleUrls: ['./restworld-image.component.css'],\r\n  providers: [{\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => RestWorldImageComponent),\r\n    multi: true\r\n  }]\r\n})\r\nexport class RestWorldImageComponent implements ControlValueAccessor, OnInit, AfterViewInit {\r\n\r\n  private onChange?: Function;\r\n\r\n  @Input()\r\n  public property!: Property & { restWorldImage: RestWorldImage}\r\n\r\n  public get alt() {\r\n    return this.property.prompt ?? this.property.name;\r\n  }\r\n\r\n  public get accept() {\r\n    return this.property.restWorldImage.accept ?? this.property.placeholder ?? \"image/*\";\r\n  }\r\n\r\n  public get fileName() {\r\n    return this.property.name + \".\" + (this.property.restWorldImage.format ?? \".png\");\r\n  }\r\n\r\n  public get alignImage() {\r\n    return this.property.restWorldImage.alignImage;\r\n  }\r\n\r\n  public get aspectRatio() {\r\n    return this.property.restWorldImage.aspectRatio;\r\n  }\r\n\r\n  public get backgroundColor() {\r\n    return this.property.restWorldImage.backgroundColor;\r\n  }\r\n  public set backgroundColor(value: string | undefined) {\r\n    this.property.restWorldImage.backgroundColor = value;\r\n  }\r\n\r\n  public get canvasRotation() {\r\n    return this.property.restWorldImage.canvasRotation;\r\n  }\r\n\r\n  public get containWithinAspectRatio() {\r\n    return this.property.restWorldImage.containWithinAspectRatio;\r\n  }\r\n\r\n  public get cropper() {\r\n    return this.property.restWorldImage.cropper;\r\n  }\r\n\r\n  public get cropperMaxHeight() {\r\n    return this.property.restWorldImage.cropperMaxHeight;\r\n  }\r\n\r\n  public get cropperMaxWidth() {\r\n    return this.property.restWorldImage.cropperMaxWidth;\r\n  }\r\n\r\n  public get cropperMinHeight() {\r\n    return this.property.restWorldImage.cropperMinHeight;\r\n  }\r\n\r\n  public get cropperMinWidth() {\r\n    return this.property.restWorldImage.cropperMinWidth;\r\n  }\r\n\r\n  public get cropperStaticHeight() {\r\n    return this.property.restWorldImage.cropperStaticHeight;\r\n  }\r\n\r\n  public get cropperStaticWidth() {\r\n    return this.property.restWorldImage.cropperStaticWidth;\r\n  }\r\n\r\n  public get format() {\r\n    return this.property.restWorldImage.format;\r\n  }\r\n\r\n  public get imageQuality() {\r\n    return this.property.restWorldImage.imageQuality;\r\n  }\r\n\r\n  public get initialStepSize() {\r\n    return this.property.restWorldImage.initialStepSize;\r\n  }\r\n\r\n  public get maintainAspectRatio() {\r\n    return this.property.restWorldImage.maintainAspectRatio;\r\n  }\r\n\r\n  public get onlyScaleDown() {\r\n    return this.property.restWorldImage.onlyScaleDown;\r\n  }\r\n\r\n  public get resizeToWidth() {\r\n    return this.property.restWorldImage.resizeToWidth;\r\n  }\r\n\r\n  public get resizeToHeight() {\r\n    return this.property.restWorldImage.resizeToHeight;\r\n  }\r\n\r\n  public get roundCropper() {\r\n    return this.property.restWorldImage.roundCropper;\r\n  }\r\n\r\n  @ViewChildren(FileUpload)\r\n  fileUploads?: QueryList<FileUpload>;\r\n\r\n\r\n  @ViewChildren(ImageCropperComponent)\r\n  imageCroppers?: QueryList<ImageCropperComponent>;\r\n\r\n  @ViewChildren(Dialog)\r\n  dialogs?: QueryList<Dialog>;\r\n\r\n  public disabled = false;\r\n  public uri?: string | null;\r\n  public tempImageFile?: File;\r\n  public displayCropDialog = false;\r\n  public tempCroppedUri?: string | null;\r\n\r\n  writeValue(obj?: string | null): void {\r\n    this.uri = obj;\r\n  }\r\n  registerOnChange(fn?: Function): void {\r\n    this.onChange = fn;\r\n  }\r\n  registerOnTouched(): void {\r\n    // not needed for this component, but needed to implement the interface\r\n  }\r\n\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    // If no background color is set, we set it to white.\r\n    // Otherwise the color picker would show red, the input would be empty and the image cropper would show transparent.\r\n    if (!this.backgroundColor)\r\n      this.backgroundColor = '#ffffff';\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    // We need to trigger imageLoadedInView each time, after the opening animation of the dialog has been completed.\r\n    // Otherwise the image cropper initially (and after every window resize) thinks that the image size is 0x0,\r\n    // because the opening animation hast just begun when the image cropper is first shown.\r\n    this.dialogs?.map(d => d.onShow.subscribe(() =>\r\n      this.imageCroppers?.forEach(i => { i.imageLoadedInView(); })\r\n    ));\r\n  }\r\n\r\n  public showCropDialog(): void {\r\n    this.displayCropDialog = true;\r\n  }\r\n\r\n  public imageChanged(event: { files: File[] }): void {\r\n    this.tempImageFile = event.files[0];\r\n    this.showCropDialog();\r\n  }\r\n\r\n  public croppedImageChanged(event: ImageCroppedEvent): void {\r\n    this.tempCroppedUri = event.base64;\r\n  }\r\n\r\n  public acceptCroppedImage(): void {\r\n    this.uri = this.tempCroppedUri;\r\n    this.onChange?.(this.uri);\r\n    this.closeCropDialog();\r\n  }\r\n\r\n  public closeCropDialog(): void {\r\n    this.fileUploads?.forEach(f => f.clear());\r\n    this.displayCropDialog = false;\r\n  }\r\n}\r\n","<div class=\"flex align-items-center\">\r\n  <p-button *ngIf=\"!uri\" [disabled]=\"true\" icon=\"pi pi-download\" class=\"mr-1\" pTooltip=\"No image present\"></p-button>\r\n  <a *ngIf=\"uri\" [href]=\"uri | safeUrl\" [download]=\"fileName || 'download'\" class=\"mr-1\" pButton pTooltip=\"Download image\" icon=\"pi pi-download\"></a>\r\n  <p-fileUpload class=\"mr-1\" chooseIcon=\"pi-upload fas fa-upload\" mode=\"basic\" [auto]=\"true\" [accept]=\"accept || 'image/*'\" [customUpload]=\"true\" (uploadHandler)=\"imageChanged($event)\" pTooltip=\"Upload new image\"></p-fileUpload>\r\n  <img *ngIf=\"uri\" class=\"thumbnail\" [src]=\"uri | safeUrl\" [alt]=\"alt\" (click)=\"showCropDialog()\" pTooltip=\"Zoom and crop\" />\r\n</div>\r\n\r\n<p-dialog [header]=\"alt ?? ''\" [(visible)]=\"displayCropDialog\">\r\n  <image-cropper\r\n                  [autoCrop]=\"true\"\r\n                  (imageCropped)=\"croppedImageChanged($event)\"\r\n                  [alignImage]=\"alignImage ?? 'center'\"\r\n                  [aspectRatio]=\"aspectRatio ?? 1\"\r\n                  [backgroundColor]=\"backgroundColor ?? null\"\r\n                  [canvasRotation]=\"canvasRotation ?? 0\"\r\n                  [containWithinAspectRatio]=\"containWithinAspectRatio ?? false\"\r\n                  [cropper]=\"cropper ?? { x1: -100, y1: -100, x2: 10000, y2: 10000 }\"\r\n                  [cropperMaxHeight]=\"cropperMaxHeight ?? 0\"\r\n                  [cropperMaxWidth]=\"cropperMaxWidth ?? 0\"\r\n                  [cropperMinHeight]=\"cropperMinHeight ?? 0\"\r\n                  [cropperMinWidth]=\"cropperMinWidth ?? 0\"\r\n                  [cropperStaticHeight]=\"cropperStaticHeight ?? 0\"\r\n                  [cropperStaticWidth]=\"cropperStaticWidth ?? 0\"\r\n                  [format]=\"format ?? 'png'\"\r\n                  [imageQuality]=\"imageQuality ?? 92\"\r\n                  [initialStepSize]=\"initialStepSize ?? 3\"\r\n                  [maintainAspectRatio]=\"maintainAspectRatio ?? true\"\r\n                  [onlyScaleDown]=\"onlyScaleDown ?? false\"\r\n                  [resizeToWidth]=\"resizeToWidth ?? 0\"\r\n                  [resizeToHeight]=\"resizeToHeight ?? 0\"\r\n                  [roundCropper]=\"roundCropper ?? false\"\r\n                  [imageFile]=\"tempImageFile!\"\r\n                  [imageURL]=\"uri!\"\r\n                 ></image-cropper>\r\n  <div class=\"flex justify-content-end\">\r\n    <div class=\"flex-auto align-items-center\">\r\n      <span>Background color:&nbsp;</span>\r\n      <p-colorPicker [(ngModel)]=\"backgroundColor\" appendTo=\"body\" class=\"ml-1 mr-1\"></p-colorPicker>\r\n      <input pInputText [(ngModel)]=\"backgroundColor\" />\r\n    </div>\r\n    <button type=\"button\" pButton pRipple (click)=\"acceptCroppedImage()\" class=\"mr-2\">Ok</button>\r\n    <button type=\"button\" pButton pRipple (click)=\"closeCropDialog()\">Cancel</button>\r\n  </div>\r\n</p-dialog>\r\n"]}
|