@wertzui/ngx-restworld-client 4.2.1 → 4.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -3,7 +3,6 @@ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
3
  import { ImageCropperComponent } from 'ngx-image-cropper';
4
4
  import { FileUpload } from 'primeng/fileupload';
5
5
  import { Dialog } from 'primeng/dialog';
6
- import { firstValueFrom } from 'rxjs';
7
6
  import * as i0 from "@angular/core";
8
7
  import * as i1 from "primeng/button";
9
8
  import * as i2 from "primeng/fileupload";
@@ -39,14 +38,14 @@ export class RESTWorldImageViewComponent {
39
38
  if (!this.backgroundColor)
40
39
  this.backgroundColor = '#ffffff';
41
40
  }
41
+ ngOnDestroy() {
42
+ this._subscriptions?.forEach(s => s.unsubscribe());
43
+ }
42
44
  ngAfterViewInit() {
43
- // We need to trigger onResize one time, after the opening animation of the dialog has been completed.
44
- // Otherwise the image cropper thinks that the image size is 0x0,
45
+ // We need to trigger imageLoadedInView each time, after the opening animation of the dialog has been completed.
46
+ // Otherwise the image cropper initially (and after every window resize) thinks that the image size is 0x0,
45
47
  // because the opening animation hast just begun when the image cropper is first shown.
46
- this.dialogs?.forEach(async (d) => {
47
- await firstValueFrom(d.onShow);
48
- this.imageCroppers?.forEach(i => i.onResize());
49
- });
48
+ this.dialogs?.map(d => d.onShow.subscribe(() => this.imageCroppers?.forEach(i => { i.imageLoadedInView(); })));
50
49
  }
51
50
  showCropDialog() {
52
51
  this.displayCropDialog = true;
@@ -137,4 +136,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImpor
137
136
  type: ViewChildren,
138
137
  args: [Dialog]
139
138
  }] } });
140
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restworld-image-view.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-restworld-client/src/lib/views/restworld-image-view/restworld-image-view.component.ts","../../../../../../projects/ngx-restworld-client/src/lib/views/restworld-image-view/restworld-image-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, forwardRef, Input, OnInit, QueryList, ViewChildren } from '@angular/core';\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 { async, firstValueFrom } from 'rxjs';\r\n\n@Component({\n  selector: 'rw-image',\n  templateUrl: './restworld-image-view.component.html',\n  styleUrls: ['./restworld-image-view.component.css'],\n  providers: [{\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => RESTWorldImageViewComponent),\r\n    multi: true\r\n  }]\n})\nexport class RESTWorldImageViewComponent implements ControlValueAccessor, OnInit, AfterViewInit {\n\r\n  private onChange?: Function;\n\n  @Input()\n  public alt?: string;\n  @Input()\n  public accept?: string;\n  @Input()\n  public fileName?: string;\n  @Input()\r\n  public alignImage?: 'center' | 'left';\r\n  @Input()\r\n  public aspectRatio?: number;\r\n  @Input()\r\n  public backgroundColor?: string;\r\n  @Input()\r\n  public canvasRotation?: number;\r\n  @Input()\r\n  public containWithinAspectRatio?: boolean;\r\n  @Input()\r\n  public cropper?: CropperPosition;\r\n  @Input()\r\n  public cropperMaxHeight?: number;\r\n  @Input()\r\n  public cropperMaxWidth?: number;\r\n  @Input()\r\n  public cropperMinHeight?: number;\r\n  @Input()\r\n  public cropperMinWidth?: number;\r\n  @Input()\r\n  public cropperStaticHeight?: number;\r\n  @Input()\r\n  public cropperStaticWidth?: number;\r\n  @Input()\r\n  public format?: OutputFormat;\r\n  @Input()\r\n  public imageQuality?: number;\r\n  @Input()\r\n  public initialStepSize?: number;\r\n  @Input()\r\n  public maintainAspectRatio?: boolean;\r\n  @Input()\r\n  public onlyScaleDown?: boolean;\r\n  @Input()\r\n  public resizeToWidth?: number;\r\n  @Input()\r\n  public resizeToHeight?: number;\r\n  @Input()\r\n  public roundCropper?: boolean;\r\n\n\n\r\n  @ViewChildren(FileUpload)\r\n  fileUploads?: QueryList<FileUpload>;\n\n\r\n  @ViewChildren(ImageCropperComponent)\n  imageCroppers?: QueryList<ImageCropperComponent>;\n\n  @ViewChildren(Dialog)\n  dialogs?: QueryList<Dialog>;\n\n\n  public disabled = false;\n  public uri?: string | null;\r\n  public tempImageFile?: File;\r\n  public displayCropDialog = false;\n  public tempCroppedUri?: string | null;\n\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 onResize one time, after the opening animation of the dialog has been completed.\r\n    // Otherwise the image cropper 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?.forEach(async d => {\r\n      await firstValueFrom(d.onShow);\r\n      this.imageCroppers?.forEach(i => i.onResize());\r\n    });\r\n  }\r\n\r\n  public showCropDialog(): void {\r\n    this.displayCropDialog = true;\r\n  }\r\n\n  public imageChanged(event: { files: File[] }): void {\r\n    this.tempImageFile = event.files[0];\r\n    this.showCropDialog();\r\n  }\n\n  public croppedImageChanged(event: ImageCroppedEvent): void {\r\n    this.tempCroppedUri = event.base64;\r\n  }\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  }\n}\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"]}
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restworld-image-view.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-restworld-client/src/lib/views/restworld-image-view/restworld-image-view.component.ts","../../../../../../projects/ngx-restworld-client/src/lib/views/restworld-image-view/restworld-image-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, forwardRef, Input, OnDestroy, OnInit, QueryList, ViewChildren } from '@angular/core';\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 { async, firstValueFrom, Subscription } from 'rxjs';\r\n\n@Component({\n  selector: 'rw-image',\n  templateUrl: './restworld-image-view.component.html',\n  styleUrls: ['./restworld-image-view.component.css'],\n  providers: [{\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => RESTWorldImageViewComponent),\r\n    multi: true\r\n  }]\n})\nexport class RESTWorldImageViewComponent implements ControlValueAccessor, OnInit, OnDestroy, AfterViewInit {\n\r\n  private onChange?: Function;\n  private _subscriptions?: Subscription[];\n\n  @Input()\n  public alt?: string;\n  @Input()\n  public accept?: string;\n  @Input()\n  public fileName?: string;\n  @Input()\r\n  public alignImage?: 'center' | 'left';\r\n  @Input()\r\n  public aspectRatio?: number;\r\n  @Input()\r\n  public backgroundColor?: string;\r\n  @Input()\r\n  public canvasRotation?: number;\r\n  @Input()\r\n  public containWithinAspectRatio?: boolean;\r\n  @Input()\r\n  public cropper?: CropperPosition;\r\n  @Input()\r\n  public cropperMaxHeight?: number;\r\n  @Input()\r\n  public cropperMaxWidth?: number;\r\n  @Input()\r\n  public cropperMinHeight?: number;\r\n  @Input()\r\n  public cropperMinWidth?: number;\r\n  @Input()\r\n  public cropperStaticHeight?: number;\r\n  @Input()\r\n  public cropperStaticWidth?: number;\r\n  @Input()\r\n  public format?: OutputFormat;\r\n  @Input()\r\n  public imageQuality?: number;\r\n  @Input()\r\n  public initialStepSize?: number;\r\n  @Input()\r\n  public maintainAspectRatio?: boolean;\r\n  @Input()\r\n  public onlyScaleDown?: boolean;\r\n  @Input()\r\n  public resizeToWidth?: number;\r\n  @Input()\r\n  public resizeToHeight?: number;\r\n  @Input()\r\n  public roundCropper?: boolean;\r\n\n\n\r\n  @ViewChildren(FileUpload)\r\n  fileUploads?: QueryList<FileUpload>;\n\n\r\n  @ViewChildren(ImageCropperComponent)\n  imageCroppers?: QueryList<ImageCropperComponent>;\n\n  @ViewChildren(Dialog)\n  dialogs?: QueryList<Dialog>;\n\n  public disabled = false;\n  public uri?: string | null;\r\n  public tempImageFile?: File;\r\n  public displayCropDialog = false;\n  public tempCroppedUri?: string | null;\n\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  ngOnDestroy(): void {\r\n    this._subscriptions?.forEach(s => s.unsubscribe());\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\n  public imageChanged(event: { files: File[] }): void {\r\n    this.tempImageFile = event.files[0];\r\n    this.showCropDialog();\r\n  }\n\n  public croppedImageChanged(event: ImageCroppedEvent): void {\r\n    this.tempCroppedUri = event.base64;\r\n  }\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  }\n}\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"]}
@@ -28,7 +28,6 @@ import * as i2 from 'primeng/fileupload';
28
28
  import { FileUpload, FileUploadModule } from 'primeng/fileupload';
