@sarasanalytics-com/design-system 0.0.107 → 0.0.108

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.
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwb2dyYXBoeS1hbmltYXRpb24taW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50LWxpYnJhcnkvc3JjL2ludGVyZmFjZXMvdHlwb2dyYXBoeS1hbmltYXRpb24taW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFRleHRBbmltYXRpb25Db25maWcge1xuICAgIHdvcmRzOiBzdHJpbmdbXTtcbiAgICBwcmVmaXg/OiBzdHJpbmc7XG4gICAgYW5pbWF0aW9uRGVsYXk/OiBudW1iZXI7XG4gICAgYW5pbWF0aW9uRHVyYXRpb24/OiBudW1iZXI7XG4gIH0iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwb2dyYXBoeS1hbmltYXRpb24taW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50LWxpYnJhcnkvc3JjL2ludGVyZmFjZXMvdHlwb2dyYXBoeS1hbmltYXRpb24taW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFRleHRBbmltYXRpb25Db25maWcge1xuICAgIHdvcmRzOiBzdHJpbmdbXTtcbiAgICBwcmVmaXg/OiBzdHJpbmc7XG4gICAgYW5pbWF0aW9uRGVsYXk/OiBudW1iZXI7XG4gICAgYW5pbWF0aW9uRHVyYXRpb24/OiBudW1iZXI7XG4gICAgc2hvd0ZpcnN0V29yZEltbWVkaWF0ZWx5PzogYm9vbGVhbjsgXG4gIH0iXX0=
@@ -9,25 +9,50 @@ export class TypographyAnimationComponent {
9
9
  words: [],
10
10
  prefix: '',
11
11
  animationDelay: 3000,
12
- animationDuration: 200
12
+ animationDuration: 200,
13
+ showFirstWordImmediately: false
13
14
  };
14
15
  this.currentWordIndex = signal(0);
16
+ this.animationState = signal('initializing');
15
17
  }
16
18
  ngOnInit() {
19
+ // Set animation state to running after a brief initialization period
20
+ // This helps ensure the first word appears immediately when requested
21
+ setTimeout(() => {
22
+ this.animationState.set('running');
23
+ }, 50);
17
24
  this.startAnimation();
18
25
  }
26
+ ngOnChanges(changes) {
27
+ // Check if config has changed and is not the first change
28
+ if (changes['config'] && !changes['config'].firstChange) {
29
+ // Reset the current word index
30
+ this.currentWordIndex.set(0);
31
+ // Clear the existing interval if it exists
32
+ if (this.intervalId) {
33
+ clearInterval(this.intervalId);
34
+ }
35
+ // Restart the animation with the new configuration
36
+ this.startAnimation();
37
+ }
38
+ }
19
39
  ngOnDestroy() {
20
40
  if (this.intervalId) {
21
41
  clearInterval(this.intervalId);
22
42
  }
23
43
  }
24
44
  startAnimation() {
25
- this.intervalId = setInterval(() => {
26
- this.currentWordIndex.update(current => (current + 1) % this.config.words.length);
27
- }, this.config.animationDelay);
45
+ // Trigger the first animation immediately
46
+ this.currentWordIndex.update(current => (current + 1) % this.config.words.length);
47
+ // Add a small delay before starting the interval to ensure DOM is ready
48
+ setTimeout(() => {
49
+ this.intervalId = setInterval(() => {
50
+ this.currentWordIndex.update(current => (current + 1) % this.config.words.length);
51
+ }, this.config.animationDelay || 3000);
52
+ }, 100);
28
53
  }
