simpo-component-library 3.6.820 → 3.6.823

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.
Files changed (21) hide show
  1. package/esm2022/lib/directive/image-editor.directive.mjs +1 -1
  2. package/esm2022/lib/directive/merge-header.directive.mjs +21 -7
  3. package/esm2022/lib/directive/sticky-directive.mjs +19 -8
  4. package/esm2022/lib/elements/below-image-card/below-image-card.component.mjs +3 -3
  5. package/esm2022/lib/sections/banner-grid-section/banner-grid-section.component.mjs +3 -3
  6. package/esm2022/lib/sections/banner-section/banner-section.component.mjs +3 -3
  7. package/esm2022/lib/sections/choose-us-section/choose-us-section.component.mjs +3 -3
  8. package/esm2022/lib/sections/feature-experience-section/feature-experience-section.component.mjs +3 -3
  9. package/esm2022/lib/sections/features-section/features-section.component.mjs +3 -3
  10. package/esm2022/lib/sections/header-section/header-section.component.mjs +79 -20
  11. package/esm2022/lib/sections/image-carousel-section/image-carousel-section.component.mjs +4 -4
  12. package/esm2022/lib/sections/testimonial-slider/testimonial-slider.component.mjs +3 -3
  13. package/esm2022/lib/sections/video-grid-section/video-grid-section.component.mjs +3 -3
  14. package/fesm2022/simpo-component-library.mjs +128 -48
  15. package/fesm2022/simpo-component-library.mjs.map +1 -1
  16. package/lib/directive/merge-header.directive.d.ts +7 -3
  17. package/lib/directive/sticky-directive.d.ts +4 -2
  18. package/lib/sections/header-section/header-section.component.d.ts +14 -4
  19. package/package.json +1 -1
  20. package/simpo-component-library-3.6.823.tgz +0 -0
  21. package/simpo-component-library-3.6.820.tgz +0 -0
@@ -108,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
108
108
  }], iconData: [{
109
109
  type: Input
110
110
  }] } });
