simpo-component-library 3.6.556 → 3.6.557
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/directive/animation-directive.mjs +46 -41
- package/fesm2022/simpo-component-library.mjs +45 -40
- package/fesm2022/simpo-component-library.mjs.map +1 -1
- package/lib/directive/animation-directive.d.ts +2 -0
- package/lib/ecommerce/sections/authentication-required/authentication-required.component.d.ts +1 -1
- package/lib/ecommerce/sections/product-desc/product-desc.component.d.ts +1 -1
- package/lib/ecommerce/sections/schemes/schemes.component.d.ts +1 -1
- package/lib/sections/banner-carousel/banner-carousel.component.d.ts +2 -2
- package/lib/sections/carousel-banner/carousel-banner.component.d.ts +1 -1
- package/lib/sections/contact-us/contact-us.component.d.ts +1 -1
- package/lib/sections/faq-section/faq-section.component.d.ts +1 -1
- package/lib/sections/image-section/image-section.component.d.ts +2 -2
- package/lib/sections/logo-showcase/logo-showcase.component.d.ts +2 -2
- package/lib/sections/new-testimonials/new-testimonials.component.d.ts +1 -1
- package/lib/sections/pricing-section/pricing-section.component.d.ts +2 -2
- package/package.json +1 -1
- package/simpo-component-library-3.6.557.tgz +0 -0
- package/simpo-component-library-3.6.556.tgz +0 -0
|
@@ -7,14 +7,16 @@ export class AnimationDirective {
|
|
|
7
7
|
this.el = el;
|
|
8
8
|
this.renderer = renderer;
|
|
9
9
|
this.eventService = eventService;
|
|
10
|
-
//
|
|
11
|
-
this.eventServiceSubscription =
|
|
12
|
-
|
|
13
|
-
this.
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
10
|
+
// External animation updates
|
|
11
|
+
this.eventServiceSubscription =
|
|
12
|
+
this.eventService.animationChangeChecks.subscribe((res) => {
|
|
13
|
+
if (this.el.nativeElement.id === res?.id) {
|
|
14
|
+
this.animationData = res?.data;
|
|
15
|
+
this.applyAnimation(true);
|
|
16
|
+
}
|
|
17
|
+
});
|
|
17
18
|
}
|
|
19
|
+
/* ------------------ LIFECYCLE ------------------ */
|
|
18
20
|
ngOnInit() {
|
|
19
21
|
this.createObserver();
|
|
20
22
|
}
|
|
@@ -22,53 +24,56 @@ export class AnimationDirective {
|
|
|
22
24
|
this.applyAnimation();
|
|
23
25
|
}
|
|
24
26
|
ngOnDestroy() {
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
if (this.eventServiceSubscription)
|
|
28
|
-
this.eventServiceSubscription.unsubscribe();
|
|
27
|
+
this.observer?.disconnect();
|
|
28
|
+
this.eventServiceSubscription?.unsubscribe();
|
|
29
29
|
}
|
|
30
|
+
/* ------------------ OBSERVER ------------------ */
|
|
30
31
|
createObserver() {
|
|
31
32
|
if (typeof window === 'undefined' || !('IntersectionObserver' in window)) {
|
|
32
|
-
this.applyAnimation();
|
|
33
|
+
this.applyAnimation(true);
|
|
33
34
|
return;
|
|
34
35
|
}
|
|
35
|
-
const options = {
|
|
36
|
-
root: null,
|
|
37
|
-
threshold: 0.1,
|
|
38
|
-
};
|
|
39
36
|
this.observer = new IntersectionObserver((entries) => {
|
|
40
37
|
entries.forEach((entry) => {
|
|
41
|
-
if (entry.isIntersecting
|
|
42
|
-
|
|
43
|
-
this.el.nativeElement.classList.add('visible');
|
|
44
|
-
this.applyAnimation();
|
|
45
|
-
this.observer?.unobserve(this.el.nativeElement);
|
|
38
|
+
if (entry.isIntersecting) {
|
|
39
|
+
this.applyAnimation(true);
|
|
46
40
|
}
|
|
47
41
|
});
|
|
48
|
-
},
|
|
42
|
+
}, { threshold: 0.1 });
|
|
49
43
|
this.observer.observe(this.el.nativeElement);
|
|
50
44
|
}
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
45
|
+
/* ------------------ ANIMATION CORE ------------------ */
|
|
46
|
+
applyAnimation(force = false) {
|
|
47
|
+
if (!this.animationData)
|
|
48
|
+
return;
|
|
49
|
+
const currentType = this.animationData.type;
|
|
50
|
+
const currentSpeed = this.animationData.speed;
|
|
51
|
+
const typeChanged = this.previousType !== currentType;
|
|
52
|
+
const speedChanged = this.previousSpeed !== currentSpeed;
|
|
53
|
+
this.previousType = currentType;
|
|
54
|
+
this.previousSpeed = currentSpeed;
|
|
55
|
+
const animationName = this.getAnimationName(currentType);
|
|
56
|
+
const duration = this.getAnimationSpeed(currentSpeed);
|
|
54
57
|
this.renderer.setStyle(this.el.nativeElement, 'position', 'relative');
|
|
55
|
-
|
|
58
|
+
if (typeChanged || speedChanged || force) {
|
|
59
|
+
this.restartAnimation(animationName, duration);
|
|
60
|
+
}
|
|
56
61
|
}
|
|
57
62
|
restartAnimation(name, durationSec) {
|
|
58
|
-
|
|
59
|
-
//
|
|
60
|
-
|
|
61
|
-
//
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
this.el.nativeElement.style.animation = `${name} ${dur} ease both`;
|
|
63
|
+
const el = this.el.nativeElement;
|
|
64
|
+
// 🔁 Force animation restart
|
|
65
|
+
el.style.animation = 'none';
|
|
66
|
+
el.offsetHeight; // Force reflow
|
|
67
|
+
if (!name || name === 'none') {
|
|
68
|
+
el.style.removeProperty('animation');
|
|
69
|
+
return;
|
|
70
|
+
}
|
|
71
|
+
const duration = durationSec ?? '0.8s';
|
|
72
|
+
el.style.animation = `${name} ${duration} ease both`;
|
|
69
73
|
}
|
|
70
|
-
|
|
71
|
-
|
|
74
|
+
/* ------------------ HELPERS ------------------ */
|
|
75
|
+
getAnimationName(type) {
|
|
76
|
+
switch (type) {
|
|
72
77
|
case 'left':
|
|
73
78
|
return 'animateleft';
|
|
74
79
|
case 'right':
|
|
@@ -84,7 +89,7 @@ export class AnimationDirective {
|
|
|
84
89
|
case 'none':
|
|
85
90
|
return 'none';
|
|
86
91
|
default:
|
|
87
|
-
return '';
|
|
92
|
+
return '';
|
|
88
93
|
}
|
|
89
94
|
}
|
|
90
95
|
getAnimationSpeed(speed) {
|
|
@@ -105,4 +110,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
105
110
|
type: Input,
|
|
106
111
|
args: ['simpoAnimation']
|
|
107
112
|
}] } });
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animation-directive.js","sourceRoot":"","sources":["../../../../../projects/simpo-ui/src/lib/directive/animation-directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  ElementRef,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Renderer2,\r\n  SimpleChanges,\r\n} from '@angular/core';\r\nimport { animation } from '../styles/index';\r\nimport { AnimationModel } from '../styles/style.model';\r\nimport { EventsService } from '../services/events.service';\r\nimport { ANIMATION_SPEED } from '../styles/types';\r\n\r\n@Directive({\r\n  selector: '[simpoAnimation]',\r\n  standalone: true,\r\n})\r\nexport class AnimationDirective implements OnInit, OnChanges, OnDestroy {\r\n  @Input('simpoAnimation') animationData?: AnimationModel;\r\n\r\n  private observer?: IntersectionObserver;\r\n  private eventServiceSubscription: any;\r\n\r\n  constructor(\r\n    private el: ElementRef<HTMLElement>,\r\n    private renderer: Renderer2,\r\n    private eventService: EventsService\r\n  ) {\r\n    // Listen for external changes and re-apply animation\r\n    this.eventServiceSubscription = this.eventService.animationChangeChecks.subscribe(\r\n      (res: any) => {\r\n        if (this.el.nativeElement.id === res?.id) {\r\n          this.animationData = res?.data;\r\n          this.applyAnimation();\r\n        }\r\n      }\r\n    );\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.createObserver();\r\n  }\r\n\r\n  ngOnChanges(_changes: SimpleChanges): void {\r\n    this.applyAnimation();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.observer) this.observer.disconnect();\r\n    if (this.eventServiceSubscription) this.eventServiceSubscription.unsubscribe();\r\n  }\r\n\r\n\r\n  private createObserver(): void {\r\n    if (typeof window === 'undefined' || !('IntersectionObserver' in window)) {\r\n      this.applyAnimation();\r\n      return;\r\n    }\r\n\r\n    const options: IntersectionObserverInit = {\r\n      root: null,\r\n      threshold: 0.1,\r\n    };\r\n\r\n    this.observer = new IntersectionObserver((entries) => {\r\n      entries.forEach((entry) => {\r\n        if (\r\n          entry.isIntersecting &&\r\n          !this.el.nativeElement.classList.contains('visible')\r\n        ) {\r\n          this.el.nativeElement.classList.add('visible');\r\n          this.applyAnimation();\r\n          this.observer?.unobserve(this.el.nativeElement);\r\n        }\r\n      });\r\n    }, options);\r\n\r\n    this.observer.observe(this.el.nativeElement);\r\n  }\r\n\r\n  private applyAnimation(): void {\r\n    const name = this.getAnimationName();\r\n    const duration = this.getAnimationSpeed(this.animationData?.speed);\r\n    this.renderer.setStyle(this.el.nativeElement, 'position', 'relative');\r\n    this.restartAnimation(name, duration);\r\n  }\r\n\r\n  private restartAnimation(name: string, durationSec: string | null): void {\r\n    // const el = this.el.nativeElement;\r\n\r\n    // el.style.animation = 'none';\r\n    // el.offsetHeight;\r\n\r\n    // if (!name || name === 'none') {\r\n    //   el.style.removeProperty('animation');\r\n    //   el.style.removeProperty('animation-name');\r\n    //   el.style.removeProperty('animation-duration');\r\n    //   return;\r\n    // }\r\n\r\n    const dur = durationSec ?? '0.8s';\r\n    this.el.nativeElement.style.animation = `${name} ${dur} ease both`;\r\n  }\r\n  private getAnimationName(): string {\r\n    switch (this.animationData?.type) {\r\n      case 'left':\r\n        return 'animateleft';\r\n      case 'right':\r\n        return 'animateright';\r\n      case 'top':\r\n        return 'animatetop';\r\n      case 'bottom':\r\n        return 'animatebottom';\r\n      case 'fadeIn':\r\n        return 'opac';\r\n      case 'zoom':\r\n        return 'animatezoom';\r\n      case 'none':\r\n        return 'none';\r\n      default:\r\n        return ''; // no animation\r\n    }\r\n  }\r\n\r\n  private getAnimationSpeed(speed?: ANIMATION_SPEED): string | null {\r\n    if (!speed) return null;\r\n    return animation.speed?.[speed] ?? null;\r\n  }\r\n}\r\n"]}
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animation-directive.js","sourceRoot":"","sources":["../../../../../projects/simpo-ui/src/lib/directive/animation-directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  ElementRef,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Renderer2,\r\n  SimpleChanges,\r\n} from '@angular/core';\r\nimport { animation } from '../styles/index';\r\nimport { AnimationModel } from '../styles/style.model';\r\nimport { EventsService } from '../services/events.service';\r\nimport { ANIMATION_SPEED } from '../styles/types';\r\n\r\n@Directive({\r\n  selector: '[simpoAnimation]',\r\n  standalone: true,\r\n})\r\nexport class AnimationDirective implements OnInit, OnChanges, OnDestroy {\r\n  @Input('simpoAnimation') animationData?: AnimationModel;\r\n\r\n  private observer?: IntersectionObserver;\r\n  private eventServiceSubscription: any;\r\n\r\n  // Track previous animation state\r\n  private previousType?: string;\r\n  private previousSpeed?: ANIMATION_SPEED;\r\n\r\n  constructor(\r\n    private el: ElementRef<HTMLElement>,\r\n    private renderer: Renderer2,\r\n    private eventService: EventsService\r\n  ) {\r\n    // External animation updates\r\n    this.eventServiceSubscription =\r\n      this.eventService.animationChangeChecks.subscribe((res: any) => {\r\n        if (this.el.nativeElement.id === res?.id) {\r\n          this.animationData = res?.data;\r\n          this.applyAnimation(true);\r\n        }\r\n      });\r\n  }\r\n\r\n  /* ------------------ LIFECYCLE ------------------ */\r\n\r\n  ngOnInit(): void {\r\n    this.createObserver();\r\n  }\r\n\r\n  ngOnChanges(_changes: SimpleChanges): void {\r\n    this.applyAnimation();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.observer?.disconnect();\r\n    this.eventServiceSubscription?.unsubscribe();\r\n  }\r\n\r\n  /* ------------------ OBSERVER ------------------ */\r\n\r\n  private createObserver(): void {\r\n    if (typeof window === 'undefined' || !('IntersectionObserver' in window)) {\r\n      this.applyAnimation(true);\r\n      return;\r\n    }\r\n\r\n    this.observer = new IntersectionObserver(\r\n      (entries) => {\r\n        entries.forEach((entry) => {\r\n          if (entry.isIntersecting) {\r\n            this.applyAnimation(true);\r\n          }\r\n        });\r\n      },\r\n      { threshold: 0.1 }\r\n    );\r\n\r\n    this.observer.observe(this.el.nativeElement);\r\n  }\r\n\r\n  /* ------------------ ANIMATION CORE ------------------ */\r\n\r\n  private applyAnimation(force = false): void {\r\n    if (!this.animationData) return;\r\n\r\n    const currentType = this.animationData.type;\r\n    const currentSpeed = this.animationData.speed;\r\n\r\n    const typeChanged = this.previousType !== currentType;\r\n    const speedChanged = this.previousSpeed !== currentSpeed;\r\n\r\n    this.previousType = currentType;\r\n    this.previousSpeed = currentSpeed;\r\n\r\n    const animationName = this.getAnimationName(currentType);\r\n    const duration = this.getAnimationSpeed(currentSpeed);\r\n\r\n    this.renderer.setStyle(this.el.nativeElement, 'position', 'relative');\r\n\r\n    if (typeChanged || speedChanged || force) {\r\n      this.restartAnimation(animationName, duration);\r\n    }\r\n  }\r\n\r\n  private restartAnimation(\r\n    name: string,\r\n    durationSec: string | null\r\n  ): void {\r\n    const el = this.el.nativeElement;\r\n\r\n    // 🔁 Force animation restart\r\n    el.style.animation = 'none';\r\n    el.offsetHeight; // Force reflow\r\n\r\n    if (!name || name === 'none') {\r\n      el.style.removeProperty('animation');\r\n      return;\r\n    }\r\n\r\n    const duration = durationSec ?? '0.8s';\r\n    el.style.animation = `${name} ${duration} ease both`;\r\n  }\r\n\r\n  /* ------------------ HELPERS ------------------ */\r\n\r\n  private getAnimationName(type?: string): string {\r\n    switch (type) {\r\n      case 'left':\r\n        return 'animateleft';\r\n      case 'right':\r\n        return 'animateright';\r\n      case 'top':\r\n        return 'animatetop';\r\n      case 'bottom':\r\n        return 'animatebottom';\r\n      case 'fadeIn':\r\n        return 'opac';\r\n      case 'zoom':\r\n        return 'animatezoom';\r\n      case 'none':\r\n        return 'none';\r\n      default:\r\n        return '';\r\n    }\r\n  }\r\n\r\n  private getAnimationSpeed(speed?: ANIMATION_SPEED): string | null {\r\n    if (!speed) return null;\r\n    return animation.speed?.[speed] ?? null;\r\n  }\r\n}\r\n"]}
|
|
@@ -4255,14 +4255,16 @@ class AnimationDirective {
|
|
|
4255
4255
|
this.el = el;
|
|
4256
4256
|
this.renderer = renderer;
|
|
4257
4257
|
this.eventService = eventService;
|
|
4258
|
-
//
|
|
4259
|
-
this.eventServiceSubscription =
|
|
4260
|
-
|
|
4261
|
-
this.
|
|
4262
|
-
|
|
4263
|
-
|
|
4264
|
-
|
|
4258
|
+
// External animation updates
|
|
4259
|
+
this.eventServiceSubscription =
|
|
4260
|
+
this.eventService.animationChangeChecks.subscribe((res) => {
|
|
4261
|
+
if (this.el.nativeElement.id === res?.id) {
|
|
4262
|
+
this.animationData = res?.data;
|
|
4263
|
+
this.applyAnimation(true);
|
|
4264
|
+
}
|
|
4265
|
+
});
|
|
4265
4266
|
}
|
|
4267
|
+
/* ------------------ LIFECYCLE ------------------ */
|
|
4266
4268
|
ngOnInit() {
|
|
4267
4269
|
this.createObserver();
|
|
4268
4270
|
}
|
|
@@ -4270,53 +4272,56 @@ class AnimationDirective {
|
|
|
4270
4272
|
this.applyAnimation();
|
|
4271
4273
|
}
|
|
4272
4274
|
ngOnDestroy() {
|
|
4273
|
-
|
|
4274
|
-
|
|
4275
|
-
if (this.eventServiceSubscription)
|
|
4276
|
-
this.eventServiceSubscription.unsubscribe();
|
|
4275
|
+
this.observer?.disconnect();
|
|
4276
|
+
this.eventServiceSubscription?.unsubscribe();
|
|
4277
4277
|
}
|
|
4278
|
+
/* ------------------ OBSERVER ------------------ */
|
|
4278
4279
|
createObserver() {
|
|
4279
4280
|
if (typeof window === 'undefined' || !('IntersectionObserver' in window)) {
|
|
4280
|
-
this.applyAnimation();
|
|
4281
|
+
this.applyAnimation(true);
|
|
4281
4282
|
return;
|
|
4282
4283
|
}
|
|
4283
|
-
const options = {
|
|
4284
|
-
root: null,
|
|
4285
|
-
threshold: 0.1,
|
|
4286
|
-
};
|
|
4287
4284
|
this.observer = new IntersectionObserver((entries) => {
|
|
4288
4285
|
entries.forEach((entry) => {
|
|
4289
|
-
if (entry.isIntersecting
|
|
4290
|
-
|
|
4291
|
-
this.el.nativeElement.classList.add('visible');
|
|
4292
|
-
this.applyAnimation();
|
|
4293
|
-
this.observer?.unobserve(this.el.nativeElement);
|
|
4286
|
+
if (entry.isIntersecting) {
|
|
4287
|
+
this.applyAnimation(true);
|
|
4294
4288
|
}
|
|
4295
4289
|
});
|
|
4296
|
-
},
|
|
4290
|
+
}, { threshold: 0.1 });
|
|
4297
4291
|
this.observer.observe(this.el.nativeElement);
|
|
4298
4292
|
}
|
|
4299
|
-
|
|
4300
|
-
|
|
4301
|
-
|
|
4293
|
+
/* ------------------ ANIMATION CORE ------------------ */
|
|
4294
|
+
applyAnimation(force = false) {
|
|
4295
|
+
if (!this.animationData)
|
|
4296
|
+
return;
|
|
4297
|
+
const currentType = this.animationData.type;
|
|
4298
|
+
const currentSpeed = this.animationData.speed;
|
|
4299
|
+
const typeChanged = this.previousType !== currentType;
|
|
4300
|
+
const speedChanged = this.previousSpeed !== currentSpeed;
|
|
4301
|
+
this.previousType = currentType;
|
|
4302
|
+
this.previousSpeed = currentSpeed;
|
|
4303
|
+
const animationName = this.getAnimationName(currentType);
|
|
4304
|
+
const duration = this.getAnimationSpeed(currentSpeed);
|
|
4302
4305
|
this.renderer.setStyle(this.el.nativeElement, 'position', 'relative');
|
|
4303
|
-
|
|
4306
|
+
if (typeChanged || speedChanged || force) {
|
|
4307
|
+
this.restartAnimation(animationName, duration);
|
|
4308
|
+
}
|
|
4304
4309
|
}
|
|
4305
4310
|
restartAnimation(name, durationSec) {
|
|
4306
|
-
|
|
4307
|
-
//
|
|
4308
|
-
|
|
4309
|
-
//
|
|
4310
|
-
|
|
4311
|
-
|
|
4312
|
-
|
|
4313
|
-
|
|
4314
|
-
|
|
4315
|
-
|
|
4316
|
-
this.el.nativeElement.style.animation = `${name} ${dur} ease both`;
|
|
4311
|
+
const el = this.el.nativeElement;
|
|
4312
|
+
// 🔁 Force animation restart
|
|
4313
|
+
el.style.animation = 'none';
|
|
4314
|
+
el.offsetHeight; // Force reflow
|
|
4315
|
+
if (!name || name === 'none') {
|
|
4316
|
+
el.style.removeProperty('animation');
|
|
4317
|
+
return;
|
|
4318
|
+
}
|
|
4319
|
+
const duration = durationSec ?? '0.8s';
|
|
4320
|
+
el.style.animation = `${name} ${duration} ease both`;
|
|
4317
4321
|
}
|
|
4318
|
-
|
|
4319
|
-
|
|
4322
|
+
/* ------------------ HELPERS ------------------ */
|
|
4323
|
+
getAnimationName(type) {
|
|
4324
|
+
switch (type) {
|
|
4320
4325
|
case 'left':
|
|
4321
4326
|
return 'animateleft';
|
|
4322
4327
|
case 'right':
|
|
@@ -4332,7 +4337,7 @@ class AnimationDirective {
|
|
|
4332
4337
|
case 'none':
|
|
4333
4338
|
return 'none';
|
|
4334
4339
|
default:
|
|
4335
|
-
return '';
|
|
4340
|
+
return '';
|
|
4336
4341
|
}
|
|
4337
4342
|
}
|
|
4338
4343
|
getAnimationSpeed(speed) {
|