29
54
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: TypographyAnimationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
30
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: TypographyAnimationComponent, isStandalone: true, selector: "sa-typography-animation", inputs: { config: "config" }, ngImport: i0, template: "<div class=\"text-animation\">\n <span class=\"prefix\" *ngIf=\"config.prefix\">{{ config.prefix }}</span>\n <span class=\"words-wrapper\">\n <ng-container *ngFor=\"let word of config.words; let i = index\">\n <span\n class=\"word\"\n [@slideAnimation]=\"currentWordIndex() === i ? 'visible' : 'hidden'\"\n [style.transition-delay]=\"config.animationDelay + 'ms'\"\n >\n {{ word }}\n </span>\n </ng-container>\n </span>\n </div>", styles: [".text-animation{display:flex;align-items:center;gap:.5rem;color:var(--text-highemphasis, #1C1B20);text-align:center;font-family:var(--font-roboto, Roboto);font-size:var(--small-16px, 16px);font-style:normal;font-weight:400;line-height:24px;letter-spacing:.5px;line-height:1.2;min-height:2.4em}.prefix{white-space:nowrap}.words-wrapper{position:relative;display:inline-block;min-width:6.25rem;height:2.4em;vertical-align:top}.word{position:absolute;left:0;top:50%;width:100%;transform-origin:0 0;white-space:nowrap;opacity:0;display:flex;align-items:center;justify-content:center;will-change:transform,opacity}.word.visible{position:absolute;opacity:1}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], animations: [
55
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: TypographyAnimationComponent, isStandalone: true, selector: "sa-typography-animation", inputs: { config: "config" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"text-animation\">\n <span class=\"prefix\" *ngIf=\"config.prefix\">{{ config.prefix }}</span>\n <span class=\"words-wrapper\">\n <ng-container *ngFor=\"let word of config.words; let i = index\">\n <span\n class=\"word\"\n [@slideAnimation]=\"currentWordIndex() === i ? 'visible' : 'hidden'\"\n [style.transition-delay]=\"config.animationDelay + 'ms'\"\n >\n {{ word }}\n </span>\n </ng-container>\n </span>\n </div>", styles: [".text-animation{display:flex;align-items:center;gap:.5rem;color:var(--text-highemphasis, #1C1B20);text-align:center;font-family:var(--font-roboto, Roboto);font-size:var(--small-16px, 16px);font-style:normal;font-weight:400;line-height:24px;letter-spacing:.5px;line-height:1.2;min-height:2.4em}.prefix{white-space:nowrap}.words-wrapper{position:relative;display:inline-block;min-width:6.25rem;height:2.4em;vertical-align:top}.word{position:absolute;left:0;top:50%;width:100%;transform-origin:0 0;white-space:nowrap;opacity:0;display:flex;align-items:center;justify-content:center;will-change:transform,opacity}.word.visible{position:absolute;opacity:1}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], animations: [
31
56
  trigger('slideAnimation', [
32
57
  state('hidden', style({
33
58
  opacity: 0,
@@ -69,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
69
94
  }], propDecorators: { config: [{
70
95
  type: Input
71
96
  }] } });
72
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwb2dyYXBoeS1hbmltYXRpb24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50LWxpYnJhcnkvc3JjL2xpYi90eXBvZ3JhcGh5LWFuaW1hdGlvbi90eXBvZ3JhcGh5LWFuaW1hdGlvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnQtbGlicmFyeS9zcmMvbGliL3R5cG9ncmFwaHktYW5pbWF0aW9uL3R5cG9ncmFwaHktYW5pbWF0aW9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFxQixNQUFNLEVBQW9CLHVCQUF1QixFQUFzQixNQUFNLGVBQWUsQ0FBQztBQUMzSSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFHL0MsT0FBTyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLFVBQVUsRUFBRSxPQUFPLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQzs7O0FBNkJqRixNQUFNLE9BQU8sNEJBQTRCO0lBMUJ6QztRQTJCVyxXQUFNLEdBQXdCO1lBQ3JDLEtBQUssRUFBRSxFQUFFO1lBQ1QsTUFBTSxFQUFFLEVBQUU7WUFDVixjQUFjLEVBQUUsSUFBSTtZQUNwQixpQkFBaUIsRUFBRSxHQUFHO1NBQ3ZCLENBQUM7UUFFRixxQkFBZ0IsR0FBRyxNQUFNLENBQVMsQ0FBQyxDQUFDLENBQUM7S0FvQnRDO0lBakJDLFFBQVE7UUFDTixJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUNwQixhQUFhLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ2pDLENBQUM7SUFDSCxDQUFDO0lBRU8sY0FBYztRQUNwQixJQUFJLENBQUMsVUFBVSxHQUFHLFdBQVcsQ0FBQyxHQUFHLEVBQUU7WUFDakMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUNyQyxDQUFDLE9BQU8sR0FBRyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQ3pDLENBQUM7UUFDSixDQUFDLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUNqQyxDQUFDOzhHQTNCVSw0QkFBNEI7a0dBQTVCLDRCQUE0QixpSENqQ3pDLDJmQWFRLHNzQkRISSxZQUFZLGtQQUdWO1lBQ1YsT0FBTyxDQUFDLGdCQUFnQixFQUFFO2dCQUN4QixLQUFLLENBQUMsUUFBUSxFQUFFLEtBQUssQ0FBQztvQkFDcEIsT0FBTyxFQUFFLENBQUM7b0JBQ1YsU0FBUyxFQUFFLGlCQUFpQjtpQkFDN0IsQ0FBQyxDQUFDO2dCQUNILEtBQUssQ0FBQyxTQUFTLEVBQUUsS0FBSyxDQUFDO29CQUNyQixPQUFPLEVBQUUsQ0FBQztvQkFDVixTQUFTLEVBQUUsa0JBQWtCO2lCQUM5QixDQUFDLENBQUM7Z0JBQ0gsVUFBVSxDQUFDLG1CQUFtQixFQUFFO29CQUM5QixPQUFPLENBQUMseUJBQXlCLENBQUM7aUJBQ25DLEVBQUUsRUFBRSxNQUFNLEVBQUUsRUFBRSxRQUFRLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQztnQkFDakMsVUFBVSxDQUFDLG1CQUFtQixFQUFFO29CQUM5QixPQUFPLENBQUMsd0JBQXdCLENBQUM7aUJBQ2xDLEVBQUUsRUFBRSxNQUFNLEVBQUUsRUFBRSxRQUFRLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQzthQUNsQyxDQUFDO1NBQ0g7OzJGQUdVLDRCQUE0QjtrQkExQnhDLFNBQVM7K0JBQ0UseUJBQXlCLGNBQ3ZCLElBQUksV0FDUCxDQUFDLFlBQVksQ0FBQyxjQUdYO3dCQUNWLE9BQU8sQ0FBQyxnQkFBZ0IsRUFBRTs0QkFDeEIsS0FBSyxDQUFDLFFBQVEsRUFBRSxLQUFLLENBQUM7Z0NBQ3BCLE9BQU8sRUFBRSxDQUFDO2dDQUNWLFNBQVMsRUFBRSxpQkFBaUI7NkJBQzdCLENBQUMsQ0FBQzs0QkFDSCxLQUFLLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQztnQ0FDckIsT0FBTyxFQUFFLENBQUM7Z0NBQ1YsU0FBUyxFQUFFLGtCQUFrQjs2QkFDOUIsQ0FBQyxDQUFDOzRCQUNILFVBQVUsQ0FBQyxtQkFBbUIsRUFBRTtnQ0FDOUIsT0FBTyxDQUFDLHlCQUF5QixDQUFDOzZCQUNuQyxFQUFFLEVBQUUsTUFBTSxFQUFFLEVBQUUsUUFBUSxFQUFFLEdBQUcsRUFBRSxFQUFFLENBQUM7NEJBQ2pDLFVBQVUsQ0FBQyxtQkFBbUIsRUFBRTtnQ0FDOUIsT0FBTyxDQUFDLHdCQUF3QixDQUFDOzZCQUNsQyxFQUFFLEVBQUUsTUFBTSxFQUFFLEVBQUUsUUFBUSxFQUFFLEdBQUcsRUFBRSxFQUFFLENBQUM7eUJBQ2xDLENBQUM7cUJBQ0gsbUJBQ2dCLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLE1BQU07c0JBQWQsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCwgT25EZXN0cm95LCBzaWduYWwsIGNvbXB1dGVkLCBlZmZlY3QsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBEZXN0cm95UmVmLCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBpbnRlcnZhbCwgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgdGFrZVVudGlsIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuaW1wb3J0IHsgdHJpZ2dlciwgc3RhdGUsIHN0eWxlLCB0cmFuc2l0aW9uLCBhbmltYXRlIH0gZnJvbSAnQGFuZ3VsYXIvYW5pbWF0aW9ucyc7XG5pbXBvcnQgeyBUZXh0QW5pbWF0aW9uQ29uZmlnIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy90eXBvZ3JhcGh5LWFuaW1hdGlvbi1pbnRlcmZhY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzYS10eXBvZ3JhcGh5LWFuaW1hdGlvbicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZVVybDogJy4vdHlwb2dyYXBoeS1hbmltYXRpb24uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vdHlwb2dyYXBoeS1hbmltYXRpb24uY29tcG9uZW50LmNzcycsXG4gIGFuaW1hdGlvbnM6IFtcbiAgICB0cmlnZ2VyKCdzbGlkZUFuaW1hdGlvbicsIFtcbiAgICAgIHN0YXRlKCdoaWRkZW4nLCBzdHlsZSh7XG4gICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoMXB4KSdcbiAgICAgIH0pKSxcbiAgICAgIHN0YXRlKCd2aXNpYmxlJywgc3R5bGUoe1xuICAgICAgICBvcGFjaXR5OiAxLFxuICAgICAgICB0cmFuc2Zvcm06ICd0cmFuc2xhdGVZKC01MCUpJ1xuICAgICAgfSkpLFxuICAgICAgdHJhbnNpdGlvbignaGlkZGVuID0+IHZpc2libGUnLCBbXG4gICAgICAgIGFuaW1hdGUoJ3t7ZHVyYXRpb259fW1zIGVhc2Utb3V0JylcbiAgICAgIF0sIHsgcGFyYW1zOiB7IGR1cmF0aW9uOiAzMDAgfSB9KSxcbiAgICAgIHRyYW5zaXRpb24oJ3Zpc2libGUgPT4gaGlkZGVuJywgW1xuICAgICAgICBhbmltYXRlKCd7e2R1cmF0aW9ufX1tcyBlYXNlLWluJylcbiAgICAgIF0sIHsgcGFyYW1zOiB7IGR1cmF0aW9uOiAzMDAgfSB9KVxuICAgIF0pXG4gIF0sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIFR5cG9ncmFwaHlBbmltYXRpb25Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gIEBJbnB1dCgpIGNvbmZpZzogVGV4dEFuaW1hdGlvbkNvbmZpZyA9IHtcbiAgICB3b3JkczogW10sXG4gICAgcHJlZml4OiAnJyxcbiAgICBhbmltYXRpb25EZWxheTogMzAwMCxcbiAgICBhbmltYXRpb25EdXJhdGlvbjogMjAwXG4gIH07XG5cbiAgY3VycmVudFdvcmRJbmRleCA9IHNpZ25hbDxudW1iZXI+KDApO1xuICBwcml2YXRlIGludGVydmFsSWQ6IGFueTtcblxuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLnN0YXJ0QW5pbWF0aW9uKCk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpIHtcbiAgICBpZiAodGhpcy5pbnRlcnZhbElkKSB7XG4gICAgICBjbGVhckludGVydmFsKHRoaXMuaW50ZXJ2YWxJZCk7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBzdGFydEFuaW1hdGlvbigpIHtcbiAgICB0aGlzLmludGVydmFsSWQgPSBzZXRJbnRlcnZhbCgoKSA9PiB7XG4gICAgICB0aGlzLmN1cnJlbnRXb3JkSW5kZXgudXBkYXRlKGN1cnJlbnQgPT4gXG4gICAgICAgIChjdXJyZW50ICsgMSkgJSB0aGlzLmNvbmZpZy53b3Jkcy5sZW5ndGhcbiAgICAgICk7XG4gICAgfSwgdGhpcy5jb25maWcuYW5pbWF0aW9uRGVsYXkpO1xuICB9XG59IiwiPGRpdiBjbGFzcz1cInRleHQtYW5pbWF0aW9uXCI+XG4gICAgPHNwYW4gY2xhc3M9XCJwcmVmaXhcIiAqbmdJZj1cImNvbmZpZy5wcmVmaXhcIj57eyBjb25maWcucHJlZml4IH19PC9zcGFuPlxuICAgIDxzcGFuIGNsYXNzPVwid29yZHMtd3JhcHBlclwiPlxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgd29yZCBvZiBjb25maWcud29yZHM7IGxldCBpID0gaW5kZXhcIj5cbiAgICAgICAgPHNwYW5cbiAgICAgICAgICBjbGFzcz1cIndvcmRcIlxuICAgICAgICAgIFtAc2xpZGVBbmltYXRpb25dPVwiY3VycmVudFdvcmRJbmRleCgpID09PSBpID8gJ3Zpc2libGUnIDogJ2hpZGRlbidcIlxuICAgICAgICAgIFtzdHlsZS50cmFuc2l0aW9uLWRlbGF5XT1cImNvbmZpZy5hbmltYXRpb25EZWxheSArICdtcydcIlxuICAgICAgICA+XG4gICAgICAgICAge3sgd29yZCB9fVxuICAgICAgICA8L3NwYW4+XG4gICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8L3NwYW4+XG4gIDwvZGl2PiJdfQ==
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"typography-animation.component.js","sourceRoot":"","sources":["../../../../../projects/component-library/src/lib/typography-animation/typography-animation.component.ts","../../../../../projects/component-library/src/lib/typography-animation/typography-animation.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAA+C,MAAM,EAAoB,uBAAuB,EAAsB,MAAM,eAAe,CAAC;AACrK,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAG/C,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;;;AA6BjF,MAAM,OAAO,4BAA4B;IA1BzC;QA2BW,WAAM,GAAwB;YACrC,KAAK,EAAE,EAAE;YACT,MAAM,EAAE,EAAE;YACV,cAAc,EAAE,IAAI;YACpB,iBAAiB,EAAE,GAAG;YACtB,wBAAwB,EAAE,KAAK;SAChC,CAAC;QAEF,qBAAgB,GAAG,MAAM,CAAS,CAAC,CAAC,CAAC;QACrC,mBAAc,GAAG,MAAM,CAA6B,cAAc,CAAC,CAAC;KAkDrE;IA/CC,QAAQ;QACN,qEAAqE;QACrE,sEAAsE;QACtE,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACrC,CAAC,EAAE,EAAE,CAAC,CAAC;QAEP,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,0DAA0D;QAC1D,IAAI,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC;YACxD,+BAA+B;YAC/B,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAE7B,2CAA2C;YAC3C,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;gBACpB,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACjC,CAAC;YAED,mDAAmD;YACnD,IAAI,CAAC,cAAc,EAAE,CAAC;QACxB,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACjC,CAAC;IACH,CAAC;IAEO,cAAc;QACpB,0CAA0C;QAC1C,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CACrC,CAAC,OAAO,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CACzC,CAAC;QAEF,wEAAwE;QACxE,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,UAAU,GAAG,WAAW,CAAC,GAAG,EAAE;gBACjC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CACrC,CAAC,OAAO,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CACzC,CAAC;YACJ,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,cAAc,IAAI,IAAI,CAAC,CAAC;QACzC,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;8GA3DU,4BAA4B;kGAA5B,4BAA4B,sICjCzC,2fAaQ,ssBDHI,YAAY,kPAGV;YACV,OAAO,CAAC,gBAAgB,EAAE;gBACxB,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC;oBACpB,OAAO,EAAE,CAAC;oBACV,SAAS,EAAE,iBAAiB;iBAC7B,CAAC,CAAC;gBACH,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC;oBACrB,OAAO,EAAE,CAAC;oBACV,SAAS,EAAE,kBAAkB;iBAC9B,CAAC,CAAC;gBACH,UAAU,CAAC,mBAAmB,EAAE;oBAC9B,OAAO,CAAC,yBAAyB,CAAC;iBACnC,EAAE,EAAE,MAAM,EAAE,EAAE,QAAQ,EAAE,GAAG,EAAE,EAAE,CAAC;gBACjC,UAAU,CAAC,mBAAmB,EAAE;oBAC9B,OAAO,CAAC,wBAAwB,CAAC;iBAClC,EAAE,EAAE,MAAM,EAAE,EAAE,QAAQ,EAAE,GAAG,EAAE,EAAE,CAAC;aAClC,CAAC;SACH;;2FAGU,4BAA4B;kBA1BxC,SAAS;+BACE,yBAAyB,cACvB,IAAI,WACP,CAAC,YAAY,CAAC,cAGX;wBACV,OAAO,CAAC,gBAAgB,EAAE;4BACxB,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC;gCACpB,OAAO,EAAE,CAAC;gCACV,SAAS,EAAE,iBAAiB;6BAC7B,CAAC,CAAC;4BACH,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC;gCACrB,OAAO,EAAE,CAAC;gCACV,SAAS,EAAE,kBAAkB;6BAC9B,CAAC,CAAC;4BACH,UAAU,CAAC,mBAAmB,EAAE;gCAC9B,OAAO,CAAC,yBAAyB,CAAC;6BACnC,EAAE,EAAE,MAAM,EAAE,EAAE,QAAQ,EAAE,GAAG,EAAE,EAAE,CAAC;4BACjC,UAAU,CAAC,mBAAmB,EAAE;gCAC9B,OAAO,CAAC,wBAAwB,CAAC;6BAClC,EAAE,EAAE,MAAM,EAAE,EAAE,QAAQ,EAAE,GAAG,EAAE,EAAE,CAAC;yBAClC,CAAC;qBACH,mBACgB,uBAAuB,CAAC,MAAM;8BAGtC,MAAM;sBAAd,KAAK","sourcesContent":["import { Component, Input, OnInit, OnDestroy, OnChanges, SimpleChanges, signal, computed, effect, ChangeDetectionStrategy, DestroyRef, inject } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { interval, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { trigger, state, style, transition, animate } from '@angular/animations';\nimport { TextAnimationConfig } from '../../interfaces/typography-animation-interface';\n\n@Component({\n  selector: 'sa-typography-animation',\n  standalone: true,\n  imports: [CommonModule],\n  templateUrl: './typography-animation.component.html',\n  styleUrl: './typography-animation.component.css',\n  animations: [\n    trigger('slideAnimation', [\n      state('hidden', style({\n        opacity: 0,\n        transform: 'translateY(1px)'\n      })),\n      state('visible', style({\n        opacity: 1,\n        transform: 'translateY(-50%)'\n      })),\n      transition('hidden => visible', [\n        animate('{{duration}}ms ease-out')\n      ], { params: { duration: 300 } }),\n      transition('visible => hidden', [\n        animate('{{duration}}ms ease-in')\n      ], { params: { duration: 300 } })\n    ])\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TypographyAnimationComponent implements OnInit, OnDestroy, OnChanges {\n  @Input() config: TextAnimationConfig = {\n    words: [],\n    prefix: '',\n    animationDelay: 3000,\n    animationDuration: 200,\n    showFirstWordImmediately: false\n  };\n\n  currentWordIndex = signal<number>(0);\n  animationState = signal<'initializing' | 'running'>('initializing');\n  private intervalId: any;\n\n  ngOnInit() {\n    // Set animation state to running after a brief initialization period\n    // This helps ensure the first word appears immediately when requested\n    setTimeout(() => {\n      this.animationState.set('running');\n    }, 50);\n    \n    this.startAnimation();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    // Check if config has changed and is not the first change\n    if (changes['config'] && !changes['config'].firstChange) {\n      // Reset the current word index\n      this.currentWordIndex.set(0);\n      \n      // Clear the existing interval if it exists\n      if (this.intervalId) {\n        clearInterval(this.intervalId);\n      }\n      \n      // Restart the animation with the new configuration\n      this.startAnimation();\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.intervalId) {\n      clearInterval(this.intervalId);\n    }\n  }\n\n  private startAnimation() {\n    // Trigger the first animation immediately\n    this.currentWordIndex.update(current => \n      (current + 1) % this.config.words.length\n    );\n\n    // Add a small delay before starting the interval to ensure DOM is ready\n    setTimeout(() => {\n      this.intervalId = setInterval(() => {\n        this.currentWordIndex.update(current => \n          (current + 1) % this.config.words.length\n        );\n      }, this.config.animationDelay || 3000);\n    }, 100);\n  }\n}","<div class=\"text-animation\">\n    <span class=\"prefix\" *ngIf=\"config.prefix\">{{ config.prefix }}</span>\n    <span class=\"words-wrapper\">\n      <ng-container *ngFor=\"let word of config.words; let i = index\">\n        <span\n          class=\"word\"\n          [@slideAnimation]=\"currentWordIndex() === i ? 'visible' : 'hidden'\"\n          [style.transition-delay]=\"config.animationDelay + 'ms'\"\n        >\n          {{ word }}\n        </span>\n      </ng-container>\n    </span>\n  </div>"]}
@@ -3090,25 +3090,50 @@ class TypographyAnimationComponent {
3090
3090
  words: [],
3091
3091
  prefix: '',
3092
3092
  animationDelay: 3000,
3093
- animationDuration: 200
3093
+ animationDuration: 200,
3094
+ showFirstWordImmediately: false
3094
3095
  };
3095
3096
  this.currentWordIndex = signal(0);
3097
+ this.animationState = signal('initializing');
3096
3098
  }
3097
3099
  ngOnInit() {
3100
+ // Set animation state to running after a brief initialization period
3101
+ // This helps ensure the first word appears immediately when requested
3102
+ setTimeout(() => {
3103
+ this.animationState.set('running');
3104
+ }, 50);
3098
3105
  this.startAnimation();
3099
3106
  }
3107
+ ngOnChanges(changes) {
3108
+ // Check if config has changed and is not the first change
3109
+ if (changes['config'] && !changes['config'].firstChange) {
3110
+ // Reset the current word index
3111
+ this.currentWordIndex.set(0);
3112
+ // Clear the existing interval if it exists
3113
+ if (this.intervalId) {
3114
+ clearInterval(this.intervalId);
3115
+ }
3116
+ // Restart the animation with the new configuration
3117
+ this.startAnimation();
3118
+ }
3119
+ }
3100
3120
  ngOnDestroy() {
3101
3121
  if (this.intervalId) {
3102
3122
  clearInterval(this.intervalId);
3103
3123
  }
3104
3124
  }
3105
3125
  startAnimation() {
3106
- this.intervalId = setInterval(() => {
3107
- this.currentWordIndex.update(current => (current + 1) % this.config.words.length);
3108
- }, this.config.animationDelay);
3126
+ // Trigger the first animation immediately
3127
+ this.currentWordIndex.update(current => (current + 1) % this.config.words.length);
3128
+ // Add a small delay before starting the interval to ensure DOM is ready
3129
+ setTimeout(() => {
3130
+ this.intervalId = setInterval(() => {
3131
+ this.currentWordIndex.update(current => (current + 1) % this.config.words.length);
3132
+ }, this.config.animationDelay || 3000);
3133
+ }, 100);
3109
3134
  }
3110
3135
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: TypographyAnimationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
3111
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: TypographyAnimationComponent, isStandalone: true, selector: "sa-typography-animation", inputs: { config: "config" }, ngImport: i0, template: "<div class=\"text-animation\">\n <span class=\"prefix\" *ngIf=\"config.prefix\">{{ config.prefix }}</span>\n <span class=\"words-wrapper\">\n <ng-container *ngFor=\"let word of config.words; let i = index\">\n <span\n class=\"word\"\n [@slideAnimation]=\"currentWordIndex() === i ? 'visible' : 'hidden'\"\n [style.transition-delay]=\"config.animationDelay + 'ms'\"\n >\n {{ word }}\n </span>\n </ng-container>\n </span>\n </div>", styles: [".text-animation{display:flex;align-items:center;gap:.5rem;color:var(--text-highemphasis, #1C1B20);text-align:center;font-family:var(--font-roboto, Roboto);font-size:var(--small-16px, 16px);font-style:normal;font-weight:400;line-height:24px;letter-spacing:.5px;line-height:1.2;min-height:2.4em}.prefix{white-space:nowrap}.words-wrapper{position:relative;display:inline-block;min-width:6.25rem;height:2.4em;vertical-align:top}.word{position:absolute;left:0;top:50%;width:100%;transform-origin:0 0;white-space:nowrap;opacity:0;display:flex;align-items:center;justify-content:center;will-change:transform,opacity}.word.visible{position:absolute;opacity:1}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], animations: [
3136
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: TypographyAnimationComponent, isStandalone: true, selector: "sa-typography-animation", inputs: { config: "config" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"text-animation\">\n <span class=\"prefix\" *ngIf=\"config.prefix\">{{ config.prefix }}</span>\n <span class=\"words-wrapper\">\n <ng-container *ngFor=\"let word of config.words; let i = index\">\n <span\n class=\"word\"\n [@slideAnimation]=\"currentWordIndex() === i ? 'visible' : 'hidden'\"\n [style.transition-delay]=\"config.animationDelay + 'ms'\"\n >\n {{ word }}\n </span>\n </ng-container>\n </span>\n </div>", styles: [".text-animation{display:flex;align-items:center;gap:.5rem;color:var(--text-highemphasis, #1C1B20);text-align:center;font-family:var(--font-roboto, Roboto);font-size:var(--small-16px, 16px);font-style:normal;font-weight:400;line-height:24px;letter-spacing:.5px;line-height:1.2;min-height:2.4em}.prefix{white-space:nowrap}.words-wrapper{position:relative;display:inline-block;min-width:6.25rem;height:2.4em;vertical-align:top}.word{position:absolute;left:0;top:50%;width:100%;transform-origin:0 0;white-space:nowrap;opacity:0;display:flex;align-items:center;justify-content:center;will-change:transform,opacity}.word.visible{position:absolute;opacity:1}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], animations: [
3112
3137
  trigger('slideAnimation', [
3113
3138
  state('hidden', style({
3114
3139
  opacity: 0,