simpo-component-library 3.6.559 → 3.6.560

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.
@@ -7,131 +7,90 @@ export class AnimationDirective {
7
7
  this.el = el;
8
8
  this.renderer = renderer;
9
9
  this.eventService = eventService;
10
- this.animationSpeed = animation;
11
- this.animationTypes = {
12
- left: "animateleft",
13
- right: "animateright",
14
- bottom: "animatebottom",
15
- top: "animatetop",
16
- zoom: "animatezoom",
17
- fadeIn: "opac"
18
- };
10
+ // Listen for external changes and re-apply animation
19
11
  this.eventServiceSubscription = this.eventService.animationChangeChecks.subscribe((res) => {
20
- if (this.el.nativeElement.id === res.id) {
21
- this.animationData = res.data;
12
+ if (this.el.nativeElement.id === res?.id) {
13
+ this.animationData = res?.data;
22
14
  this.applyAnimation();
23
15
  }
24
16
  });
25
17
  }
26
- ngOnDestroy() {
27
- if (this.observer) {
28
- this.observer.disconnect();
29
- }
30
- if (this.eventServiceSubscription) {
31
- this.eventServiceSubscription.unsubscribe();
32
- }
33
- }
34
18
  ngOnInit() {
35
19
  this.createObserver();
36
- // this.applyAnimation();
37
20
  }
38
- ngOnChanges() {
39
- // this.applyAnimation();
21
+ ngOnChanges(_changes) {
22
+ this.applyAnimation();
23
+ }
24
+ ngOnDestroy() {
25
+ if (this.observer)
26
+ this.observer.disconnect();
27
+ if (this.eventServiceSubscription)
28
+ this.eventServiceSubscription.unsubscribe();
40
29
  }
41
30
  createObserver() {
31
+ if (typeof window === 'undefined' || !('IntersectionObserver' in window)) {
32
+ this.applyAnimation();
33
+ return;
34
+ }
42
35
  const options = {
43
- root: null, // Use the viewport as the container
44
- threshold: 0.1 // Percentage of element visibility required to trigger the callback
36
+ root: null,
37
+ threshold: 0.1,
45
38
  };
46
- if (typeof window !== 'undefined' && 'IntersectionObserver' in window) {
47
- this.observer = new IntersectionObserver((entries) => {
48
- entries.forEach(entry => {
49
- if (entry.isIntersecting &&
50
- !this.el.nativeElement.className.includes('visible')) {
51
- this.el.nativeElement.classList.add('visible');
52
- this.el.nativeElement.style.setProperty('position', 'relative');
53
- this.el.nativeElement.style.setProperty('animation-name', this.getAnimationName());
54
- if (this.animationData?.speed) {
55
- const speed = animation.speed[this.animationData?.speed];
56
- this.el.nativeElement.style.setProperty('animation-duration', this.getAnimationSpeed(this.animationData.speed));
57
- }
58
- this.observer?.unobserve(this.el.nativeElement);
59
- }
60
- });
61
- }, options);
62
- this.observer.observe(this.el.nativeElement);
39
+ this.observer = new IntersectionObserver((entries) => {
40
+ entries.forEach((entry) => {
41
+ if (entry.isIntersecting &&
42
+ !this.el.nativeElement.classList.contains('visible')) {
43
+ this.el.nativeElement.classList.add('visible');
44
+ this.applyAnimation();
45
+ this.observer?.unobserve(this.el.nativeElement);
46
+ }
47
+ });
48
+ }, options);
49
+ this.observer.observe(this.el.nativeElement);
50
+ }
51
+ applyAnimation() {
52
+ const name = this.getAnimationName();
53
+ const duration = this.getAnimationSpeed(this.animationData?.speed);
54
+ this.renderer.setStyle(this.el.nativeElement, 'position', 'relative');
55
+ this.restartAnimation(name, duration);
56
+ }
57
+ restartAnimation(name, durationSec) {
58
+ const el = this.el.nativeElement;
59
+ el.style.animation = 'none';
60
+ el.offsetHeight;
61
+ if (!name || name === 'none') {
62
+ el.style.removeProperty('animation');
63
+ el.style.removeProperty('animation-name');
64
+ el.style.removeProperty('animation-duration');
65
+ return;
63
66
  }
67
+ const dur = durationSec ?? '0.8s';
68
+ el.style.animation = `${name} ${dur} ease both`;
64
69
  }
65
70
  getAnimationName() {
66
- if (this.animationData?.type) {
67
- if (this.animationData?.type == 'left') {
71
+ switch (this.animationData?.type) {
72
+ case 'left':
68
73
  return 'animateleft';
69
- }
70
- if (this.animationData?.type == 'right') {
74
+ case 'right':
71
75
  return 'animateright';
72
- }
73
- if (this.animationData?.type == 'top') {
76
+ case 'top':
74
77
  return 'animatetop';
75
- }
76
- if (this.animationData?.type == 'bottom') {
78
+ case 'bottom':
77
79
  return 'animatebottom';
78
- }
79
- if (this.animationData?.type == 'fadeIn') {
80
+ case 'fadeIn':
80
81
  return 'opac';
81
- }
82
- if (this.animationData?.type == 'zoom') {
82
+ case 'zoom':
83
83
  return 'animatezoom';
84
- }
85
- if (this.animationData?.type === 'none') {
84
+ case 'none':
86
85
  return 'none';
87
- }
88
- }
89
- return null;
90
- }
91
- applyAnimation() {
92
- if (this.animationData?.type) {
93
- const anim = animation.type[this.animationData?.type];
94
- // this.renderer.removeClass(this.el.nativeElement,anim);
95
- // this.renderer.addClass(this.el.nativeElement, anim);
96
- if (this.animationData.type == 'left') {
97
- this.name = 'animateleft';
98
- }
99
- if (this.animationData.type == 'right') {
100
- this.name = 'animateright';
101
- }
102
- if (this.animationData.type == 'top') {
103
- this.name = 'animatetop';
104
- }
105
- if (this.animationData.type == 'bottom') {
106
- this.name = 'animatebottom';
107
- }
108
- if (this.animationData.type == 'fadeIn') {
109
- this.name = 'opac';
110
- }
111
- if (this.animationData.type == 'zoom') {
112
- this.name = 'animatezoom';
113
- }
114
- if (this.animationData.type === 'none') {
115
- this.name = 'none';
116
- }
117
- this.el.nativeElement.style.setProperty('position', 'relative');
118
- this.el.nativeElement.style.setProperty('animation-name', this.name);
119
- }
120
- if (this.animationData?.speed) {
121
- const speed = animation.speed[this.animationData?.speed];
122
- this.el.nativeElement.style.setProperty('position', 'relative');
123
- this.el.nativeElement.style.setProperty('animation-name', this.name);
124
- this.el.nativeElement.style.setProperty('animation-duration', this.getAnimationSpeed(this.animationData.speed));
86
+ default:
87
+ return ''; // no animation
125
88
  }
126
89
  }
127
90
  getAnimationSpeed(speed) {
128
- let speedInSec = '';
129
- for (let key of Object.keys(animation.speed)) {
130
- if (key === speed) {
131
- speedInSec = animation.speed[key];
132
- }
133
- }
134
- return speedInSec;
91
+ if (!speed)
92
+ return null;
93
+ return animation.speed?.[speed] ?? null;
135
94
  }
136
95
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AnimationDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.EventsService }], target: i0.ɵɵFactoryTarget.Directive }); }
137
96
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: AnimationDirective, isStandalone: true, selector: "[simpoAnimation]", inputs: { animationData: ["simpoAnimation", "animationData"] }, usesOnChanges: true, ngImport: i0 }); }
@@ -146,4 +105,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
146
105
  type: Input,