29
29
  import * as i3 from 'primeng/dialog';
30
30
  import { Dialog, DialogModule } from 'primeng/dialog';
31
- import { firstValueFrom } from 'rxjs';
32
31
  import * as i1$2 from 'primeng/button';
33
32
  import { ButtonModule } from 'primeng/button';
34
33
  import * as i5 from 'primeng/colorpicker';
@@ -665,16 +664,16 @@ class RESTWorldImageViewComponent {
665
664
  if (!this.backgroundColor)
666
665
  this.backgroundColor = '#ffffff';
667
666
  }
667
+ ngOnDestroy() {
668
+ var _a;
669
+ (_a = this._subscriptions) === null || _a === void 0 ? void 0 : _a.forEach(s => s.unsubscribe());
670
+ }
668
671
  ngAfterViewInit() {
669
672
  var _a;
670
- // We need to trigger onResize one time, after the opening animation of the dialog has been completed.
671
- // Otherwise the image cropper thinks that the image size is 0x0,
673
+ // We need to trigger imageLoadedInView each time, after the opening animation of the dialog has been completed.
674
+ // Otherwise the image cropper initially (and after every window resize) thinks that the image size is 0x0,
672
675
  // because the opening animation hast just begun when the image cropper is first shown.
673
- (_a = this.dialogs) === null || _a === void 0 ? void 0 : _a.forEach((d) => __awaiter(this, void 0, void 0, function* () {
674
- var _b;
675
- yield firstValueFrom(d.onShow);
676
- (_b = this.imageCroppers) === null || _b === void 0 ? void 0 : _b.forEach(i => i.onResize());
677
- }));
676
+ (_a = this.dialogs) === null || _a === void 0 ? void 0 : _a.map(d => d.onShow.subscribe(() => { var _a; return (_a = this.imageCroppers) === null || _a === void 0 ? void 0 : _a.forEach(i => { i.imageLoadedInView(); }); }));
678
677
  }
679
678
  showCropDialog() {
680
679
  this.displayCropDialog = true;