111
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-editor.directive.js","sourceRoot":"","sources":["../../../../../projects/simpo-ui/src/lib/directive/image-editor.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, OnInit, OnDestroy, Input } from '@angular/core';\r\nimport { Image } from '../styles/style.model';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { ImageEditorComponent } from '../elements/image-editor/image-editor.component';\r\nimport { debounceTime, fromEvent, Subscription, filter } from 'rxjs';\r\nimport { EventsService } from '../services/events.service';\r\nimport { Router } from '@angular/router';\r\nimport { Icon } from '../styles/style.model';\r\n\r\n@Directive({\r\n  selector: '[appImageEditor]',\r\n  standalone: true\r\n})\r\nexport class ImageEditorDirective implements OnInit, OnDestroy {\r\n  @Input() appImageEditor: boolean = false;\r\n  @Input() imageData?: Image;\r\n  @Input() sectionId?: string;\r\n  @Input() showIcon?: boolean = false;\r\n  @Input() iconData?: Icon;\r\n\r\n  private mouseEnterSub?: Subscription;\r\n  private mouseLeaveSub?: Subscription;\r\n  private clickSub?: Subscription;\r\n  private readonly HIGHLIGHT_BORDER = '3px solid #283E90';\r\n\r\n  constructor(private el: ElementRef, private matDialog: MatDialog, private _eventService: EventsService, private router: Router) { }\r\n\r\n  ngOnInit() {\r\n    if (this.appImageEditor) {\r\n      this.setupEventListeners();\r\n    } else {\r\n      this.redirectTo();\r\n    }\r\n  }\r\n\r\n  ngOnChanges() {\r\n    this.cleanup();\r\n    if (this.appImageEditor) {\r\n      this.setupEventListeners();\r\n    }\r\n  }\r\n\r\n  private setupEventListeners() {\r\n    this.mouseEnterSub = fromEvent(this.el.nativeElement, 'mouseenter')\r\n      .pipe(debounceTime(100))\r\n      .subscribe(() => {\r\n        this.el.nativeElement.style.boxSizing = 'border-box';\r\n        this.el.nativeElement.style.outline = this.HIGHLIGHT_BORDER;\r\n        this.el.nativeElement.style.cursor = 'pointer';\r\n      });\r\n\r\n    this.mouseLeaveSub = fromEvent(this.el.nativeElement, 'mouseleave')\r\n      .pipe(debounceTime(100))\r\n      .subscribe(() => {\r\n        this.el.nativeElement.style.border = '';\r\n        this.el.nativeElement.style.outline = '';\r\n        this.el.nativeElement.style.borderColor = 'transparent';\r\n      });\r\n\r\n    this.clickSub = fromEvent(this.el.nativeElement, 'click')\r\n      .pipe(\r\n        filter(() => !this.matDialog.openDialogs.length)\r\n      )\r\n      .subscribe(() => {\r\n        this.matDialog.open(ImageEditorComponent, {\r\n          panelClass: 'link-editor',\r\n          data: {\r\n            imageData: this.imageData,\r\n            iconData :  this.iconData,\r\n            sectionId: this.sectionId,\r\n            showIcon: this.showIcon\r\n          }\r\n        });\r\n      });\r\n  }\r\n\r\n  private cleanup() {\r\n    if (this.mouseEnterSub) {\r\n      this.mouseEnterSub.unsubscribe();\r\n      this.mouseEnterSub = undefined;\r\n    }\r\n\r\n    if (this.mouseLeaveSub) {\r\n      this.mouseLeaveSub.unsubscribe();\r\n      this.mouseLeaveSub = undefined;\r\n    }\r\n\r\n    if (this.clickSub) {\r\n      this.clickSub.unsubscribe();\r\n      this.clickSub = undefined;\r\n    }\r\n\r\n    // Reset styles when cleaning up\r\n    this.el.nativeElement.style.border = '';\r\n    this.el.nativeElement.style.cursor = '';\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.cleanup();\r\n  }\r\n  redirectTo() {\r\n    this.el.nativeElement.style.cursor = 'pointer';\r\n    if (!this.imageData?.content?.redirectionUrl)\r\n      return;\r\n    this.clickSub = fromEvent(this.el.nativeElement, 'click')\r\n      .pipe(debounceTime(100))\r\n      .subscribe(() => {\r\n        this._eventService.buttonRedirection.emit({ data: this.imageData?.content });\r\n      });\r\n  }\r\n}\r\n"]}
111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-editor.directive.js","sourceRoot":"","sources":["../../../../../projects/simpo-ui/src/lib/directive/image-editor.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, OnInit, OnDestroy, Input } from '@angular/core';\r\nimport { Image } from '../styles/style.model';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { ImageEditorComponent } from '../elements/image-editor/image-editor.component';\r\nimport { debounceTime, fromEvent, Subscription, filter } from 'rxjs';\r\nimport { EventsService } from '../services/events.service';\r\nimport { Router } from '@angular/router';\r\nimport { Icon } from '../styles/style.model';\r\n\r\n@Directive({\r\n  selector: '[appImageEditor]',\r\n  standalone: true\r\n})\r\nexport class ImageEditorDirective implements OnInit, OnDestroy {\r\n  @Input() appImageEditor: boolean = false;\r\n  @Input() imageData?: Image;\r\n  @Input() sectionId?: string;\r\n  @Input() showIcon?: boolean = false;\r\n  @Input() iconData?: Icon;\r\n\r\n  private mouseEnterSub?: Subscription;\r\n  private mouseLeaveSub?: Subscription;\r\n  private clickSub?: Subscription;\r\n  private readonly HIGHLIGHT_BORDER = '3px solid #283E90';\r\n\r\n  constructor(private el: ElementRef, private matDialog: MatDialog, private _eventService: EventsService, private router: Router) { }\r\n\r\n  ngOnInit() {\r\n    if (this.appImageEditor) {\r\n      this.setupEventListeners();\r\n    } else {\r\n      this.redirectTo();\r\n    }\r\n  }\r\n\r\n  ngOnChanges() {\r\n    this.cleanup();\r\n    if (this.appImageEditor) {\r\n      this.setupEventListeners();\r\n    }\r\n  }\r\n\r\n  private setupEventListeners() {\r\n    this.mouseEnterSub = fromEvent(this.el.nativeElement, 'mouseenter')\r\n      .pipe(debounceTime(100))\r\n      .subscribe(() => {\r\n        this.el.nativeElement.style.boxSizing = 'border-box';\r\n        this.el.nativeElement.style.outline = this.HIGHLIGHT_BORDER;\r\n        this.el.nativeElement.style.cursor = 'pointer';\r\n      });\r\n\r\n    this.mouseLeaveSub = fromEvent(this.el.nativeElement, 'mouseleave')\r\n      .pipe(debounceTime(100))\r\n      .subscribe(() => {\r\n        this.el.nativeElement.style.border = '';\r\n        this.el.nativeElement.style.outline = '';\r\n        this.el.nativeElement.style.borderColor = 'transparent';\r\n      });\r\n\r\n    this.clickSub = fromEvent(this.el.nativeElement, 'click')\r\n      .pipe(\r\n        filter(() => !this.matDialog.openDialogs.length)\r\n      )\r\n      .subscribe(() => {\r\n        this.matDialog.open(ImageEditorComponent, {\r\n          panelClass: 'link-editor',\r\n          data: {\r\n            imageData: this.imageData,\r\n            iconData: this.iconData,\r\n            sectionId: this.sectionId,\r\n            showIcon: this.showIcon\r\n          }\r\n        });\r\n      });\r\n  }\r\n\r\n  private cleanup() {\r\n    if (this.mouseEnterSub) {\r\n      this.mouseEnterSub.unsubscribe();\r\n      this.mouseEnterSub = undefined;\r\n    }\r\n\r\n    if (this.mouseLeaveSub) {\r\n      this.mouseLeaveSub.unsubscribe();\r\n      this.mouseLeaveSub = undefined;\r\n    }\r\n\r\n    if (this.clickSub) {\r\n      this.clickSub.unsubscribe();\r\n      this.clickSub = undefined;\r\n    }\r\n\r\n    // Reset styles when cleaning up\r\n    this.el.nativeElement.style.border = '';\r\n    this.el.nativeElement.style.cursor = '';\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.cleanup();\r\n  }\r\n  redirectTo() {\r\n    this.el.nativeElement.style.cursor = 'pointer';\r\n    if (!this.imageData?.content?.redirectionUrl)\r\n      return;\r\n    this.clickSub = fromEvent(this.el.nativeElement, 'click')\r\n      .pipe(debounceTime(100))\r\n      .subscribe(() => {\r\n        this._eventService.buttonRedirection.emit({ data: this.imageData?.content });\r\n      });\r\n  }\r\n}\r\n"]}
@@ -1,22 +1,33 @@
1
- import { Directive, Input } from '@angular/core';
1
+ import { isPlatformBrowser } from '@angular/common';
2
+ import { Directive, Inject, Input, PLATFORM_ID } from '@angular/core';
2
3
  import * as i0 from "@angular/core";
3
4
  import * as i1 from "../services/events.service";
4
5
  export class MergeHeaderDirective {
5
- constructor(eventsService, el) {
6
+ constructor(eventsService, el, platformId) {
6
7
  this.eventsService = eventsService;
7
8
  this.el = el;
9
+ this.platformId = platformId;
8
10
  this.top = 0;
11
+ this.isBrowser = false;
12
+ this.isBrowser = isPlatformBrowser(this.platformId);
9
13
  }
10
14
  ngOnInit() {
11
- this.eventsService.elementHeight.subscribe((res) => {
12
- this.top = res;
15
+ if (!this.isBrowser)
16
+ return;
17
+ this.elementHeightSubscription = this.eventsService.elementHeight.subscribe((res) => {
18
+ this.top = Number(res) || 0;
13
19
  this.applyBackgroundPosition();
14
20
  });
15
21
  }
16
22
  ngOnChanges() {
17
23
  this.applyBackgroundPosition();
18
24
  }
25
+ ngOnDestroy() {
26
+ this.elementHeightSubscription?.unsubscribe();
27
+ }
19
28
  applyBackgroundPosition() {
29
+ if (!this.isBrowser)
30
+ return;
20
31
  if (window.innerWidth > 475) {
21
32
  if (this.merge)
22
33
  this.el.nativeElement.style.setProperty('margin-top', `-${this.top}px`);
@@ -24,7 +35,7 @@ export class MergeHeaderDirective {
24
35
  this.el.nativeElement.style.setProperty('margin-top', `0px`);
25
36
  }
26
37
  }
27
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MergeHeaderDirective, deps: [{ token: i1.EventsService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
38
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MergeHeaderDirective, deps: [{ token: i1.EventsService }, { token: i0.ElementRef }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Directive }); }
28
39
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: MergeHeaderDirective, isStandalone: true, selector: "[simpoMergeHeader]", inputs: { merge: ["simpoMergeHeader", "merge"], backgroundInfo: "backgroundInfo" }, usesOnChanges: true, ngImport: i0 }); }
29
40
  }
30
41
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MergeHeaderDirective, decorators: [{
@@ -33,11 +44,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
33
44
  selector: '[simpoMergeHeader]',
34
45
  standalone: true
35
46
  }]
36
- }], ctorParameters: () => [{ type: i1.EventsService }, { type: i0.ElementRef }], propDecorators: { merge: [{
47
+ }], ctorParameters: () => [{ type: i1.EventsService }, { type: i0.ElementRef }, { type: undefined, decorators: [{
48
+ type: Inject,
49
+ args: [PLATFORM_ID]
50
+ }] }], propDecorators: { merge: [{
37
51
  type: Input,
38
52
  args: ['simpoMergeHeader']
39
53
  }], backgroundInfo: [{
40
54
  type: Input,
41
55
  args: ['backgroundInfo']
42
56
  }] } });
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVyZ2UtaGVhZGVyLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NpbXBvLXVpL3NyYy9saWIvZGlyZWN0aXZlL21lcmdlLWhlYWRlci5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxLQUFLLEVBQW9DLE1BQU0sZUFBZSxDQUFDOzs7QUFPL0YsTUFBTSxPQUFPLG9CQUFvQjtJQU0vQixZQUFvQixhQUE0QixFQUFVLEVBQWM7UUFBcEQsa0JBQWEsR0FBYixhQUFhLENBQWU7UUFBVSxPQUFFLEdBQUYsRUFBRSxDQUFZO1FBRmhFLFFBQUcsR0FBVyxDQUFDLENBQUM7SUFFb0QsQ0FBQztJQUU3RSxRQUFRO1FBQ04sSUFBSSxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLENBQUMsR0FBVyxFQUFFLEVBQUU7WUFDekQsSUFBSSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7WUFDZixJQUFJLENBQUMsdUJBQXVCLEVBQUUsQ0FBQztRQUNqQyxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLHVCQUF1QixFQUFFLENBQUE7SUFDaEMsQ0FBQztJQUVPLHVCQUF1QjtRQUU3QixJQUFJLE1BQU0sQ0FBQyxVQUFVLEdBQUcsR0FBRyxFQUFFLENBQUM7WUFDNUIsSUFBSSxJQUFJLENBQUMsS0FBSztnQkFDWixJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUNyQyxZQUFZLEVBQUUsSUFBSSxJQUFJLENBQUMsR0FBRyxJQUFJLENBQy9CLENBQUM7O2dCQUVGLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQ3JDLFlBQVksRUFBRSxLQUFLLENBQ3BCLENBQUM7UUFDTixDQUFDO0lBQ0gsQ0FBQzsrR0EvQlUsb0JBQW9CO21HQUFwQixvQkFBb0I7OzRGQUFwQixvQkFBb0I7a0JBSmhDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG9CQUFvQjtvQkFDOUIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOzJHQUU0QixLQUFLO3NCQUEvQixLQUFLO3VCQUFDLGtCQUFrQjtnQkFDQSxjQUFjO3NCQUF0QyxLQUFLO3VCQUFDLGdCQUFnQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSW5wdXQsIFNpbXBsZUNoYW5nZXMsIE9uSW5pdCwgT25DaGFuZ2VzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEV2ZW50c1NlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9ldmVudHMuc2VydmljZSc7XHJcblxyXG5ARGlyZWN0aXZlKHtcclxuICBzZWxlY3RvcjogJ1tzaW1wb01lcmdlSGVhZGVyXScsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTWVyZ2VIZWFkZXJEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIE9uQ2hhbmdlcyB7XHJcbiAgQElucHV0KCdzaW1wb01lcmdlSGVhZGVyJykgbWVyZ2U/OiBib29sZWFuO1xyXG4gIEBJbnB1dCgnYmFja2dyb3VuZEluZm8nKSBiYWNrZ3JvdW5kSW5mbzogYW55O1xyXG5cclxuICBwcml2YXRlIHRvcDogbnVtYmVyID0gMDtcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBldmVudHNTZXJ2aWNlOiBFdmVudHNTZXJ2aWNlLCBwcml2YXRlIGVsOiBFbGVtZW50UmVmKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICB0aGlzLmV2ZW50c1NlcnZpY2UuZWxlbWVudEhlaWdodC5zdWJzY3JpYmUoKHJlczogbnVtYmVyKSA9PiB7XHJcbiAgICAgIHRoaXMudG9wID0gcmVzO1xyXG4gICAgICB0aGlzLmFwcGx5QmFja2dyb3VuZFBvc2l0aW9uKCk7XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIG5nT25DaGFuZ2VzKCkge1xyXG4gICAgdGhpcy5hcHBseUJhY2tncm91bmRQb3NpdGlvbigpXHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGFwcGx5QmFja2dyb3VuZFBvc2l0aW9uKCkge1xyXG5cclxuICAgIGlmICh3aW5kb3cuaW5uZXJXaWR0aCA+IDQ3NSkge1xyXG4gICAgICBpZiAodGhpcy5tZXJnZSlcclxuICAgICAgICB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQuc3R5bGUuc2V0UHJvcGVydHkoXHJcbiAgICAgICAgICAnbWFyZ2luLXRvcCcsIGAtJHt0aGlzLnRvcH1weGBcclxuICAgICAgICApO1xyXG4gICAgICBlbHNlXHJcbiAgICAgICAgdGhpcy5lbC5uYXRpdmVFbGVtZW50LnN0eWxlLnNldFByb3BlcnR5KFxyXG4gICAgICAgICAgJ21hcmdpbi10b3AnLCBgMHB4YFxyXG4gICAgICAgICk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVyZ2UtaGVhZGVyLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NpbXBvLXVpL3NyYy9saWIvZGlyZWN0aXZlL21lcmdlLWhlYWRlci5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDcEQsT0FBTyxFQUFFLFNBQVMsRUFBYyxNQUFNLEVBQUUsS0FBSyxFQUFnQyxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQVFoSCxNQUFNLE9BQU8sb0JBQW9CO0lBUS9CLFlBQ1UsYUFBNEIsRUFDNUIsRUFBYyxFQUNPLFVBQWtCO1FBRnZDLGtCQUFhLEdBQWIsYUFBYSxDQUFlO1FBQzVCLE9BQUUsR0FBRixFQUFFLENBQVk7UUFDTyxlQUFVLEdBQVYsVUFBVSxDQUFRO1FBUHpDLFFBQUcsR0FBVyxDQUFDLENBQUM7UUFDaEIsY0FBUyxHQUFHLEtBQUssQ0FBQztRQVF4QixJQUFJLENBQUMsU0FBUyxHQUFHLGlCQUFpQixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUN0RCxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUztZQUFFLE9BQU87UUFFNUIsSUFBSSxDQUFDLHlCQUF5QixHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQVksRUFBRSxFQUFFO1lBQzNGLElBQUksQ0FBQyxHQUFHLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUM1QixJQUFJLENBQUMsdUJBQXVCLEVBQUUsQ0FBQztRQUNqQyxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLHVCQUF1QixFQUFFLENBQUE7SUFDaEMsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMseUJBQXlCLEVBQUUsV0FBVyxFQUFFLENBQUM7SUFDaEQsQ0FBQztJQUVPLHVCQUF1QjtRQUM3QixJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVM7WUFBRSxPQUFPO1FBRTVCLElBQUksTUFBTSxDQUFDLFVBQVUsR0FBRyxHQUFHLEVBQUUsQ0FBQztZQUM1QixJQUFJLElBQUksQ0FBQyxLQUFLO2dCQUNaLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQ3JDLFlBQVksRUFBRSxJQUFJLElBQUksQ0FBQyxHQUFHLElBQUksQ0FDL0IsQ0FBQzs7Z0JBRUYsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FDckMsWUFBWSxFQUFFLEtBQUssQ0FDcEIsQ0FBQztRQUNOLENBQUM7SUFDSCxDQUFDOytHQTlDVSxvQkFBb0IseUVBV3JCLFdBQVc7bUdBWFYsb0JBQW9COzs0RkFBcEIsb0JBQW9CO2tCQUpoQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxvQkFBb0I7b0JBQzlCLFVBQVUsRUFBRSxJQUFJO2lCQUNqQjs7MEJBWUksTUFBTTsyQkFBQyxXQUFXO3lDQVZNLEtBQUs7c0JBQS9CLEtBQUs7dUJBQUMsa0JBQWtCO2dCQUNBLGNBQWM7c0JBQXRDLEtBQUs7dUJBQUMsZ0JBQWdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaXNQbGF0Zm9ybUJyb3dzZXIgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIEluamVjdCwgSW5wdXQsIE9uQ2hhbmdlcywgT25EZXN0cm95LCBPbkluaXQsIFBMQVRGT1JNX0lEIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEV2ZW50c1NlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9ldmVudHMuc2VydmljZSc7XHJcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6ICdbc2ltcG9NZXJnZUhlYWRlcl0nLFxyXG4gIHN0YW5kYWxvbmU6IHRydWVcclxufSlcclxuZXhwb3J0IGNsYXNzIE1lcmdlSGVhZGVyRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMsIE9uRGVzdHJveSB7XHJcbiAgQElucHV0KCdzaW1wb01lcmdlSGVhZGVyJykgbWVyZ2U/OiBib29sZWFuO1xyXG4gIEBJbnB1dCgnYmFja2dyb3VuZEluZm8nKSBiYWNrZ3JvdW5kSW5mbzogYW55O1xyXG5cclxuICBwcml2YXRlIHRvcDogbnVtYmVyID0gMDtcclxuICBwcml2YXRlIGlzQnJvd3NlciA9IGZhbHNlO1xyXG4gIHByaXZhdGUgZWxlbWVudEhlaWdodFN1YnNjcmlwdGlvbj86IFN1YnNjcmlwdGlvbjtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIGV2ZW50c1NlcnZpY2U6IEV2ZW50c1NlcnZpY2UsXHJcbiAgICBwcml2YXRlIGVsOiBFbGVtZW50UmVmLFxyXG4gICAgQEluamVjdChQTEFURk9STV9JRCkgcHJpdmF0ZSBwbGF0Zm9ybUlkOiBvYmplY3RcclxuICApIHtcclxuICAgIHRoaXMuaXNCcm93c2VyID0gaXNQbGF0Zm9ybUJyb3dzZXIodGhpcy5wbGF0Zm9ybUlkKTtcclxuICB9XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gICAgaWYgKCF0aGlzLmlzQnJvd3NlcikgcmV0dXJuO1xyXG5cclxuICAgIHRoaXMuZWxlbWVudEhlaWdodFN1YnNjcmlwdGlvbiA9IHRoaXMuZXZlbnRzU2VydmljZS5lbGVtZW50SGVpZ2h0LnN1YnNjcmliZSgocmVzOiB1bmtub3duKSA9PiB7XHJcbiAgICAgIHRoaXMudG9wID0gTnVtYmVyKHJlcykgfHwgMDtcclxuICAgICAgdGhpcy5hcHBseUJhY2tncm91bmRQb3NpdGlvbigpO1xyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBuZ09uQ2hhbmdlcygpIHtcclxuICAgIHRoaXMuYXBwbHlCYWNrZ3JvdW5kUG9zaXRpb24oKVxyXG4gIH1cclxuXHJcbiAgbmdPbkRlc3Ryb3koKSB7XHJcbiAgICB0aGlzLmVsZW1lbnRIZWlnaHRTdWJzY3JpcHRpb24/LnVuc3Vic2NyaWJlKCk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGFwcGx5QmFja2dyb3VuZFBvc2l0aW9uKCkge1xyXG4gICAgaWYgKCF0aGlzLmlzQnJvd3NlcikgcmV0dXJuO1xyXG5cclxuICAgIGlmICh3aW5kb3cuaW5uZXJXaWR0aCA+IDQ3NSkge1xyXG4gICAgICBpZiAodGhpcy5tZXJnZSlcclxuICAgICAgICB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQuc3R5bGUuc2V0UHJvcGVydHkoXHJcbiAgICAgICAgICAnbWFyZ2luLXRvcCcsIGAtJHt0aGlzLnRvcH1weGBcclxuICAgICAgICApO1xyXG4gICAgICBlbHNlXHJcbiAgICAgICAgdGhpcy5lbC5uYXRpdmVFbGVtZW50LnN0eWxlLnNldFByb3BlcnR5KFxyXG4gICAgICAgICAgJ21hcmdpbi10b3AnLCBgMHB4YFxyXG4gICAgICAgICk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
@@ -1,17 +1,21 @@
1
- import { Directive, Input } from '@angular/core';
1
+ import { Directive, Inject, Input, PLATFORM_ID } from '@angular/core';
2
+ import { isPlatformBrowser } from '@angular/common';
2
3
  import * as i0 from "@angular/core";
3
4
  import * as i1 from "@angular/router";
4
5
  export class SimpoStickyDirective {
5
- constructor(el, router) {
6
+ constructor(el, router, platformId) {
6
7
  this.el = el;
7
8
  this.router = router;
9
+ this.platformId = platformId;
10
+ this.isBrowser = false;
11
+ this.isBrowser = isPlatformBrowser(this.platformId);
8
12
  }
9
13
  ngOnChanges() {
10
14
  if (this.simpoSticky) {
11
15
  this.el.nativeElement.style.setProperty("position", "fixed");
12
16
  this.el.nativeElement.style.setProperty("top", "0px");
13
17
  this.el.nativeElement.style.setProperty("left", '0px');
14
- if (localStorage.getItem('REQUEST_FROM') == 'USER')
18
+ if (this.isBrowser && localStorage.getItem('REQUEST_FROM') == 'USER')
15
19
  this.el.nativeElement.style.setProperty("z-index", "10000002");
16
20
  else {
17
21
  let url = this.router.url;
@@ -24,7 +28,7 @@ export class SimpoStickyDirective {
24
28
  this.el.nativeElement.style.setProperty("margin-top", "0px");
25
29
  }
26
30
  setTimeout(() => {
27
- if (window.innerWidth > 475) {
31
+ if (this.isBrowser && window.innerWidth > 475) {
28
32
  this.addParentMargin();
29
33
  }
30
34
  }, 0);
@@ -35,6 +39,8 @@ export class SimpoStickyDirective {
35
39
  }
36
40
  }
37
41
  ngAfterViewInit() {
42
+ if (!this.isBrowser || typeof ResizeObserver === 'undefined')
43
+ return;
38
44
  this.resizeObserver = new ResizeObserver(() => {
39
45
  setTimeout(() => {
40
46
  if (window.innerWidth > 475 && this.simpoSticky) {
@@ -45,7 +51,8 @@ export class SimpoStickyDirective {
45
51
  this.resizeObserver.observe(this.el.nativeElement);
46
52
  }
47
53
  addParentMargin() {
48
- let headerHeight = this.el.nativeElement.offsetHeight;
54
+ const nativeElement = this.el.nativeElement;
55
+ let headerHeight = Math.ceil(nativeElement.getBoundingClientRect().height || nativeElement.offsetHeight || 0);
49
56
  const parent = this.el.nativeElement.parentElement;
50
57
  if (parent && headerHeight > 0) {
51
58
  parent.style.marginBottom = (headerHeight) + 'px';
@@ -58,9 +65,10 @@ export class SimpoStickyDirective {
58
65
  }
59
66
  }
60
67
  ngOnDestroy() {
68
+ this.resizeObserver?.disconnect();
61
69
  this.removeParentMargin();
62
70
  }
63
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SimpoStickyDirective, deps: [{ token: i0.ElementRef }, { token: i1.Router }], target: i0.ɵɵFactoryTarget.Directive }); }
71
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SimpoStickyDirective, deps: [{ token: i0.ElementRef }, { token: i1.Router }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Directive }); }
64
72
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: SimpoStickyDirective, isStandalone: true, selector: "[simpoSticky]", inputs: { simpoSticky: "simpoSticky", categoryHeader: "categoryHeader" }, usesOnChanges: true, ngImport: i0 }); }
65
73
  }
66
74
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SimpoStickyDirective, decorators: [{
@@ -69,11 +77,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
69
77
  selector: '[simpoSticky]',
70
78
  standalone: true
71
79
  }]
72
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.Router }], propDecorators: { simpoSticky: [{
80
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.Router }, { type: undefined, decorators: [{
81
+ type: Inject,
82
+ args: [PLATFORM_ID]
83
+ }] }], propDecorators: { simpoSticky: [{
73
84
  type: Input,
74
85
  args: ['simpoSticky']
75
86
  }], categoryHeader: [{
76
87
  type: Input,
77
88
  args: ['categoryHeader']
78
89
  }] } });
79
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RpY2t5LWRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NpbXBvLXVpL3NyYy9saWIvZGlyZWN0aXZlL3N0aWNreS1kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQU83RCxNQUFNLE9BQU8sb0JBQW9CO0lBSS9CLFlBQW9CLEVBQWMsRUFDeEIsTUFBYztRQURKLE9BQUUsR0FBRixFQUFFLENBQVk7UUFDeEIsV0FBTSxHQUFOLE1BQU0sQ0FBUTtJQUNwQixDQUFDO0lBS0wsV0FBVztRQUNULElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsVUFBVSxFQUFFLE9BQU8sQ0FBQyxDQUFDO1lBQzdELElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxDQUFDO1lBQ3RELElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsTUFBTSxFQUFFLEtBQUssQ0FBQyxDQUFBO1lBQ3RELElBQUksWUFBWSxDQUFDLE9BQU8sQ0FBQyxjQUFjLENBQUMsSUFBSSxNQUFNO2dCQUNoRCxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLFNBQVMsRUFBRSxVQUFVLENBQUMsQ0FBQTtpQkFDM0QsQ0FBQztnQkFDSixJQUFJLEdBQUcsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQTtnQkFDekIsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxTQUFTLEVBQUUsS0FBSyxDQUFDLENBQUE7Z0JBQ3pELElBQUksR0FBRyxDQUFDLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQztvQkFDaEMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxZQUFZLEVBQUUsTUFBTSxDQUFDLENBQUE7cUJBQzFELElBQUksR0FBRyxDQUFDLFFBQVEsQ0FBQyxjQUFjLENBQUM7b0JBQ25DLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsWUFBWSxFQUFFLE1BQU0sQ0FBQyxDQUFBOztvQkFFN0QsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxZQUFZLEVBQUUsS0FBSyxDQUFDLENBQUE7WUFDaEUsQ0FBQztZQUNELFVBQVUsQ0FBQyxHQUFHLEVBQUU7Z0JBQ2QsSUFBSSxNQUFNLENBQUMsVUFBVSxHQUFHLEdBQUcsRUFBRSxDQUFDO29CQUM1QixJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7Z0JBQ3pCLENBQUM7WUFDSCxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDUixDQUFDO2FBQU0sQ0FBQztZQUNOLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsVUFBVSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1lBQ2hFLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO1FBQzVCLENBQUM7SUFDSCxDQUFDO0lBR0QsZUFBZTtRQUNiLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxjQUFjLENBQUMsR0FBRyxFQUFFO1lBQzVDLFVBQVUsQ0FBQyxHQUFHLEVBQUU7Z0JBQ2QsSUFBSSxNQUFNLENBQUMsVUFBVSxHQUFHLEdBQUcsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7b0JBQ2hELElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQztnQkFDekIsQ0FBQztZQUNILENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNSLENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUNyRCxDQUFDO0lBRU8sZUFBZTtRQUNyQixJQUFJLFlBQVksR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUM7UUFDdEQsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsYUFBYSxDQUFDO1FBQ25ELElBQUksTUFBTSxJQUFJLFlBQVksR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUMvQixNQUFNLENBQUMsS0FBSyxDQUFDLFlBQVksR0FBRyxDQUFDLFlBQVksQ0FBQyxHQUFHLElBQUksQ0FBQztRQUNwRCxDQUFDO0lBQ0gsQ0FBQztJQUVPLGtCQUFrQjtRQUN4QixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUM7UUFDbkQsSUFBSSxNQUFNLEVBQUUsQ0FBQztZQUNYLE1BQU0sQ0FBQyxLQUFLLENBQUMsWUFBWSxHQUFHLEtBQUssQ0FBQztRQUNwQyxDQUFDO0lBQ0gsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztJQUM1QixDQUFDOytHQXBFVSxvQkFBb0I7bUdBQXBCLG9CQUFvQjs7NEZBQXBCLG9CQUFvQjtrQkFKaEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsZUFBZTtvQkFDekIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCO29HQUV1QixXQUFXO3NCQUFoQyxLQUFLO3VCQUFDLGFBQWE7Z0JBQ0ssY0FBYztzQkFBdEMsS0FBSzt1QkFBQyxnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XHJcblxyXG5ARGlyZWN0aXZlKHtcclxuICBzZWxlY3RvcjogJ1tzaW1wb1N0aWNreV0nLFxyXG4gIHN0YW5kYWxvbmU6IHRydWVcclxufSlcclxuZXhwb3J0IGNsYXNzIFNpbXBvU3RpY2t5RGlyZWN0aXZlIHtcclxuICBASW5wdXQoJ3NpbXBvU3RpY2t5Jykgc2ltcG9TdGlja3k/OiBib29sZWFuO1xyXG4gIEBJbnB1dCgnY2F0ZWdvcnlIZWFkZXInKSBjYXRlZ29yeUhlYWRlcj86IGJvb2xlYW5cclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBlbDogRWxlbWVudFJlZixcclxuICAgIHByaXZhdGUgcm91dGVyOiBSb3V0ZXJcclxuICApIHsgfVxyXG5cclxuXHJcblxyXG5cclxuICBuZ09uQ2hhbmdlcygpIHtcclxuICAgIGlmICh0aGlzLnNpbXBvU3RpY2t5KSB7XHJcbiAgICAgIHRoaXMuZWwubmF0aXZlRWxlbWVudC5zdHlsZS5zZXRQcm9wZXJ0eShcInBvc2l0aW9uXCIsIFwiZml4ZWRcIik7XHJcbiAgICAgIHRoaXMuZWwubmF0aXZlRWxlbWVudC5zdHlsZS5zZXRQcm9wZXJ0eShcInRvcFwiLCBcIjBweFwiKTtcclxuICAgICAgdGhpcy5lbC5uYXRpdmVFbGVtZW50LnN0eWxlLnNldFByb3BlcnR5KFwibGVmdFwiLCAnMHB4JylcclxuICAgICAgaWYgKGxvY2FsU3RvcmFnZS5nZXRJdGVtKCdSRVFVRVNUX0ZST00nKSA9PSAnVVNFUicpXHJcbiAgICAgICAgdGhpcy5lbC5uYXRpdmVFbGVtZW50LnN0eWxlLnNldFByb3BlcnR5KFwiei1pbmRleFwiLCBcIjEwMDAwMDAyXCIpXHJcbiAgICAgIGVsc2Uge1xyXG4gICAgICAgIGxldCB1cmwgPSB0aGlzLnJvdXRlci51cmxcclxuICAgICAgICB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQuc3R5bGUuc2V0UHJvcGVydHkoXCJ6LWluZGV4XCIsIFwiMTA4XCIpXHJcbiAgICAgICAgaWYgKHVybC5pbmNsdWRlcygnd2Vic2l0ZS1lZGl0b3InKSlcclxuICAgICAgICAgIHRoaXMuZWwubmF0aXZlRWxlbWVudC5zdHlsZS5zZXRQcm9wZXJ0eShcIm1hcmdpbi10b3BcIiwgXCI0NXB4XCIpXHJcbiAgICAgICAgZWxzZSBpZiAodXJsLmluY2x1ZGVzKCd2My1nZW5lcmF0b3InKSlcclxuICAgICAgICAgIHRoaXMuZWwubmF0aXZlRWxlbWVudC5zdHlsZS5zZXRQcm9wZXJ0eShcIm1hcmdpbi10b3BcIiwgXCI3MHB4XCIpXHJcbiAgICAgICAgZWxzZVxyXG4gICAgICAgICAgdGhpcy5lbC5uYXRpdmVFbGVtZW50LnN0eWxlLnNldFByb3BlcnR5KFwibWFyZ2luLXRvcFwiLCBcIjBweFwiKVxyXG4gICAgICB9XHJcbiAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xyXG4gICAgICAgIGlmICh3aW5kb3cuaW5uZXJXaWR0aCA+IDQ3NSkge1xyXG4gICAgICAgICAgdGhpcy5hZGRQYXJlbnRNYXJnaW4oKTtcclxuICAgICAgICB9XHJcbiAgICAgIH0sIDApO1xyXG4gICAgfSBlbHNlIHtcclxuICAgICAgdGhpcy5lbC5uYXRpdmVFbGVtZW50LnN0eWxlLnNldFByb3BlcnR5KFwicG9zaXRpb25cIiwgXCJyZWxhdGl2ZVwiKTtcclxuICAgICAgdGhpcy5yZW1vdmVQYXJlbnRNYXJnaW4oKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHByaXZhdGUgcmVzaXplT2JzZXJ2ZXIhOiBSZXNpemVPYnNlcnZlcjtcclxuICBuZ0FmdGVyVmlld0luaXQoKSB7XHJcbiAgICB0aGlzLnJlc2l6ZU9ic2VydmVyID0gbmV3IFJlc2l6ZU9ic2VydmVyKCgpID0+IHtcclxuICAgICAgc2V0VGltZW91dCgoKSA9PiB7XHJcbiAgICAgICAgaWYgKHdpbmRvdy5pbm5lcldpZHRoID4gNDc1ICYmIHRoaXMuc2ltcG9TdGlja3kpIHtcclxuICAgICAgICAgIHRoaXMuYWRkUGFyZW50TWFyZ2luKCk7XHJcbiAgICAgICAgfVxyXG4gICAgICB9LCAwKTtcclxuICAgIH0pO1xyXG4gICAgdGhpcy5yZXNpemVPYnNlcnZlci5vYnNlcnZlKHRoaXMuZWwubmF0aXZlRWxlbWVudCk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGFkZFBhcmVudE1hcmdpbigpIHtcclxuICAgIGxldCBoZWFkZXJIZWlnaHQgPSB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQub2Zmc2V0SGVpZ2h0O1xyXG4gICAgY29uc3QgcGFyZW50ID0gdGhpcy5lbC5uYXRpdmVFbGVtZW50LnBhcmVudEVsZW1lbnQ7XHJcbiAgICBpZiAocGFyZW50ICYmIGhlYWRlckhlaWdodCA+IDApIHtcclxuICAgICAgcGFyZW50LnN0eWxlLm1hcmdpbkJvdHRvbSA9IChoZWFkZXJIZWlnaHQpICsgJ3B4JztcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHByaXZhdGUgcmVtb3ZlUGFyZW50TWFyZ2luKCkge1xyXG4gICAgY29uc3QgcGFyZW50ID0gdGhpcy5lbC5uYXRpdmVFbGVtZW50LnBhcmVudEVsZW1lbnQ7XHJcbiAgICBpZiAocGFyZW50KSB7XHJcbiAgICAgIHBhcmVudC5zdHlsZS5tYXJnaW5Cb3R0b20gPSAnMHB4JztcclxuICAgIH1cclxuICB9XHJcblxyXG4gIG5nT25EZXN0cm95KCkge1xyXG4gICAgdGhpcy5yZW1vdmVQYXJlbnRNYXJnaW4oKTtcclxuICB9XHJcbn0iXX0=
90
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sticky-directive.js","sourceRoot":"","sources":["../../../../../projects/simpo-ui/src/lib/directive/sticky-directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Inject, Input, PLATFORM_ID } from '@angular/core';\r\nimport { isPlatformBrowser } from '@angular/common';\r\nimport { Router } from '@angular/router';\r\n\r\n@Directive({\r\n  selector: '[simpoSticky]',\r\n  standalone: true\r\n})\r\nexport class SimpoStickyDirective {\r\n  @Input('simpoSticky') simpoSticky?: boolean;\r\n  @Input('categoryHeader') categoryHeader?: boolean\r\n  private isBrowser = false;\r\n  private resizeObserver?: ResizeObserver;\r\n\r\n  constructor(private el: ElementRef,\r\n    private router: Router,\r\n    @Inject(PLATFORM_ID) private platformId: object\r\n  ) {\r\n    this.isBrowser = isPlatformBrowser(this.platformId);\r\n  }\r\n\r\n\r\n\r\n\r\n  ngOnChanges() {\r\n    if (this.simpoSticky) {\r\n      this.el.nativeElement.style.setProperty(\"position\", \"fixed\");\r\n      this.el.nativeElement.style.setProperty(\"top\", \"0px\");\r\n      this.el.nativeElement.style.setProperty(\"left\", '0px')\r\n      if (this.isBrowser && localStorage.getItem('REQUEST_FROM') == 'USER')\r\n        this.el.nativeElement.style.setProperty(\"z-index\", \"10000002\")\r\n      else {\r\n        let url = this.router.url\r\n        this.el.nativeElement.style.setProperty(\"z-index\", \"108\")\r\n        if (url.includes('website-editor'))\r\n          this.el.nativeElement.style.setProperty(\"margin-top\", \"45px\")\r\n        else if (url.includes('v3-generator'))\r\n          this.el.nativeElement.style.setProperty(\"margin-top\", \"70px\")\r\n        else\r\n          this.el.nativeElement.style.setProperty(\"margin-top\", \"0px\")\r\n      }\r\n      setTimeout(() => {\r\n        if (this.isBrowser && window.innerWidth > 475) {\r\n          this.addParentMargin();\r\n        }\r\n      }, 0);\r\n    } else {\r\n      this.el.nativeElement.style.setProperty(\"position\", \"relative\");\r\n      this.removeParentMargin();\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    if (!this.isBrowser || typeof ResizeObserver === 'undefined') return;\r\n\r\n    this.resizeObserver = new ResizeObserver(() => {\r\n      setTimeout(() => {\r\n        if (window.innerWidth > 475 && this.simpoSticky) {\r\n          this.addParentMargin();\r\n        }\r\n      }, 0);\r\n    });\r\n    this.resizeObserver.observe(this.el.nativeElement);\r\n  }\r\n\r\n  private addParentMargin() {\r\n    const nativeElement = this.el.nativeElement as HTMLElement;\r\n    let headerHeight = Math.ceil(nativeElement.getBoundingClientRect().height || nativeElement.offsetHeight || 0);\r\n    const parent = this.el.nativeElement.parentElement;\r\n    if (parent && headerHeight > 0) {\r\n      parent.style.marginBottom = (headerHeight) + 'px';\r\n    }\r\n  }\r\n\r\n  private removeParentMargin() {\r\n    const parent = this.el.nativeElement.parentElement;\r\n    if (parent) {\r\n      parent.style.marginBottom = '0px';\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.resizeObserver?.disconnect();\r\n    this.removeParentMargin();\r\n  }\r\n}\r\n"]}
@@ -88,7 +88,7 @@ export class BelowImageCardComponent {
88
88
  }
89
89
  }
90
90
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BelowImageCardComponent, deps: [{ token: i1.EventsService }], target: i0.ɵɵFactoryTarget.Component }); }
91
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: BelowImageCardComponent, isStandalone: true, selector: "simpo-below-image-card", inputs: { data: "data", styles: "styles", content: "content", componentId: "componentId", button: "button", edit: "edit", positionLayout: "positionLayout" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"card-container\"\r\n (click)=\"(content?.display?.showLink && content?.display?.linkType === 'List Item' ? redirectTo() : '')\"\r\n [ngClass]=\"{'box-shadow' : content.display.showCard, 'px-0 py-0': styles?.borderLessImage && !content?.display?.showIcon ,'py-14' : content?.display?.showCardBackground && !styles?.borderLessImage}\"\r\n [style.background]=\"getBackground()\" [id]=\"data?.id\" [simpoCorner]=\"styles?.corners\"\r\n [simpoTranslateOnhover]=\"content?.display?.showHoverEffect\" [backgroundColor]=\"styles?.background?.color\"\r\n [simpoSetDynamicBackground]=\"content?.display?.showCardBackground\" [class]=\"getAlignment()\">\r\n\r\n <ng-container *ngIf=\"positionLayout == 'bottom'\">\r\n <ng-container *ngTemplateOutlet=\"headingDescription\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"iconAndImage\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"positionLayout == 'top'\">\r\n <ng-container *ngTemplateOutlet=\"iconAndImage\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"headingDescription\"></ng-container>\r\n </ng-container>\r\n\r\n <div class=\"ptb-1 w-100\">\r\n <div *ngIf=\"content.display.showLink && content.display.linkType === 'Button'\" class=\"card-button\"\r\n [simpoHoverAnimation]=\"getContentAnimation()\">\r\n <app-button-element [buttonContent]=\"data.button\" [buttonStyle]=\"button?.styles\"\r\n [buttonId]=\"button ? button.id : ''\" [sectionId]=\"componentId\" [color]=\"styles?.background?.accentColor\"\r\n [backgroundInfo]=\"styles?.background\" [edit]=\"edit\">\r\n </app-button-element>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #iconAndImage>\r\n <img loading=\"lazy\" [src]=\"data.image.url\" [alt]=\"data.image.altText\" [simpoImageDirective]=\"styles?.image\"\r\n [attr.simpoObjectPosition]=\"styles?.image?.fit !== 'contain' ? data.image?.position : null\"\r\n [simpoCorner]=\"styles?.corners\" [id]=\"componentId\" class=\"w-100\" *ngIf=\"content.display.showImage\"\r\n [appImageEditor]=\"edit || false\" [imageData]=\"data.image\" [sectionId]=\"data?.id\"\r\n [simpoObjectPosition]=\"data?.image?.position\" [class]=\"data?.id+data.image.id\">\r\n\r\n\r\n <ng-container *ngIf=\"content.display.showIcon && (data.icon.url.includes('.png') || data.icon.url.includes('.svg'))\">\r\n <div [simpoCorner]=\"styles?.corners\" [class.hovering-effect]=\"content?.display?.showHoverEffect\" [id]=\"componentId\"\r\n class=\"logo-img d-flex justify-content-center align-items-center\"\r\n [style.background]=\"data?.icon?.showBackground ? getIconBackground : 'transparent'\"\r\n [appImageEditor]=\"edit || false\" [iconData]=\"data.icon\" [sectionId]=\"componentId\"\r\n [showIcon]=\"content.display.showIcon\">\r\n <div [id]=\"componentId\" [iconId]=\"componentId + data?.icon?.id\" [simpoIconDirective]=\"data?.icon\"\r\n class=\"w-65 h-100\" [class.w-100]=\"!data?.icon?.showBackground\">\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <img loading=\"lazy\" class=\"logo-img\" [src]=\"data.icon.url\" [appImageEditor]=\"edit || false\" [iconData]=\"data.icon\"\r\n [sectionId]=\"componentId\" [showIcon]=\"content.display.showIcon\"\r\n *ngIf=\"content.display.showIcon && !data.icon.url.includes('.png') && !data.icon.url.includes('.svg')\"\r\n class=\"logo-img\" [simpoCorner]=\"styles?.corners\" [id]=\"data?.id\"\r\n [class.hovering-effect]=\"content?.display?.showHoverEffect\">\r\n</ng-template>\r\n\r\n<ng-template #headingDescription>\r\n\r\n <div class=\"ptb-1 content-side w-100\">\r\n <div class=\"heading-medium mb-1\" *ngIf=\"content.display.showHeading\">\r\n <div class=\"d-flex justify-content-between align-items-start\">\r\n <simpo-text-editor [(value)]=\"data.inputText[0].value\" [editable]=\"edit || false\">\r\n </simpo-text-editor>\r\n <div class=\"indexing\" *ngIf=\"styles?.showIndexing\" [style.color]=\"styles?.background?.accentColor\"\r\n [style.background]=\"getGlassyBackground(styles?.background?.accentColor)\">\r\n 0{{ currentIndex }}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"body-desc\" *ngIf=\"content.display.showContent\">\r\n <simpo-text-editor [(value)]=\"data.inputText[01].value \" [editable]=\"edit || false\"></simpo-text-editor>\r\n </div>\r\n </div>\r\n</ng-template>", styles: [".w-100{width:100%}.card-container{display:flex;flex-direction:column;height:100%;position:relative}.card-inner{display:flex;flex-direction:column;width:100%}.justify-items-start{align-items:flex-start;text-align:left}.justify-items-end{align-items:flex-end;text-align:right}.justify-items-center{align-items:center;text-align:center}.content-side{display:flex;flex-direction:column;flex:1;padding:14px 18px}.card-button{margin-top:auto;padding-top:12px}.ptb-1{padding-top:1rem}.mb-1{margin-bottom:1rem!important}.box-shadow{box-shadow:0 10px 40px #0a32231a;padding:12px 20px;color:#000!important}.logo-img{width:70px;height:70px;margin-top:.25rem;margin:0 18px}.w-65{width:65%}.justify-items-start{justify-items:flex-start}.justify-items-end{justify-items:flex-end}.justify-items-center{justify-items:center}.indexing{font-size:14px;padding:6px 8px;border-radius:50px}@media screen and (max-width: 475px){.mt-4{margin-top:unset!important}.box-shadow{box-shadow:unset!important}}\n"], dependencies: [{ kind: "directive", type: ObjectPositionDirective, selector: "[simpoObjectPosition]", inputs: ["simpoObjectPosition"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: ImageDirectiveDirective, selector: "[simpoImageDirective]", inputs: ["simpoImageDirective"] }, { kind: "directive", type: CornerDirective, selector: "[simpoCorner]", inputs: ["simpoCorner"] }, { kind: "component", type: SimpoButtonComponent, selector: "app-button-element", inputs: ["buttonContent", "buttonStyle", "buttonId", "color", "sectionId", "edit", "backgroundInfo", "disabled", "loading", "isFullWidth"] }, { kind: "component", type: TextEditorComponent, selector: "simpo-text-editor", inputs: ["value", "editable", "sectionId", "label", "type"], outputs: ["valueChange"] }, { kind: "directive", type: ImageEditorDirective, selector: "[appImageEditor]", inputs: ["appImageEditor", "imageData", "sectionId", "showIcon", "iconData"] }, { kind: "directive", type: HoverAnimationDirective, selector: "[simpoHoverAnimation]", inputs: ["simpoHoverAnimation"] }, { kind: "directive", type: TranslateOnhoverDirective, selector: "[simpoTranslateOnhover]", inputs: ["simpoTranslateOnhover"] }, { kind: "directive", type: SetDynamicBackgroundDirective, selector: "[simpoSetDynamicBackground]", inputs: ["backgroundColor", "simpoSetDynamicBackground"] }, { kind: "directive", type: IconDirectiveDirective, selector: "[simpoIconDirective]", inputs: ["simpoIconDirective", "iconId"] }] }); }
91
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: BelowImageCardComponent, isStandalone: true, selector: "simpo-below-image-card", inputs: { data: "data", styles: "styles", content: "content", componentId: "componentId", button: "button", edit: "edit", positionLayout: "positionLayout" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"card-container\"\r\n (click)=\"(content?.display?.showLink && content?.display?.linkType === 'List Item' ? redirectTo() : '')\"\r\n [ngClass]=\"{'box-shadow' : content.display.showCard, 'px-0 py-0': styles?.borderLessImage && !content?.display?.showIcon ,'py-14' : content?.display?.showCardBackground && !styles?.borderLessImage}\"\r\n [style.background]=\"getBackground()\" [id]=\"data?.id\" [simpoCorner]=\"styles?.corners\"\r\n [simpoTranslateOnhover]=\"content?.display?.showHoverEffect\" [backgroundColor]=\"styles?.background?.color\"\r\n [simpoSetDynamicBackground]=\"content?.display?.showCardBackground\" [class]=\"getAlignment()\">\r\n\r\n <ng-container *ngIf=\"positionLayout == 'bottom'\">\r\n <ng-container *ngTemplateOutlet=\"headingDescription\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"iconAndImage\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"positionLayout == 'top'\">\r\n <ng-container *ngTemplateOutlet=\"iconAndImage\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"headingDescription\"></ng-container>\r\n </ng-container>\r\n\r\n <div class=\"ptb-1 w-100\">\r\n <div *ngIf=\"content.display.showLink && content.display.linkType === 'Button'\" class=\"card-button\"\r\n [simpoHoverAnimation]=\"getContentAnimation()\">\r\n <app-button-element [buttonContent]=\"data.button\" [buttonStyle]=\"button?.styles\"\r\n [buttonId]=\"button ? button.id : ''\" [sectionId]=\"componentId\" [color]=\"styles?.background?.accentColor\"\r\n [backgroundInfo]=\"styles?.background\" [edit]=\"edit\">\r\n </app-button-element>\r\n </div>\r\n </div>\r\n</div>\r\n<ng-template #iconAndImage>\r\n <img loading=\"lazy\" [src]=\"data.image.url\" [alt]=\"data.image.altText\" [simpoImageDirective]=\"styles?.image\"\r\n [attr.simpoObjectPosition]=\"styles?.image?.fit !== 'contain' ? data.image?.position : null\"\r\n [simpoCorner]=\"styles?.corners\" [id]=\"componentId\" class=\"w-100\" *ngIf=\"content.display.showImage\"\r\n [appImageEditor]=\"edit || false\" [imageData]=\"data.image\" [sectionId]=\"data?.id\"\r\n [simpoObjectPosition]=\"data?.image?.position\" [class]=\"data?.id+data.image.id\">\r\n\r\n\r\n <ng-container *ngIf=\"content.display.showIcon && (data.icon.url.includes('.png') || data.icon.url.includes('.svg'))\">\r\n <div [simpoCorner]=\"styles?.corners\" [class.hovering-effect]=\"content?.display?.showHoverEffect\" [id]=\"componentId\"\r\n class=\"logo-img d-flex justify-content-center align-items-center\"\r\n [style.background]=\"data?.icon?.showBackground ? getIconBackground : 'transparent'\"\r\n [appImageEditor]=\"edit || false\" [iconData]=\"data.icon\" [sectionId]=\"componentId\"\r\n [showIcon]=\"content.display.showIcon\">\r\n <div [id]=\"componentId\" [iconId]=\"componentId + data?.icon?.id\" [simpoIconDirective]=\"data?.icon\"\r\n class=\"w-65 h-100\" [class.w-100]=\"!data?.icon?.showBackground\">\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <img loading=\"lazy\" class=\"logo-img\" [src]=\"data.icon.url\" [appImageEditor]=\"edit || false\" [iconData]=\"data.icon\"\r\n [sectionId]=\"componentId\" [showIcon]=\"content.display.showIcon\"\r\n *ngIf=\"content.display.showIcon && !data.icon.url.includes('.png') && !data.icon.url.includes('.svg')\"\r\n class=\"logo-img\" [simpoCorner]=\"styles?.corners\" [id]=\"data?.id\"\r\n [class.hovering-effect]=\"content?.display?.showHoverEffect\">\r\n</ng-template>\r\n\r\n<ng-template #headingDescription>\r\n\r\n <div class=\"ptb-1 content-side w-100\">\r\n <div class=\"heading-medium mb-1\" *ngIf=\"content.display.showHeading\">\r\n <div class=\"d-flex justify-content-between align-items-start\">\r\n <simpo-text-editor [(value)]=\"data.inputText[0].value\" [editable]=\"edit || false\">\r\n </simpo-text-editor>\r\n <div class=\"indexing\" *ngIf=\"styles?.showIndexing\" [style.color]=\"styles?.background?.accentColor\"\r\n [style.background]=\"getGlassyBackground(styles?.background?.accentColor)\">\r\n 0{{ currentIndex }}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"body-desc\" *ngIf=\"content.display.showContent\">\r\n <simpo-text-editor [(value)]=\"data.inputText[01].value \" [editable]=\"edit || false\"></simpo-text-editor>\r\n </div>\r\n </div>\r\n</ng-template>", styles: [".w-100{width:100%}.card-container{display:flex;flex-direction:column;height:100%;position:relative}.card-inner{display:flex;flex-direction:column;width:100%}.justify-items-start{align-items:flex-start;text-align:left}.justify-items-end{align-items:flex-end;text-align:right}.justify-items-center{align-items:center;text-align:center}.content-side{display:flex;flex-direction:column;flex:1;padding:14px 18px}.card-button{margin-top:auto;padding-top:12px;padding-bottom:10px}.ptb-1{padding-top:1rem}.mb-1{margin-bottom:1rem!important}.box-shadow{box-shadow:0 10px 40px #0a32231a;padding:12px 20px;color:#000!important}.logo-img{width:70px;height:70px;margin-top:.25rem;margin:0 18px}.w-65{width:65%}.justify-items-start{justify-items:flex-start}.justify-items-end{justify-items:flex-end}.justify-items-center{justify-items:center}.indexing{font-size:14px;padding:6px 8px;border-radius:50px}@media screen and (max-width: 475px){.mt-4{margin-top:unset!important}}\n"], dependencies: [{ kind: "directive", type: ObjectPositionDirective, selector: "[simpoObjectPosition]", inputs: ["simpoObjectPosition"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: ImageDirectiveDirective, selector: "[simpoImageDirective]", inputs: ["simpoImageDirective"] }, { kind: "directive", type: CornerDirective, selector: "[simpoCorner]", inputs: ["simpoCorner"] }, { kind: "component", type: SimpoButtonComponent, selector: "app-button-element", inputs: ["buttonContent", "buttonStyle", "buttonId", "color", "sectionId", "edit", "backgroundInfo", "disabled", "loading", "isFullWidth"] }, { kind: "component", type: TextEditorComponent, selector: "simpo-text-editor", inputs: ["value", "editable", "sectionId", "label", "type"], outputs: ["valueChange"] }, { kind: "directive", type: ImageEditorDirective, selector: "[appImageEditor]", inputs: ["appImageEditor", "imageData", "sectionId", "showIcon", "iconData"] }, { kind: "directive", type: HoverAnimationDirective, selector: "[simpoHoverAnimation]", inputs: ["simpoHoverAnimation"] }, { kind: "directive", type: TranslateOnhoverDirective, selector: "[simpoTranslateOnhover]", inputs: ["simpoTranslateOnhover"] }, { kind: "directive", type: SetDynamicBackgroundDirective, selector: "[simpoSetDynamicBackground]", inputs: ["backgroundColor", "simpoSetDynamicBackground"] }, { kind: "directive", type: IconDirectiveDirective, selector: "[simpoIconDirective]", inputs: ["simpoIconDirective", "iconId"] }] }); }
92
92
  }