147
106
  args: ['simpoAnimation']
148
107
  }] } });
149
- //# 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} 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@Directive({\r\n  selector: '[simpoAnimation]',\r\n  standalone: true,\r\n})\r\nexport class AnimationDirective implements OnChanges, OnInit, OnDestroy {\r\n  @Input('simpoAnimation') animationData?: AnimationModel;\r\n  eventServiceSubscription : any;\r\n  private observer: IntersectionObserver | undefined;\r\n\r\n  animationSpeed = animation\r\n  constructor(\r\n    private el: ElementRef,\r\n    private renderer: Renderer2,\r\n    private eventService : EventsService\r\n  ) {\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  ngOnDestroy(): void {\r\n    if (this.observer) {\r\n      this.observer.disconnect();\r\n    }\r\n    if(this.eventServiceSubscription){\r\n      this.eventServiceSubscription.unsubscribe();\r\n    }\r\n  }\r\n  ngOnInit(): void {\r\n    this.createObserver();\r\n    // this.applyAnimation();\r\n  }\r\n\r\n  ngOnChanges(): void {\r\n    // this.applyAnimation();\r\n  }\r\n\r\n  private createObserver(): void {\r\n\r\n    const options = {\r\n      root: null, // Use the viewport as the container\r\n      threshold: 0.1 // Percentage of element visibility required to trigger the callback\r\n    };\r\n    if(typeof window !== 'undefined' && 'IntersectionObserver' in window) {\r\n      this.observer = new IntersectionObserver((entries) => {\r\n        entries.forEach(entry => {\r\n          if (\r\n            entry.isIntersecting &&\r\n            !this.el.nativeElement.className.includes('visible')\r\n          ) {\r\n            this.el.nativeElement.classList.add('visible');\r\n            this.el.nativeElement.style.setProperty('position', 'relative');\r\n            this.el.nativeElement.style.setProperty('animation-name', this.getAnimationName());\r\n\r\n            if (this.animationData?.speed) {\r\n              const speed = animation.speed[this.animationData?.speed];\r\n              this.el.nativeElement.style.setProperty('animation-duration', this.getAnimationSpeed(this.animationData.speed));\r\n            }\r\n\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  }\r\n\r\n  getAnimationName() {\r\n    if (this.animationData?.type) {\r\n\r\n      if (this.animationData?.type == 'left') {\r\n        return 'animateleft'\r\n      }\r\n      if (this.animationData?.type == 'right') {\r\n        return 'animateright'\r\n      }\r\n      if (this.animationData?.type == 'top') {\r\n        return 'animatetop'\r\n      }\r\n      if (this.animationData?.type == 'bottom') {\r\n        return 'animatebottom'\r\n      }\r\n      if (this.animationData?.type == 'fadeIn') {\r\n        return 'opac'\r\n      }\r\n      if (this.animationData?.type == 'zoom') {\r\n        return 'animatezoom'\r\n      }\r\n      if (this.animationData?.type === 'none') {\r\n        return 'none'\r\n      }\r\n\r\n    }\r\n    return null;\r\n  }\r\n\r\n  name: any;\r\n\r\n  private applyAnimation() {\r\n    if (this.animationData?.type) {\r\n      const anim = animation.type[this.animationData?.type];\r\n      // this.renderer.removeClass(this.el.nativeElement,anim);\r\n      // this.renderer.addClass(this.el.nativeElement, anim);\r\n      if(this.animationData.type == 'left'){\r\n        this.name = 'animateleft'\r\n      }\r\n      if(this.animationData.type == 'right'){\r\n        this.name = 'animateright'\r\n      }\r\n      if(this.animationData.type == 'top'){\r\n        this.name = 'animatetop'\r\n      }\r\n      if(this.animationData.type == 'bottom'){\r\n        this.name = 'animatebottom'\r\n      }\r\n      if(this.animationData.type == 'fadeIn'){\r\n        this.name = 'opac'\r\n      }\r\n      if(this.animationData.type == 'zoom'){\r\n        this.name = 'animatezoom'\r\n      }\r\n      if(this.animationData.type === 'none') {\r\n        this.name = 'none'\r\n      }\r\n      this.el.nativeElement.style.setProperty('position', 'relative');\r\n      this.el.nativeElement.style.setProperty('animation-name', this.name);\r\n    }\r\n\r\n    if (this.animationData?.speed) {\r\n      const speed = animation.speed[this.animationData?.speed];\r\n      this.el.nativeElement.style.setProperty('position', 'relative');\r\n      this.el.nativeElement.style.setProperty('animation-name', this.name);\r\n      this.el.nativeElement.style.setProperty('animation-duration', this.getAnimationSpeed(this.animationData.speed));\r\n    }\r\n  }\r\n\r\n  getAnimationSpeed(speed:ANIMATION_SPEED){\r\n    let speedInSec = ''\r\n    for(let key of Object.keys(animation.speed)){\r\n       if(key === speed){\r\n        speedInSec =  animation.speed[key];\r\n       }\r\n    }\r\n    return speedInSec;\r\n  }\r\n\r\n  animationTypes : any ={\r\n    left : \"animateleft\",\r\n    right : \"animateright\",\r\n    bottom :\"animatebottom\",\r\n    top : \"animatetop\",\r\n    zoom : \"animatezoom\",\r\n    fadeIn : \"opac\"\r\n  }\r\n}"]}
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    el.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"]}
@@ -4255,131 +4255,90 @@ class AnimationDirective {
4255
4255
  this.el = el;
4256
4256
  this.renderer = renderer;
4257
4257
  this.eventService = eventService;
4258
- this.animationSpeed = animation;
4259
- this.animationTypes = {
4260
- left: "animateleft",
4261
- right: "animateright",
4262
- bottom: "animatebottom",
4263
- top: "animatetop",
4264
- zoom: "animatezoom",
4265
- fadeIn: "opac"
4266
- };
4258
+ // Listen for external changes and re-apply animation
4267
4259
  this.eventServiceSubscription = this.eventService.animationChangeChecks.subscribe((res) => {
4268
- if (this.el.nativeElement.id === res.id) {
4269
- this.animationData = res.data;
4260
+ if (this.el.nativeElement.id === res?.id) {
4261
+ this.animationData = res?.data;
4270
4262
  this.applyAnimation();
4271
4263
  }
4272
4264
  });
4273
4265
  }
4274
- ngOnDestroy() {
4275
- if (this.observer) {
4276
- this.observer.disconnect();
4277
- }
4278
- if (this.eventServiceSubscription) {
4279
- this.eventServiceSubscription.unsubscribe();
4280
- }
4281
- }
4282
4266
  ngOnInit() {
4283
4267
  this.createObserver();
4284
- // this.applyAnimation();
4285
4268
  }
4286
- ngOnChanges() {
4287
- // this.applyAnimation();
4269
+ ngOnChanges(_changes) {
4270
+ this.applyAnimation();
4271
+ }
4272
+ ngOnDestroy() {
4273
+ if (this.observer)
4274
+ this.observer.disconnect();
4275
+ if (this.eventServiceSubscription)
4276
+ this.eventServiceSubscription.unsubscribe();
4288
4277
  }
4289
4278
  createObserver() {
4279
+ if (typeof window === 'undefined' || !('IntersectionObserver' in window)) {
4280
+ this.applyAnimation();
4281
+ return;
4282
+ }
4290
4283
  const options = {
4291
- root: null, // Use the viewport as the container
4292
- threshold: 0.1 // Percentage of element visibility required to trigger the callback
4284
+ root: null,
4285
+ threshold: 0.1,
4293
4286
  };
4294
- if (typeof window !== 'undefined' && 'IntersectionObserver' in window) {
4295
- this.observer = new IntersectionObserver((entries) => {
4296
- entries.forEach(entry => {
4297
- if (entry.isIntersecting &&
4298
- !this.el.nativeElement.className.includes('visible')) {
4299
- this.el.nativeElement.classList.add('visible');
4300
- this.el.nativeElement.style.setProperty('position', 'relative');
4301
- this.el.nativeElement.style.setProperty('animation-name', this.getAnimationName());
4302
- if (this.animationData?.speed) {
4303
- const speed = animation.speed[this.animationData?.speed];
4304
- this.el.nativeElement.style.setProperty('animation-duration', this.getAnimationSpeed(this.animationData.speed));
4305
- }
4306
- this.observer?.unobserve(this.el.nativeElement);
4307
- }
4308
- });
4309
- }, options);
4310
- this.observer.observe(this.el.nativeElement);
4287
+ this.observer = new IntersectionObserver((entries) => {
4288
+ entries.forEach((entry) => {
4289
+ if (entry.isIntersecting &&
4290
+ !this.el.nativeElement.classList.contains('visible')) {
4291
+ this.el.nativeElement.classList.add('visible');
4292
+ this.applyAnimation();
4293
+ this.observer?.unobserve(this.el.nativeElement);
4294
+ }
4295
+ });
4296
+ }, options);
4297
+ this.observer.observe(this.el.nativeElement);
4298
+ }
4299
+ applyAnimation() {
4300
+ const name = this.getAnimationName();
4301
+ const duration = this.getAnimationSpeed(this.animationData?.speed);
4302
+ this.renderer.setStyle(this.el.nativeElement, 'position', 'relative');
4303
+ this.restartAnimation(name, duration);
4304
+ }
4305
+ restartAnimation(name, durationSec) {
4306
+ const el = this.el.nativeElement;
4307
+ el.style.animation = 'none';
4308
+ el.offsetHeight;
4309
+ if (!name || name === 'none') {
4310
+ el.style.removeProperty('animation');
4311
+ el.style.removeProperty('animation-name');
4312
+ el.style.removeProperty('animation-duration');
4313
+ return;
4311
4314
  }
4315
+ const dur = durationSec ?? '0.8s';
4316
+ el.style.animation = `${name} ${dur} ease both`;
4312
4317
  }
4313
4318
  getAnimationName() {
4314
- if (this.animationData?.type) {
4315
- if (this.animationData?.type == 'left') {
4319
+ switch (this.animationData?.type) {
4320
+ case 'left':
4316
4321
  return 'animateleft';
4317
- }
4318
- if (this.animationData?.type == 'right') {
4322
+ case 'right':
4319
4323
  return 'animateright';
4320
- }
4321
- if (this.animationData?.type == 'top') {
4324
+ case 'top':
4322
4325
  return 'animatetop';
4323
- }
4324
- if (this.animationData?.type == 'bottom') {
4326
+ case 'bottom':
4325
4327
  return 'animatebottom';
4326
- }
4327
- if (this.animationData?.type == 'fadeIn') {
4328
+ case 'fadeIn':
4328
4329
  return 'opac';
4329
- }
4330
- if (this.animationData?.type == 'zoom') {
4330
+ case 'zoom':
4331
4331
  return 'animatezoom';
4332
- }
4333
- if (this.animationData?.type === 'none') {
4332
+ case 'none':
4334
4333
  return 'none';
4335
- }
4336
- }
4337
- return null;
4338
- }
4339
- applyAnimation() {
4340
- if (this.animationData?.type) {
4341
- const anim = animation.type[this.animationData?.type];
4342
- // this.renderer.removeClass(this.el.nativeElement,anim);
4343
- // this.renderer.addClass(this.el.nativeElement, anim);
4344
- if (this.animationData.type == 'left') {
4345
- this.name = 'animateleft';
4346
- }
4347
- if (this.animationData.type == 'right') {
4348
- this.name = 'animateright';
4349
- }
4350
- if (this.animationData.type == 'top') {
4351
- this.name = 'animatetop';
4352
- }
4353
- if (this.animationData.type == 'bottom') {
4354
- this.name = 'animatebottom';
4355
- }
4356
- if (this.animationData.type == 'fadeIn') {
4357
- this.name = 'opac';
4358
- }
4359
- if (this.animationData.type == 'zoom') {
4360
- this.name = 'animatezoom';
4361
- }
4362
- if (this.animationData.type === 'none') {
4363
- this.name = 'none';
4364
- }
4365
- this.el.nativeElement.style.setProperty('position', 'relative');
4366
- this.el.nativeElement.style.setProperty('animation-name', this.name);
4367
- }
4368
- if (this.animationData?.speed) {
4369
- const speed = animation.speed[this.animationData?.speed];
4370
- this.el.nativeElement.style.setProperty('position', 'relative');
4371
- this.el.nativeElement.style.setProperty('animation-name', this.name);
4372
- this.el.nativeElement.style.setProperty('animation-duration', this.getAnimationSpeed(this.animationData.speed));
4334
+ default:
4335
+ return ''; // no animation
4373
4336
  }
4374
4337
  }
4375
4338
  getAnimationSpeed(speed) {
4376
- let speedInSec = '';
4377
- for (let key of Object.keys(animation.speed)) {
4378
- if (key === speed) {
4379
- speedInSec = animation.speed[key];
4380
- }
4381
- }
4382
- return speedInSec;
4339
+ if (!speed)
4340
+ return null;
4341
+ return animation.speed?.[speed] ?? null;
4383
4342
  }
4384
4343
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AnimationDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: EventsService }], target: i0.ɵɵFactoryTarget.Directive }); }
4385
4344
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: AnimationDirective, isStandalone: true, selector: "[simpoAnimation]", inputs: { animationData: ["simpoAnimation", "animationData"] }, usesOnChanges: true, ngImport: i0 }); }