UNPKG

kwikui

Version:

KwikID's UI Component Library in Angular

108 lines 14.3 kB
import { Component, EventEmitter, Input, Output } from "@angular/core"; import { throwErrorMessage } from "../../../helpers/kwikui.common.helpers"; import { DEFAULT_VALUES, VALIDATE_KEY_VALUES } from "./image.constants"; import { EKwikUIImageType } from "./image.definitions"; import { isValidKeyValue } from "./image.validation"; import * as i0 from "@angular/core"; import * as i1 from "@angular/platform-browser"; import * as i2 from "../../../pipes/safe-html/safe-html.pipe"; export class KwikUIImageComponent { constructor(domSanitizer) { this.domSanitizer = domSanitizer; this.altText = DEFAULT_VALUES.altText; this.class = DEFAULT_VALUES.class; this.html = DEFAULT_VALUES.html; this.id = DEFAULT_VALUES.id; this.imageSrc = DEFAULT_VALUES.imageSrc; this.imageType = DEFAULT_VALUES.imageType; this.loadingType = DEFAULT_VALUES.loadingType; this.styles = DEFAULT_VALUES.styles; this.onClick = new EventEmitter(); } ngOnInit() { this.handleImageBasedOnImageType(); } ngOnChanges(changes) { const verifyChange = (key) => { return changes.hasOwnProperty(key) && !changes[key].firstChange; }; for (const change of Object.entries(changes)) { const key = change[0]; const value = change[1].currentValue; this.validateInputProperty(key, value); } if (verifyChange("imageSrc")) { this.imageSrc = changes.imageSrc.currentValue; this.handleImageBasedOnImageType(); } if (verifyChange("altText")) { this.altText = changes.altText.currentValue; } if (verifyChange("imageType")) { this.imageType = changes.imageType.currentValue; this.handleImageBasedOnImageType(); } if (verifyChange("loadingType")) { this.loadingType = changes.loadingType.currentValue; } } validateInputProperty(key, value) { if (VALIDATE_KEY_VALUES[key] && !isValidKeyValue(key, value)) { this[key] = DEFAULT_VALUES[key]; throwErrorMessage("kwikui-image", this.id, key, value, DEFAULT_VALUES[key]); } } handleOnClick(e) { this.onClick.emit(e); } cleanImageSrc() { this.imageSrc = this.imageSrc.trim(); } sanitizeImage() { this.safeImageSrc = this.domSanitizer.bypassSecurityTrustResourceUrl(this.imageSrc); } handleImageBasedOnImageType() { this.cleanImageSrc(); switch (this.imageType) { case EKwikUIImageType.BASE64: if (!this.imageSrc.startsWith("data:image")) { this.imageSrc = `data:image/png;base64,${this.imageSrc}`; } break; case EKwikUIImageType.URL: break; default: break; } this.sanitizeImage(); } } /** @nocollapse */ KwikUIImageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikUIImageComponent, deps: [{ token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component }); /** @nocollapse */ KwikUIImageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: KwikUIImageComponent, selector: "kwikui-image", inputs: { altText: "altText", class: "class", html: "html", id: "id", imageSrc: "imageSrc", imageType: "imageType", loadingType: "loadingType", styles: "styles" }, outputs: { onClick: "onClick" }, usesOnChanges: true, ngImport: i0, template: "<div id=\"image-container\">\n <div [innerHtml]=\"html?.before ?? '' | kwikuiSafeHtml\"></div>\n <img\n [attr.alt]=\"altText\"\n [attr.id]=\"id\"\n [attr.loading]=\"loadingType\"\n [attr.src]=\"safeImageSrc\"\n [class]=\"class\"\n [style]=\"styles\"\n (click)=\"handleOnClick($event)\"\n />\n <div [innerHtml]=\"html?.after ?? '' | kwikuiSafeHtml\"></div>\n</div>\n", styles: [".image-container{display:flex;flex-direction:column;justify-content:flex-start;align-items:stretch;align-content:space-between;grid-gap:.5rem;gap:.5rem}img{max-width:100%;height:auto}\n"], pipes: { "kwikuiSafeHtml": i2.KwikUISafeHtmlPipe } }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikUIImageComponent, decorators: [{ type: Component, args: [{ selector: "kwikui-image", templateUrl: "./image.component.html", styleUrls: ["./image.component.scss"] }] }], ctorParameters: function () { return [{ type: i1.DomSanitizer }]; }, propDecorators: { altText: [{ type: Input }], class: [{ type: Input }], html: [{ type: Input }], id: [{ type: Input }], imageSrc: [{ type: Input }], imageType: [{ type: Input }], loadingType: [{ type: Input }], styles: [{ type: Input }], onClick: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.component.js","sourceRoot":"","sources":["../../../../../../../projects/kwikui/src/lib/components/core/image/image.component.ts","../../../../../../../projects/kwikui/src/lib/components/core/image/image.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges\n} from \"@angular/core\";\nimport { DomSanitizer } from \"@angular/platform-browser\";\nimport { throwErrorMessage } from \"../../../helpers/kwikui.common.helpers\";\nimport { DEFAULT_VALUES, VALIDATE_KEY_VALUES } from \"./image.constants\";\nimport { EKwikUIImageLoadingType, EKwikUIImageType } from \"./image.definitions\";\nimport { isValidKeyValue } from \"./image.validation\";\n\n@Component({\n  selector: \"kwikui-image\",\n  templateUrl: \"./image.component.html\",\n  styleUrls: [\"./image.component.scss\"]\n})\nexport class KwikUIImageComponent implements OnInit, OnChanges {\n  @Input() altText: string = DEFAULT_VALUES.altText;\n\n  @Input() class: string = DEFAULT_VALUES.class;\n\n  @Input() html: any = DEFAULT_VALUES.html;\n\n  @Input() id: string = DEFAULT_VALUES.id;\n\n  @Input() imageSrc: string = DEFAULT_VALUES.imageSrc;\n\n  @Input() imageType: EKwikUIImageType = DEFAULT_VALUES.imageType;\n\n  @Input() loadingType: EKwikUIImageLoadingType = DEFAULT_VALUES.loadingType;\n\n  @Input() styles: string = DEFAULT_VALUES.styles;\n\n  @Output() onClick = new EventEmitter<any>();\n\n  safeImageSrc: any;\n\n  constructor(private domSanitizer: DomSanitizer) {}\n\n  ngOnInit(): void {\n    this.handleImageBasedOnImageType();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const verifyChange = (key: string) => {\n      return changes.hasOwnProperty(key) && !changes[key].firstChange;\n    };\n\n    for (const change of Object.entries(changes)) {\n      const key: string = change[0];\n      const value: any = change[1].currentValue;\n      this.validateInputProperty(key, value);\n    }\n\n    if (verifyChange(\"imageSrc\")) {\n      this.imageSrc = changes.imageSrc.currentValue;\n      this.handleImageBasedOnImageType();\n    }\n\n    if (verifyChange(\"altText\")) {\n      this.altText = changes.altText.currentValue;\n    }\n\n    if (verifyChange(\"imageType\")) {\n      this.imageType = changes.imageType.currentValue;\n      this.handleImageBasedOnImageType();\n    }\n\n    if (verifyChange(\"loadingType\")) {\n      this.loadingType = changes.loadingType.currentValue;\n    }\n  }\n\n  private validateInputProperty(key: string, value: any): void {\n    if (VALIDATE_KEY_VALUES[key] && !isValidKeyValue(key, value)) {\n      this[key] = DEFAULT_VALUES[key];\n      throwErrorMessage(\n        \"kwikui-image\",\n        this.id,\n        key,\n        value,\n        DEFAULT_VALUES[key]\n      );\n    }\n  }\n\n  handleOnClick(e: any): void {\n    this.onClick.emit(e);\n  }\n\n  private cleanImageSrc(): void {\n    this.imageSrc = this.imageSrc.trim();\n  }\n\n  private sanitizeImage(): void {\n    this.safeImageSrc = this.domSanitizer.bypassSecurityTrustResourceUrl(\n      this.imageSrc\n    );\n  }\n\n  handleImageBasedOnImageType(): void {\n    this.cleanImageSrc();\n\n    switch (this.imageType) {\n      case EKwikUIImageType.BASE64:\n        if (!this.imageSrc.startsWith(\"data:image\")) {\n          this.imageSrc = `data:image/png;base64,${this.imageSrc}`;\n        }\n        break;\n      case EKwikUIImageType.URL:\n        break;\n      default:\n        break;\n    }\n\n    this.sanitizeImage();\n  }\n}\n","<div id=\"image-container\">\n  <div [innerHtml]=\"html?.before ?? '' | kwikuiSafeHtml\"></div>\n  <img\n    [attr.alt]=\"altText\"\n    [attr.id]=\"id\"\n    [attr.loading]=\"loadingType\"\n    [attr.src]=\"safeImageSrc\"\n    [class]=\"class\"\n    [style]=\"styles\"\n    (click)=\"handleOnClick($event)\"\n  />\n  <div [innerHtml]=\"html?.after ?? '' | kwikuiSafeHtml\"></div>\n</div>\n"]}