93
93
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BelowImageCardComponent, decorators: [{
94
94
  type: Component,
@@ -105,7 +105,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
105
105
  SetDynamicBackgroundDirective,
106
106
  IconDirectiveDirective,
107
107
  CdkDragPlaceholder
108
- ], template: "<div class=\"card-container\"\r\n (click)=\"(content?.display?.showLink && content?.display?.linkType === 'List Item' ? redirectTo() : '')\"\r\n [ngClass]=\"{'box-shadow' : content.display.showCard, 'px-0 py-0': styles?.borderLessImage && !content?.display?.showIcon ,'py-14' : content?.display?.showCardBackground && !styles?.borderLessImage}\"\r\n [style.background]=\"getBackground()\" [id]=\"data?.id\" [simpoCorner]=\"styles?.corners\"\r\n [simpoTranslateOnhover]=\"content?.display?.showHoverEffect\" [backgroundColor]=\"styles?.background?.color\"\r\n [simpoSetDynamicBackground]=\"content?.display?.showCardBackground\" [class]=\"getAlignment()\">\r\n\r\n <ng-container *ngIf=\"positionLayout == 'bottom'\">\r\n <ng-container *ngTemplateOutlet=\"headingDescription\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"iconAndImage\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"positionLayout == 'top'\">\r\n <ng-container *ngTemplateOutlet=\"iconAndImage\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"headingDescription\"></ng-container>\r\n </ng-container>\r\n\r\n <div class=\"ptb-1 w-100\">\r\n <div *ngIf=\"content.display.showLink && content.display.linkType === 'Button'\" class=\"card-button\"\r\n [simpoHoverAnimation]=\"getContentAnimation()\">\r\n <app-button-element [buttonContent]=\"data.button\" [buttonStyle]=\"button?.styles\"\r\n [buttonId]=\"button ? button.id : ''\" [sectionId]=\"componentId\" [color]=\"styles?.background?.accentColor\"\r\n [backgroundInfo]=\"styles?.background\" [edit]=\"edit\">\r\n </app-button-element>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #iconAndImage>\r\n <img loading=\"lazy\" [src]=\"data.image.url\" [alt]=\"data.image.altText\" [simpoImageDirective]=\"styles?.image\"\r\n [attr.simpoObjectPosition]=\"styles?.image?.fit !== 'contain' ? data.image?.position : null\"\r\n [simpoCorner]=\"styles?.corners\" [id]=\"componentId\" class=\"w-100\" *ngIf=\"content.display.showImage\"\r\n [appImageEditor]=\"edit || false\" [imageData]=\"data.image\" [sectionId]=\"data?.id\"\r\n [simpoObjectPosition]=\"data?.image?.position\" [class]=\"data?.id+data.image.id\">\r\n\r\n\r\n <ng-container *ngIf=\"content.display.showIcon && (data.icon.url.includes('.png') || data.icon.url.includes('.svg'))\">\r\n <div [simpoCorner]=\"styles?.corners\" [class.hovering-effect]=\"content?.display?.showHoverEffect\" [id]=\"componentId\"\r\n class=\"logo-img d-flex justify-content-center align-items-center\"\r\n [style.background]=\"data?.icon?.showBackground ? getIconBackground : 'transparent'\"\r\n [appImageEditor]=\"edit || false\" [iconData]=\"data.icon\" [sectionId]=\"componentId\"\r\n [showIcon]=\"content.display.showIcon\">\r\n <div [id]=\"componentId\" [iconId]=\"componentId + data?.icon?.id\" [simpoIconDirective]=\"data?.icon\"\r\n class=\"w-65 h-100\" [class.w-100]=\"!data?.icon?.showBackground\">\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <img loading=\"lazy\" class=\"logo-img\" [src]=\"data.icon.url\" [appImageEditor]=\"edit || false\" [iconData]=\"data.icon\"\r\n [sectionId]=\"componentId\" [showIcon]=\"content.display.showIcon\"\r\n *ngIf=\"content.display.showIcon && !data.icon.url.includes('.png') && !data.icon.url.includes('.svg')\"\r\n class=\"logo-img\" [simpoCorner]=\"styles?.corners\" [id]=\"data?.id\"\r\n [class.hovering-effect]=\"content?.display?.showHoverEffect\">\r\n</ng-template>\r\n\r\n<ng-template #headingDescription>\r\n\r\n <div class=\"ptb-1 content-side w-100\">\r\n <div class=\"heading-medium mb-1\" *ngIf=\"content.display.showHeading\">\r\n <div class=\"d-flex justify-content-between align-items-start\">\r\n <simpo-text-editor [(value)]=\"data.inputText[0].value\" [editable]=\"edit || false\">\r\n </simpo-text-editor>\r\n <div class=\"indexing\" *ngIf=\"styles?.showIndexing\" [style.color]=\"styles?.background?.accentColor\"\r\n [style.background]=\"getGlassyBackground(styles?.background?.accentColor)\">\r\n 0{{ currentIndex }}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"body-desc\" *ngIf=\"content.display.showContent\">\r\n <simpo-text-editor [(value)]=\"data.inputText[01].value \" [editable]=\"edit || false\"></simpo-text-editor>\r\n </div>\r\n </div>\r\n</ng-template>", styles: [".w-100{width:100%}.card-container{display:flex;flex-direction:column;height:100%;position:relative}.card-inner{display:flex;flex-direction:column;width:100%}.justify-items-start{align-items:flex-start;text-align:left}.justify-items-end{align-items:flex-end;text-align:right}.justify-items-center{align-items:center;text-align:center}.content-side{display:flex;flex-direction:column;flex:1;padding:14px 18px}.card-button{margin-top:auto;padding-top:12px}.ptb-1{padding-top:1rem}.mb-1{margin-bottom:1rem!important}.box-shadow{box-shadow:0 10px 40px #0a32231a;padding:12px 20px;color:#000!important}.logo-img{width:70px;height:70px;margin-top:.25rem;margin:0 18px}.w-65{width:65%}.justify-items-start{justify-items:flex-start}.justify-items-end{justify-items:flex-end}.justify-items-center{justify-items:center}.indexing{font-size:14px;padding:6px 8px;border-radius:50px}@media screen and (max-width: 475px){.mt-4{margin-top:unset!important}.box-shadow{box-shadow:unset!important}}\n"] }]
108
+ ], template: "<div class=\"card-container\"\r\n (click)=\"(content?.display?.showLink && content?.display?.linkType === 'List Item' ? redirectTo() : '')\"\r\n [ngClass]=\"{'box-shadow' : content.display.showCard, 'px-0 py-0': styles?.borderLessImage && !content?.display?.showIcon ,'py-14' : content?.display?.showCardBackground && !styles?.borderLessImage}\"\r\n [style.background]=\"getBackground()\" [id]=\"data?.id\" [simpoCorner]=\"styles?.corners\"\r\n [simpoTranslateOnhover]=\"content?.display?.showHoverEffect\" [backgroundColor]=\"styles?.background?.color\"\r\n [simpoSetDynamicBackground]=\"content?.display?.showCardBackground\" [class]=\"getAlignment()\">\r\n\r\n <ng-container *ngIf=\"positionLayout == 'bottom'\">\r\n <ng-container *ngTemplateOutlet=\"headingDescription\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"iconAndImage\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"positionLayout == 'top'\">\r\n <ng-container *ngTemplateOutlet=\"iconAndImage\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"headingDescription\"></ng-container>\r\n </ng-container>\r\n\r\n <div class=\"ptb-1 w-100\">\r\n <div *ngIf=\"content.display.showLink && content.display.linkType === 'Button'\" class=\"card-button\"\r\n [simpoHoverAnimation]=\"getContentAnimation()\">\r\n <app-button-element [buttonContent]=\"data.button\" [buttonStyle]=\"button?.styles\"\r\n [buttonId]=\"button ? button.id : ''\" [sectionId]=\"componentId\" [color]=\"styles?.background?.accentColor\"\r\n [backgroundInfo]=\"styles?.background\" [edit]=\"edit\">\r\n </app-button-element>\r\n </div>\r\n </div>\r\n</div>\r\n<ng-template #iconAndImage>\r\n <img loading=\"lazy\" [src]=\"data.image.url\" [alt]=\"data.image.altText\" [simpoImageDirective]=\"styles?.image\"\r\n [attr.simpoObjectPosition]=\"styles?.image?.fit !== 'contain' ? data.image?.position : null\"\r\n [simpoCorner]=\"styles?.corners\" [id]=\"componentId\" class=\"w-100\" *ngIf=\"content.display.showImage\"\r\n [appImageEditor]=\"edit || false\" [imageData]=\"data.image\" [sectionId]=\"data?.id\"\r\n [simpoObjectPosition]=\"data?.image?.position\" [class]=\"data?.id+data.image.id\">\r\n\r\n\r\n <ng-container *ngIf=\"content.display.showIcon && (data.icon.url.includes('.png') || data.icon.url.includes('.svg'))\">\r\n <div [simpoCorner]=\"styles?.corners\" [class.hovering-effect]=\"content?.display?.showHoverEffect\" [id]=\"componentId\"\r\n class=\"logo-img d-flex justify-content-center align-items-center\"\r\n [style.background]=\"data?.icon?.showBackground ? getIconBackground : 'transparent'\"\r\n [appImageEditor]=\"edit || false\" [iconData]=\"data.icon\" [sectionId]=\"componentId\"\r\n [showIcon]=\"content.display.showIcon\">\r\n <div [id]=\"componentId\" [iconId]=\"componentId + data?.icon?.id\" [simpoIconDirective]=\"data?.icon\"\r\n class=\"w-65 h-100\" [class.w-100]=\"!data?.icon?.showBackground\">\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <img loading=\"lazy\" class=\"logo-img\" [src]=\"data.icon.url\" [appImageEditor]=\"edit || false\" [iconData]=\"data.icon\"\r\n [sectionId]=\"componentId\" [showIcon]=\"content.display.showIcon\"\r\n *ngIf=\"content.display.showIcon && !data.icon.url.includes('.png') && !data.icon.url.includes('.svg')\"\r\n class=\"logo-img\" [simpoCorner]=\"styles?.corners\" [id]=\"data?.id\"\r\n [class.hovering-effect]=\"content?.display?.showHoverEffect\">\r\n</ng-template>\r\n\r\n<ng-template #headingDescription>\r\n\r\n <div class=\"ptb-1 content-side w-100\">\r\n <div class=\"heading-medium mb-1\" *ngIf=\"content.display.showHeading\">\r\n <div class=\"d-flex justify-content-between align-items-start\">\r\n <simpo-text-editor [(value)]=\"data.inputText[0].value\" [editable]=\"edit || false\">\r\n </simpo-text-editor>\r\n <div class=\"indexing\" *ngIf=\"styles?.showIndexing\" [style.color]=\"styles?.background?.accentColor\"\r\n [style.background]=\"getGlassyBackground(styles?.background?.accentColor)\">\r\n 0{{ currentIndex }}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"body-desc\" *ngIf=\"content.display.showContent\">\r\n <simpo-text-editor [(value)]=\"data.inputText[01].value \" [editable]=\"edit || false\"></simpo-text-editor>\r\n </div>\r\n </div>\r\n</ng-template>", styles: [".w-100{width:100%}.card-container{display:flex;flex-direction:column;height:100%;position:relative}.card-inner{display:flex;flex-direction:column;width:100%}.justify-items-start{align-items:flex-start;text-align:left}.justify-items-end{align-items:flex-end;text-align:right}.justify-items-center{align-items:center;text-align:center}.content-side{display:flex;flex-direction:column;flex:1;padding:14px 18px}.card-button{margin-top:auto;padding-top:12px;padding-bottom:10px}.ptb-1{padding-top:1rem}.mb-1{margin-bottom:1rem!important}.box-shadow{box-shadow:0 10px 40px #0a32231a;padding:12px 20px;color:#000!important}.logo-img{width:70px;height:70px;margin-top:.25rem;margin:0 18px}.w-65{width:65%}.justify-items-start{justify-items:flex-start}.justify-items-end{justify-items:flex-end}.justify-items-center{justify-items:center}.indexing{font-size:14px;padding:6px 8px;border-radius:50px}@media screen and (max-width: 475px){.mt-4{margin-top:unset!important}}\n"] }]
109
109
  }], ctorParameters: () => [{ type: i1.EventsService }], propDecorators: { data: [{
110
110
  type: Input
111
111
  }], styles: [{
@@ -121,4 +121,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
121
121
  }], positionLayout: [{
122
122
  type: Input
123
123
  }] } });
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"below-image-card.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/elements/below-image-card/below-image-card.component.ts","../../../../../../projects/simpo-ui/src/lib/elements/below-image-card/below-image-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, Input } from '@angular/core';\r\nimport { CornerDirective } from './../../directive/corner-directive';\r\nimport { ImageDirectiveDirective } from './../../directive/image-directive.directive';\r\nimport { SimpoButtonComponent } from '../simpo-button/simpo-button.component';\r\nimport { ButtonModel } from '../../styles/style.model';\r\nimport { ObjectPositionDirective } from '../../directive/image-position.directive';\r\nimport { EventsService } from '../../services/events.service';\r\nimport { ImageContainerDirective } from '../../directive/image-container.directive';\r\nimport { TextEditorComponent } from '../text-editor/text-editor.component';\r\nimport { ImageEditorDirective } from '../../directive/image-editor.directive';\r\nimport { HoverAnimationDirective } from '../../directive/hover-animation.directive';\r\nimport { TranslateOnhoverDirective } from '../../directive/translate-onhover.directive';\r\nimport { SetDynamicBackgroundDirective } from '../../directive/set-dynamic-background.directive';\r\nimport { SimpoBorderlessDirective } from '../../directive/borderlessImage.directive';\r\nimport { IconDirectiveDirective } from '../../directive/icon-directive.directive';\r\nimport { GradientDirection } from '../../styles';\r\nimport { CdkDragPlaceholder } from \"@angular/cdk/drag-drop\";\r\n\r\n\r\n@Component({\r\n  selector: 'simpo-below-image-card',\r\n  standalone: true,\r\n  imports: [\r\n    ObjectPositionDirective,\r\n    CommonModule,\r\n    ImageDirectiveDirective,\r\n    CornerDirective,\r\n    SimpoButtonComponent,\r\n    TextEditorComponent,\r\n    ImageEditorDirective,\r\n    HoverAnimationDirective,\r\n    TranslateOnhoverDirective,\r\n    SetDynamicBackgroundDirective,\r\n    IconDirectiveDirective,\r\n    CdkDragPlaceholder\r\n  ],\r\n  templateUrl: './below-image-card.component.html',\r\n  styleUrl: './below-image-card.component.css'\r\n})\r\nexport class BelowImageCardComponent {\r\n\r\n  @Input() data: any;\r\n  @Input() styles: any;\r\n  @Input() content: any;\r\n  @Input() componentId?: string;\r\n  @Input() button?: ButtonModel;\r\n  @Input() edit?: boolean;\r\n  @Input() positionLayout?: string;\r\n  allContents: any[] = [];\r\n  currentIndex = 0\r\n  counter = 0;\r\n\r\n  constructor(private _eventService: EventsService) { }\r\n  static counter = 0;\r\n\r\n  ngOnInit() {\r\n    this.currentIndex = this.getNextIndex();\r\n  }\r\n\r\n  getNextIndex(): number {\r\n    BelowImageCardComponent.counter++;\r\n    return BelowImageCardComponent.counter;\r\n  }\r\n\r\n  getGlassyBackground(color: any) {\r\n    return `rgba(${this.hexToRgb(color)}, 0.1)`;\r\n  }\r\n\r\n  hexToRgb(hex: string) {\r\n    const bigint = parseInt(hex.slice(1), 16);\r\n    const r = (bigint >> 16) & 255;\r\n    const g = (bigint >> 8) & 255;\r\n    const b = bigint & 255;\r\n\r\n    return `${r}, ${g}, ${b}`;\r\n  }\r\n\r\n  redirectTo() {\r\n    this._eventService.buttonRedirection.emit({ data: this.data.button });\r\n  }\r\n  get getAspectRatio() {\r\n    return { ...this.styles.image };\r\n  }\r\n  getContentAnimation() {\r\n    return { contentAnimation: this.styles?.contentAnimation }\r\n  }\r\n\r\n  get getIconStyls() {\r\n    return this.data?.icon\r\n  }\r\n\r\n  ngOnChanges() {\r\n    // console.log('Below Image Card Data', this.data);\r\n  }\r\n  getAlignment() {\r\n    switch (this.styles?.layout?.align) {\r\n      case 'left':\r\n        return 'justify-items-start';\r\n      case 'right':\r\n        return 'justify-items-end';\r\n      case 'center':\r\n        return 'justify-items-center';\r\n      default:\r\n        return 'justify-items-start';\r\n    }\r\n  }\r\n\r\n  getBackground() {\r\n    if (this.content.display.showCard) {\r\n      if (this.data?.background?.backgroundType === 'Gradient') {\r\n        const direction = GradientDirection[this.data?.background?.backgroundGradientDirection as unknown as keyof typeof GradientDirection || GradientDirection.DOWN];\r\n        return `linear-gradient(${direction}, ${this.data?.background?.color}, ${this.data?.background?.secondaryColor})`;\r\n      }\r\n      else {\r\n        return this.data?.background?.color\r\n      }\r\n    }\r\n  }\r\n  get getIconBackground() {\r\n    if (this.data?.icon?.backgroundType === 'Gradient') {\r\n      const direction = GradientDirection[this.data?.icon?.backgroundGradientDirection as unknown as keyof typeof GradientDirection || GradientDirection.DOWN];\r\n      return `linear-gradient(${direction}, ${this.data?.icon?.backgroundColor}, ${this.data?.icon?.secondaryColor})`;\r\n    }\r\n    else {\r\n      return this.data?.icon?.backgroundColor\r\n    }\r\n  }\r\n\r\n\r\n}\r\n","<div class=\"card-container\"\r\n  (click)=\"(content?.display?.showLink && content?.display?.linkType === 'List Item' ? redirectTo() : '')\"\r\n  [ngClass]=\"{'box-shadow' : content.display.showCard, 'px-0 py-0': styles?.borderLessImage && !content?.display?.showIcon ,'py-14' : content?.display?.showCardBackground && !styles?.borderLessImage}\"\r\n  [style.background]=\"getBackground()\" [id]=\"data?.id\" [simpoCorner]=\"styles?.corners\"\r\n  [simpoTranslateOnhover]=\"content?.display?.showHoverEffect\" [backgroundColor]=\"styles?.background?.color\"\r\n  [simpoSetDynamicBackground]=\"content?.display?.showCardBackground\" [class]=\"getAlignment()\">\r\n\r\n  <ng-container *ngIf=\"positionLayout == 'bottom'\">\r\n    <ng-container *ngTemplateOutlet=\"headingDescription\"></ng-container>\r\n    <ng-container *ngTemplateOutlet=\"iconAndImage\"></ng-container>\r\n  </ng-container>\r\n\r\n  <ng-container *ngIf=\"positionLayout == 'top'\">\r\n    <ng-container *ngTemplateOutlet=\"iconAndImage\"></ng-container>\r\n    <ng-container *ngTemplateOutlet=\"headingDescription\"></ng-container>\r\n  </ng-container>\r\n\r\n  <div class=\"ptb-1 w-100\">\r\n    <div *ngIf=\"content.display.showLink && content.display.linkType === 'Button'\" class=\"card-button\"\r\n      [simpoHoverAnimation]=\"getContentAnimation()\">\r\n      <app-button-element [buttonContent]=\"data.button\" [buttonStyle]=\"button?.styles\"\r\n        [buttonId]=\"button ? button.id : ''\" [sectionId]=\"componentId\" [color]=\"styles?.background?.accentColor\"\r\n        [backgroundInfo]=\"styles?.background\" [edit]=\"edit\">\r\n      </app-button-element>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #iconAndImage>\r\n  <img loading=\"lazy\" [src]=\"data.image.url\" [alt]=\"data.image.altText\" [simpoImageDirective]=\"styles?.image\"\r\n    [attr.simpoObjectPosition]=\"styles?.image?.fit !== 'contain' ? data.image?.position : null\"\r\n    [simpoCorner]=\"styles?.corners\" [id]=\"componentId\" class=\"w-100\" *ngIf=\"content.display.showImage\"\r\n    [appImageEditor]=\"edit || false\" [imageData]=\"data.image\" [sectionId]=\"data?.id\"\r\n    [simpoObjectPosition]=\"data?.image?.position\" [class]=\"data?.id+data.image.id\">\r\n\r\n\r\n  <ng-container *ngIf=\"content.display.showIcon && (data.icon.url.includes('.png') || data.icon.url.includes('.svg'))\">\r\n    <div [simpoCorner]=\"styles?.corners\" [class.hovering-effect]=\"content?.display?.showHoverEffect\" [id]=\"componentId\"\r\n      class=\"logo-img d-flex justify-content-center align-items-center\"\r\n      [style.background]=\"data?.icon?.showBackground ? getIconBackground : 'transparent'\"\r\n      [appImageEditor]=\"edit || false\" [iconData]=\"data.icon\" [sectionId]=\"componentId\"\r\n      [showIcon]=\"content.display.showIcon\">\r\n      <div [id]=\"componentId\" [iconId]=\"componentId + data?.icon?.id\" [simpoIconDirective]=\"data?.icon\"\r\n        class=\"w-65 h-100\" [class.w-100]=\"!data?.icon?.showBackground\">\r\n      </div>\r\n    </div>\r\n  </ng-container>\r\n\r\n  <img loading=\"lazy\" class=\"logo-img\" [src]=\"data.icon.url\" [appImageEditor]=\"edit || false\" [iconData]=\"data.icon\"\r\n    [sectionId]=\"componentId\" [showIcon]=\"content.display.showIcon\"\r\n    *ngIf=\"content.display.showIcon && !data.icon.url.includes('.png') && !data.icon.url.includes('.svg')\"\r\n    class=\"logo-img\" [simpoCorner]=\"styles?.corners\" [id]=\"data?.id\"\r\n    [class.hovering-effect]=\"content?.display?.showHoverEffect\">\r\n</ng-template>\r\n\r\n<ng-template #headingDescription>\r\n\r\n  <div class=\"ptb-1 content-side w-100\">\r\n    <div class=\"heading-medium mb-1\" *ngIf=\"content.display.showHeading\">\r\n      <div class=\"d-flex justify-content-between align-items-start\">\r\n        <simpo-text-editor [(value)]=\"data.inputText[0].value\" [editable]=\"edit || false\">\r\n        </simpo-text-editor>\r\n        <div class=\"indexing\" *ngIf=\"styles?.showIndexing\" [style.color]=\"styles?.background?.accentColor\"\r\n          [style.background]=\"getGlassyBackground(styles?.background?.accentColor)\">\r\n          0{{ currentIndex }}\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"body-desc\" *ngIf=\"content.display.showContent\">\r\n      <simpo-text-editor [(value)]=\"data.inputText[01].value \" [editable]=\"edit || false\"></simpo-text-editor>\r\n    </div>\r\n  </div>\r\n</ng-template>"]}
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"below-image-card.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/elements/below-image-card/below-image-card.component.ts","../../../../../../projects/simpo-ui/src/lib/elements/below-image-card/below-image-card.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC;AACrE,OAAO,EAAE,uBAAuB,EAAE,MAAM,6CAA6C,CAAC;AACtF,OAAO,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AAE9E,OAAO,EAAE,uBAAuB,EAAE,MAAM,0CAA0C,CAAC;AAGnF,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;AAC3E,OAAO,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AAC9E,OAAO,EAAE,uBAAuB,EAAE,MAAM,2CAA2C,CAAC;AACpF,OAAO,EAAE,yBAAyB,EAAE,MAAM,6CAA6C,CAAC;AACxF,OAAO,EAAE,6BAA6B,EAAE,MAAM,kDAAkD,CAAC;AAEjG,OAAO,EAAE,sBAAsB,EAAE,MAAM,0CAA0C,CAAC;AAClF,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;;;;AAuB5D,MAAM,OAAO,uBAAuB;IAalC,YAAoB,aAA4B;QAA5B,kBAAa,GAAb,aAAa,CAAe;QAJhD,gBAAW,GAAU,EAAE,CAAC;QACxB,iBAAY,GAAG,CAAC,CAAA;QAChB,YAAO,GAAG,CAAC,CAAC;IAEwC,CAAC;aAC9C,YAAO,GAAG,CAAC,AAAJ,CAAK;IAEnB,QAAQ;QACN,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;IAC1C,CAAC;IAED,YAAY;QACV,uBAAuB,CAAC,OAAO,EAAE,CAAC;QAClC,OAAO,uBAAuB,CAAC,OAAO,CAAC;IACzC,CAAC;IAED,mBAAmB,CAAC,KAAU;QAC5B,OAAO,QAAQ,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC;IAC9C,CAAC;IAED,QAAQ,CAAC,GAAW;QAClB,MAAM,MAAM,GAAG,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAC1C,MAAM,CAAC,GAAG,CAAC,MAAM,IAAI,EAAE,CAAC,GAAG,GAAG,CAAC;QAC/B,MAAM,CAAC,GAAG,CAAC,MAAM,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC;QAC9B,MAAM,CAAC,GAAG,MAAM,GAAG,GAAG,CAAC;QAEvB,OAAO,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC;IAC5B,CAAC;IAED,UAAU;QACR,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IACxE,CAAC;IACD,IAAI,cAAc;QAChB,OAAO,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;IAClC,CAAC;IACD,mBAAmB;QACjB,OAAO,EAAE,gBAAgB,EAAE,IAAI,CAAC,MAAM,EAAE,gBAAgB,EAAE,CAAA;IAC5D,CAAC;IAED,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,IAAI,EAAE,IAAI,CAAA;IACxB,CAAC;IAED,WAAW;QACT,mDAAmD;IACrD,CAAC;IACD,YAAY;QACV,QAAQ,IAAI,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC;YACnC,KAAK,MAAM;gBACT,OAAO,qBAAqB,CAAC;YAC/B,KAAK,OAAO;gBACV,OAAO,mBAAmB,CAAC;YAC7B,KAAK,QAAQ;gBACX,OAAO,sBAAsB,CAAC;YAChC;gBACE,OAAO,qBAAqB,CAAC;QACjC,CAAC;IACH,CAAC;IAED,aAAa;QACX,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;YAClC,IAAI,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE,cAAc,KAAK,UAAU,EAAE,CAAC;gBACzD,MAAM,SAAS,GAAG,iBAAiB,CAAC,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE,2BAAwE,IAAI,iBAAiB,CAAC,IAAI,CAAC,CAAC;gBAC/J,OAAO,mBAAmB,SAAS,KAAK,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE,KAAK,KAAK,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE,cAAc,GAAG,CAAC;YACpH,CAAC;iBACI,CAAC;gBACJ,OAAO,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE,KAAK,CAAA;YACrC,CAAC;QACH,CAAC;IACH,CAAC;IACD,IAAI,iBAAiB;QACnB,IAAI,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,cAAc,KAAK,UAAU,EAAE,CAAC;YACnD,MAAM,SAAS,GAAG,iBAAiB,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,2BAAwE,IAAI,iBAAiB,CAAC,IAAI,CAAC,CAAC;YACzJ,OAAO,mBAAmB,SAAS,KAAK,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,eAAe,KAAK,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,cAAc,GAAG,CAAC;QAClH,CAAC;aACI,CAAC;YACJ,OAAO,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,eAAe,CAAA;QACzC,CAAC;IACH,CAAC;+GAvFU,uBAAuB;mGAAvB,uBAAuB,qQCxCpC,01IAwEc,2/BDhDV,uBAAuB,kGACvB,YAAY,wYACZ,uBAAuB,mGACvB,eAAe,mFACf,oBAAoB,2MACpB,mBAAmB,qJACnB,oBAAoB,2IACpB,uBAAuB,mGACvB,yBAAyB,uGACzB,6BAA6B,kIAC7B,sBAAsB;;4FAMb,uBAAuB;kBApBnC,SAAS;+BACE,wBAAwB,cACtB,IAAI,WACP;wBACP,uBAAuB;wBACvB,YAAY;wBACZ,uBAAuB;wBACvB,eAAe;wBACf,oBAAoB;wBACpB,mBAAmB;wBACnB,oBAAoB;wBACpB,uBAAuB;wBACvB,yBAAyB;wBACzB,6BAA6B;wBAC7B,sBAAsB;wBACtB,kBAAkB;qBACnB;kFAMQ,IAAI;sBAAZ,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,cAAc;sBAAtB,KAAK","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, Input } from '@angular/core';\r\nimport { CornerDirective } from './../../directive/corner-directive';\r\nimport { ImageDirectiveDirective } from './../../directive/image-directive.directive';\r\nimport { SimpoButtonComponent } from '../simpo-button/simpo-button.component';\r\nimport { ButtonModel } from '../../styles/style.model';\r\nimport { ObjectPositionDirective } from '../../directive/image-position.directive';\r\nimport { EventsService } from '../../services/events.service';\r\nimport { ImageContainerDirective } from '../../directive/image-container.directive';\r\nimport { TextEditorComponent } from '../text-editor/text-editor.component';\r\nimport { ImageEditorDirective } from '../../directive/image-editor.directive';\r\nimport { HoverAnimationDirective } from '../../directive/hover-animation.directive';\r\nimport { TranslateOnhoverDirective } from '../../directive/translate-onhover.directive';\r\nimport { SetDynamicBackgroundDirective } from '../../directive/set-dynamic-background.directive';\r\nimport { SimpoBorderlessDirective } from '../../directive/borderlessImage.directive';\r\nimport { IconDirectiveDirective } from '../../directive/icon-directive.directive';\r\nimport { GradientDirection } from '../../styles';\r\nimport { CdkDragPlaceholder } from \"@angular/cdk/drag-drop\";\r\n\r\n\r\n@Component({\r\n  selector: 'simpo-below-image-card',\r\n  standalone: true,\r\n  imports: [\r\n    ObjectPositionDirective,\r\n    CommonModule,\r\n    ImageDirectiveDirective,\r\n    CornerDirective,\r\n    SimpoButtonComponent,\r\n    TextEditorComponent,\r\n    ImageEditorDirective,\r\n    HoverAnimationDirective,\r\n    TranslateOnhoverDirective,\r\n    SetDynamicBackgroundDirective,\r\n    IconDirectiveDirective,\r\n    CdkDragPlaceholder\r\n  ],\r\n  templateUrl: './below-image-card.component.html',\r\n  styleUrl: './below-image-card.component.css'\r\n})\r\nexport class BelowImageCardComponent {\r\n\r\n  @Input() data: any;\r\n  @Input() styles: any;\r\n  @Input() content: any;\r\n  @Input() componentId?: string;\r\n  @Input() button?: ButtonModel;\r\n  @Input() edit?: boolean;\r\n  @Input() positionLayout?: string;\r\n  allContents: any[] = [];\r\n  currentIndex = 0\r\n  counter = 0;\r\n\r\n  constructor(private _eventService: EventsService) { }\r\n  static counter = 0;\r\n\r\n  ngOnInit() {\r\n    this.currentIndex = this.getNextIndex();\r\n  }\r\n\r\n  getNextIndex(): number {\r\n    BelowImageCardComponent.counter++;\r\n    return BelowImageCardComponent.counter;\r\n  }\r\n\r\n  getGlassyBackground(color: any) {\r\n    return `rgba(${this.hexToRgb(color)}, 0.1)`;\r\n  }\r\n\r\n  hexToRgb(hex: string) {\r\n    const bigint = parseInt(hex.slice(1), 16);\r\n    const r = (bigint >> 16) & 255;\r\n    const g = (bigint >> 8) & 255;\r\n    const b = bigint & 255;\r\n\r\n    return `${r}, ${g}, ${b}`;\r\n  }\r\n\r\n  redirectTo() {\r\n    this._eventService.buttonRedirection.emit({ data: this.data.button });\r\n  }\r\n  get getAspectRatio() {\r\n    return { ...this.styles.image };\r\n  }\r\n  getContentAnimation() {\r\n    return { contentAnimation: this.styles?.contentAnimation }\r\n  }\r\n\r\n  get getIconStyls() {\r\n    return this.data?.icon\r\n  }\r\n\r\n  ngOnChanges() {\r\n    // console.log('Below Image Card Data', this.data);\r\n  }\r\n  getAlignment() {\r\n    switch (this.styles?.layout?.align) {\r\n      case 'left':\r\n        return 'justify-items-start';\r\n      case 'right':\r\n        return 'justify-items-end';\r\n      case 'center':\r\n        return 'justify-items-center';\r\n      default:\r\n        return 'justify-items-start';\r\n    }\r\n  }\r\n\r\n  getBackground() {\r\n    if (this.content.display.showCard) {\r\n      if (this.data?.background?.backgroundType === 'Gradient') {\r\n        const direction = GradientDirection[this.data?.background?.backgroundGradientDirection as unknown as keyof typeof GradientDirection || GradientDirection.DOWN];\r\n        return `linear-gradient(${direction}, ${this.data?.background?.color}, ${this.data?.background?.secondaryColor})`;\r\n      }\r\n      else {\r\n        return this.data?.background?.color\r\n      }\r\n    }\r\n  }\r\n  get getIconBackground() {\r\n    if (this.data?.icon?.backgroundType === 'Gradient') {\r\n      const direction = GradientDirection[this.data?.icon?.backgroundGradientDirection as unknown as keyof typeof GradientDirection || GradientDirection.DOWN];\r\n      return `linear-gradient(${direction}, ${this.data?.icon?.backgroundColor}, ${this.data?.icon?.secondaryColor})`;\r\n    }\r\n    else {\r\n      return this.data?.icon?.backgroundColor\r\n    }\r\n  }\r\n\r\n\r\n}\r\n","<div class=\"card-container\"\r\n  (click)=\"(content?.display?.showLink && content?.display?.linkType === 'List Item' ? redirectTo() : '')\"\r\n  [ngClass]=\"{'box-shadow' : content.display.showCard, 'px-0 py-0': styles?.borderLessImage && !content?.display?.showIcon ,'py-14' : content?.display?.showCardBackground && !styles?.borderLessImage}\"\r\n  [style.background]=\"getBackground()\" [id]=\"data?.id\" [simpoCorner]=\"styles?.corners\"\r\n  [simpoTranslateOnhover]=\"content?.display?.showHoverEffect\" [backgroundColor]=\"styles?.background?.color\"\r\n  [simpoSetDynamicBackground]=\"content?.display?.showCardBackground\" [class]=\"getAlignment()\">\r\n\r\n  <ng-container *ngIf=\"positionLayout == 'bottom'\">\r\n    <ng-container *ngTemplateOutlet=\"headingDescription\"></ng-container>\r\n    <ng-container *ngTemplateOutlet=\"iconAndImage\"></ng-container>\r\n  </ng-container>\r\n\r\n  <ng-container *ngIf=\"positionLayout == 'top'\">\r\n    <ng-container *ngTemplateOutlet=\"iconAndImage\"></ng-container>\r\n    <ng-container *ngTemplateOutlet=\"headingDescription\"></ng-container>\r\n  </ng-container>\r\n\r\n  <div class=\"ptb-1 w-100\">\r\n    <div *ngIf=\"content.display.showLink && content.display.linkType === 'Button'\" class=\"card-button\"\r\n      [simpoHoverAnimation]=\"getContentAnimation()\">\r\n      <app-button-element [buttonContent]=\"data.button\" [buttonStyle]=\"button?.styles\"\r\n        [buttonId]=\"button ? button.id : ''\" [sectionId]=\"componentId\" [color]=\"styles?.background?.accentColor\"\r\n        [backgroundInfo]=\"styles?.background\" [edit]=\"edit\">\r\n      </app-button-element>\r\n    </div>\r\n  </div>\r\n</div>\r\n<ng-template #iconAndImage>\r\n  <img loading=\"lazy\" [src]=\"data.image.url\" [alt]=\"data.image.altText\" [simpoImageDirective]=\"styles?.image\"\r\n    [attr.simpoObjectPosition]=\"styles?.image?.fit !== 'contain' ? data.image?.position : null\"\r\n    [simpoCorner]=\"styles?.corners\" [id]=\"componentId\" class=\"w-100\" *ngIf=\"content.display.showImage\"\r\n    [appImageEditor]=\"edit || false\" [imageData]=\"data.image\" [sectionId]=\"data?.id\"\r\n    [simpoObjectPosition]=\"data?.image?.position\" [class]=\"data?.id+data.image.id\">\r\n\r\n\r\n  <ng-container *ngIf=\"content.display.showIcon && (data.icon.url.includes('.png') || data.icon.url.includes('.svg'))\">\r\n    <div [simpoCorner]=\"styles?.corners\" [class.hovering-effect]=\"content?.display?.showHoverEffect\" [id]=\"componentId\"\r\n      class=\"logo-img d-flex justify-content-center align-items-center\"\r\n      [style.background]=\"data?.icon?.showBackground ? getIconBackground : 'transparent'\"\r\n      [appImageEditor]=\"edit || false\" [iconData]=\"data.icon\" [sectionId]=\"componentId\"\r\n      [showIcon]=\"content.display.showIcon\">\r\n      <div [id]=\"componentId\" [iconId]=\"componentId + data?.icon?.id\" [simpoIconDirective]=\"data?.icon\"\r\n        class=\"w-65 h-100\" [class.w-100]=\"!data?.icon?.showBackground\">\r\n      </div>\r\n    </div>\r\n  </ng-container>\r\n\r\n  <img loading=\"lazy\" class=\"logo-img\" [src]=\"data.icon.url\" [appImageEditor]=\"edit || false\" [iconData]=\"data.icon\"\r\n    [sectionId]=\"componentId\" [showIcon]=\"content.display.showIcon\"\r\n    *ngIf=\"content.display.showIcon && !data.icon.url.includes('.png') && !data.icon.url.includes('.svg')\"\r\n    class=\"logo-img\" [simpoCorner]=\"styles?.corners\" [id]=\"data?.id\"\r\n    [class.hovering-effect]=\"content?.display?.showHoverEffect\">\r\n</ng-template>\r\n\r\n<ng-template #headingDescription>\r\n\r\n  <div class=\"ptb-1 content-side w-100\">\r\n    <div class=\"heading-medium mb-1\" *ngIf=\"content.display.showHeading\">\r\n      <div class=\"d-flex justify-content-between align-items-start\">\r\n        <simpo-text-editor [(value)]=\"data.inputText[0].value\" [editable]=\"edit || false\">\r\n        </simpo-text-editor>\r\n        <div class=\"indexing\" *ngIf=\"styles?.showIndexing\" [style.color]=\"styles?.background?.accentColor\"\r\n          [style.background]=\"getGlassyBackground(styles?.background?.accentColor)\">\r\n          0{{ currentIndex }}\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"body-desc\" *ngIf=\"content.display.showContent\">\r\n      <simpo-text-editor [(value)]=\"data.inputText[01].value \" [editable]=\"edit || false\"></simpo-text-editor>\r\n    </div>\r\n  </div>\r\n</ng-template>"]}