@posiwise/shared-components 0.0.64 → 0.0.65

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.
@@ -22,8 +22,12 @@ export class ProfileImageCropperComponent {
22
22
  this.fileChangeEvent.emit(event.target.files[0]?.name);
23
23
  }
24
24
  imageCropped(event) {
25
- this.croppedImage = event.base64;
26
- this.cdr.detectChanges();
25
+ const reader = new FileReader();
26
+ reader.onloadend = () => {
27
+ this.croppedImage = reader.result;
28
+ this.cdr.detectChanges();
29
+ };
30
+ reader.readAsDataURL(event.blob);
27
31
  }
28
32
  imageLoaded() {
29
33
  this.showCropper = true;
@@ -83,4 +87,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
83
87
  }], aspectRatio: [{
84
88
  type: Input
85
89
  }] } });
86
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-cropper.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/image-cropper/image-cropper.component.ts","../../../../../../libs/shared-components/src/lib/image-cropper/image-cropper.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;AAQ1F,MAAM,OAAO,4BAA4B;IAuBrC,YAAoB,GAAsB;QAAtB,QAAG,GAAH,GAAG,CAAmB;QAtB1C,sBAAiB,GAAG,EAAE,CAAC;QAEvB,iBAAY,GAAG,EAAE,CAAC;QAER,wBAAmB,GAAsB,IAAI,YAAY,EAAO,CAAC;QAEjE,eAAU,GAAsB,IAAI,YAAY,EAAO,CAAC;QAEzD,eAAU,GAAG,EAAE,CAAC;QAEf,oBAAe,GAAsB,IAAI,YAAY,EAAO,CAAC;QAI9D,gBAAW,GAAG,MAAM,CAAC;QAE9B,cAAS,GAAmB,EAAE,CAAC;QAE/B,mBAAc,GAAG,CAAC,CAAC;QAEnB,gBAAW,GAAG,KAAK,CAAC;IAEyB,CAAC;IAE9C,YAAY,CAAC,KAAU;QACnB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;IAC3D,CAAC;IAED,YAAY,CAAC,KAAwB;QACjC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,MAAM,CAAC;QACjC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC7B,CAAC;IAED,WAAW;QACP,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC5B,CAAC;IAED,UAAU;QACN,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAED,WAAW;QACP,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAEO,eAAe;QACnB,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;QACtC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;QACtC,IAAI,CAAC,SAAS,GAAG;YACb,GAAG,IAAI,CAAC,SAAS;YACjB,KAAK,EAAE,QAAQ;YACf,KAAK,EAAE,QAAQ;SAClB,CAAC;IACN,CAAC;IAED,cAAc;QACV,IAAI,CAAC,SAAS,GAAG;YACb,GAAG,IAAI,CAAC,SAAS;YACjB,KAAK,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK;SAC/B,CAAC;IACN,CAAC;IAED,YAAY;QACR,IAAI,CAAC,SAAS,GAAG;YACb,GAAG,IAAI,CAAC,SAAS;YACjB,KAAK,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK;SAC/B,CAAC;IACN,CAAC;IAED,kBAAkB;QACd,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACjD,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;SACpB;IACL,CAAC;IAED,YAAY;QACR,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;8GAlFQ,4BAA4B;kGAA5B,4BAA4B,iPCRzC,+vJA+HA;;2FDvHa,4BAA4B;kBALxC,SAAS;+BACI,kBAAkB;sFASlB,mBAAmB;sBAA5B,MAAM;gBAEG,UAAU;sBAAnB,MAAM;gBAEE,UAAU;sBAAlB,KAAK;gBAEI,eAAe;sBAAxB,MAAM;gBAIE,WAAW;sBAAnB,KAAK","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, Output } from '@angular/core';\nimport { ImageCroppedEvent, ImageTransform } from 'ngx-image-cropper';\n\n@Component({\n    selector: 'pw-image-cropper',\n    templateUrl: './image-cropper.component.html',\n    styleUrls: ['./image-cropper.component.scss']\n})\nexport class ProfileImageCropperComponent {\n    imageChangedEvent = '';\n\n    croppedImage = '';\n\n    @Output() imageSelectionEvent: EventEmitter<any> = new EventEmitter<any>();\n\n    @Output() closeEvent: EventEmitter<any> = new EventEmitter<any>();\n\n    @Input() userAvatar = '';\n\n    @Output() fileChangeEvent: EventEmitter<any> = new EventEmitter<any>();\n\n    busy: boolean;\n\n    @Input() aspectRatio = 'auto';\n\n    transform: ImageTransform = {};\n\n    canvasRotation = 0;\n\n    showCropper = false;\n\n    constructor(private cdr: ChangeDetectorRef) {}\n\n    onFileChange(event: any): void {\n        this.imageChangedEvent = event;\n        this.fileChangeEvent.emit(event.target.files[0]?.name);\n    }\n\n    imageCropped(event: ImageCroppedEvent) {\n        this.croppedImage = event.base64;\n        this.cdr.detectChanges();\n    }\n\n    imageLoaded() {\n        this.showCropper = true;\n    }\n\n    rotateLeft() {\n        this.canvasRotation--;\n        this.flipAfterRotate();\n    }\n\n    rotateRight() {\n        this.canvasRotation++;\n        this.flipAfterRotate();\n    }\n\n    private flipAfterRotate() {\n        const flippedH = this.transform.flipH;\n        const flippedV = this.transform.flipV;\n        this.transform = {\n            ...this.transform,\n            flipH: flippedV,\n            flipV: flippedH\n        };\n    }\n\n    flipHorizontal() {\n        this.transform = {\n            ...this.transform,\n            flipH: !this.transform.flipH\n        };\n    }\n\n    flipVertical() {\n        this.transform = {\n            ...this.transform,\n            flipV: !this.transform.flipV\n        };\n    }\n\n    saveProfilePicture() {\n        if (this.croppedImage) {\n            this.imageSelectionEvent.emit(this.croppedImage);\n            this.busy = true;\n        }\n    }\n\n    onCloseModal() {\n        this.closeEvent.emit();\n    }\n}\n","<section class=\"image-cropper\">\n  <div class=\"row text-start\">\n    <div class=\"col-12\">\n      <div class=\"card-block pb-0\">\n        <div class=\"row\">\n          <div class=\"col-12\">\n            <div class=\"file-upload my-2 float-start\">\n              <label>\n                Upload Pic\n                <input id=\"custom-input\"\n                  type=\"file\"\n                  (change)=\"onFileChange($event)\" />\n              </label>\n            </div>\n\n            <div class=\"float-end m-2\">\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Rotate Left\">\n                <i\n                                    class=\"fa fa-undo-alt\"\n                                    (click)=\"rotateLeft()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Rotate Right\">\n                <i\n                                    class=\"fa fa-redo-alt\"\n                                    (click)=\"rotateRight()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Flip Horizontal\">\n                <i\n                                    class=\"fa fa-arrows-alt-h\"\n                                    (click)=\"flipHorizontal()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Flip Vertical\">\n                <i\n                                    class=\"fa fa-arrows-alt-v\"\n                                    (click)=\"flipVertical()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n            </div>\n          </div>\n        </div>\n\n        <div class=\"row\">\n          <div class=\"col-8\">\n            <div *ngIf=\"aspectRatio === 'auto'\">\n              <image-cropper [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [canvasRotation]=\"canvasRotation\"\n                [aspectRatio]=\"4 / 4\"\n                [onlyScaleDown]=\"true\"\n                [transform]=\"transform\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n\n            <div *ngIf=\"aspectRatio === 'fullLogo'\">\n              <image-cropper [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [aspectRatio]=\"5 / 1.1\"\n                [onlyScaleDown]=\"true\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n\n            <div *ngIf=\"aspectRatio === 'custom'\">\n              <image-cropper [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [canvasRotation]=\"canvasRotation\"\n                [transform]=\"transform\"\n                [aspectRatio]=\"4 / 3\"\n                [onlyScaleDown]=\"true\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n          </div>\n          <div class=\"col-4\">\n            <img [src]=\"userAvatar\"\n              alt=\"cropped.png\"\n              width=\"128\" />\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n  <div class=\"card-footer px-3\">\n    <div class=\"float-end mt-2\">\n      <button type=\"button\"\n        class=\"btn btn-outline-default me-2\"\n        (click)=\"onCloseModal()\">\n        Close\n      </button>\n      <button type=\"button\"\n        class=\"btn btn-primary\"\n        (click)=\"saveProfilePicture()\"\n        [buttonBusy]=\"busy\">\n        Save\n      </button>\n    </div>\n  </div>\n</section>\n"]}
90
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-cropper.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/image-cropper/image-cropper.component.ts","../../../../../../libs/shared-components/src/lib/image-cropper/image-cropper.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, Output } from '@angular/core';\nimport { ImageCroppedEvent, ImageTransform } from 'ngx-image-cropper';\n\n@Component({\n    selector: 'pw-image-cropper',\n    templateUrl: './image-cropper.component.html',\n    styleUrls: ['./image-cropper.component.scss']\n})\nexport class ProfileImageCropperComponent {\n    imageChangedEvent = '';\n\n    croppedImage = '';\n\n    @Output() imageSelectionEvent: EventEmitter<any> = new EventEmitter<any>();\n\n    @Output() closeEvent: EventEmitter<any> = new EventEmitter<any>();\n\n    @Input() userAvatar = '';\n\n    @Output() fileChangeEvent: EventEmitter<any> = new EventEmitter<any>();\n\n    busy: boolean;\n\n    @Input() aspectRatio = 'auto';\n\n    transform: ImageTransform = {};\n\n    canvasRotation = 0;\n\n    showCropper = false;\n\n    constructor(private cdr: ChangeDetectorRef) {}\n\n    onFileChange(event: any): void {\n        this.imageChangedEvent = event;\n        this.fileChangeEvent.emit(event.target.files[0]?.name);\n    }\n\n    imageCropped(event: ImageCroppedEvent) {\n        const reader = new FileReader();\n        reader.onloadend = () => {\n            this.croppedImage = reader.result as string;\n            this.cdr.detectChanges();\n        };\n        reader.readAsDataURL(event.blob);\n    }\n\n    imageLoaded() {\n        this.showCropper = true;\n    }\n\n    rotateLeft() {\n        this.canvasRotation--;\n        this.flipAfterRotate();\n    }\n\n    rotateRight() {\n        this.canvasRotation++;\n        this.flipAfterRotate();\n    }\n\n    private flipAfterRotate() {\n        const flippedH = this.transform.flipH;\n        const flippedV = this.transform.flipV;\n        this.transform = {\n            ...this.transform,\n            flipH: flippedV,\n            flipV: flippedH\n        };\n    }\n\n    flipHorizontal() {\n        this.transform = {\n            ...this.transform,\n            flipH: !this.transform.flipH\n        };\n    }\n\n    flipVertical() {\n        this.transform = {\n            ...this.transform,\n            flipV: !this.transform.flipV\n        };\n    }\n\n    saveProfilePicture() {\n        if (this.croppedImage) {\n            this.imageSelectionEvent.emit(this.croppedImage);\n            this.busy = true;\n        }\n    }\n\n    onCloseModal() {\n        this.closeEvent.emit();\n    }\n}\n","<section class=\"image-cropper\">\n  <div class=\"row text-start\">\n    <div class=\"col-12\">\n      <div class=\"card-block pb-0\">\n        <div class=\"row\">\n          <div class=\"col-12\">\n            <div class=\"file-upload my-2 float-start\">\n              <label>\n                Upload Pic\n                <input id=\"custom-input\"\n                  type=\"file\"\n                  (change)=\"onFileChange($event)\" />\n              </label>\n            </div>\n\n            <div class=\"float-end m-2\">\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Rotate Left\">\n                <i\n                                    class=\"fa fa-undo-alt\"\n                                    (click)=\"rotateLeft()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Rotate Right\">\n                <i\n                                    class=\"fa fa-redo-alt\"\n                                    (click)=\"rotateRight()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Flip Horizontal\">\n                <i\n                                    class=\"fa fa-arrows-alt-h\"\n                                    (click)=\"flipHorizontal()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Flip Vertical\">\n                <i\n                                    class=\"fa fa-arrows-alt-v\"\n                                    (click)=\"flipVertical()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n            </div>\n          </div>\n        </div>\n\n        <div class=\"row\">\n          <div class=\"col-8\">\n            <div *ngIf=\"aspectRatio === 'auto'\">\n              <image-cropper [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [canvasRotation]=\"canvasRotation\"\n                [aspectRatio]=\"4 / 4\"\n                [onlyScaleDown]=\"true\"\n                [transform]=\"transform\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n\n            <div *ngIf=\"aspectRatio === 'fullLogo'\">\n              <image-cropper [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [aspectRatio]=\"5 / 1.1\"\n                [onlyScaleDown]=\"true\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n\n            <div *ngIf=\"aspectRatio === 'custom'\">\n              <image-cropper [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [canvasRotation]=\"canvasRotation\"\n                [transform]=\"transform\"\n                [aspectRatio]=\"4 / 3\"\n                [onlyScaleDown]=\"true\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n          </div>\n          <div class=\"col-4\">\n            <img [src]=\"userAvatar\"\n              alt=\"cropped.png\"\n              width=\"128\" />\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n  <div class=\"card-footer px-3\">\n    <div class=\"float-end mt-2\">\n      <button type=\"button\"\n        class=\"btn btn-outline-default me-2\"\n        (click)=\"onCloseModal()\">\n        Close\n      </button>\n      <button type=\"button\"\n        class=\"btn btn-primary\"\n        (click)=\"saveProfilePicture()\"\n        [buttonBusy]=\"busy\">\n        Save\n      </button>\n    </div>\n  </div>\n</section>\n"]}
@@ -170,8 +170,12 @@ class ProfileImageCropperComponent {
170
170
  this.fileChangeEvent.emit(event.target.files[0]?.name);
171
171
  }
172
172
  imageCropped(event) {
173
- this.croppedImage = event.base64;
174
- this.cdr.detectChanges();
173
+ const reader = new FileReader();
174
+ reader.onloadend = () => {
175
+ this.croppedImage = reader.result;
176
+ this.cdr.detectChanges();
177
+ };
178
+ reader.readAsDataURL(event.blob);
175
179
  }
176
180
  imageLoaded() {
177
181
  this.showCropper = true;